tauri-mcp-testing

Tauri MCP E2E Testing

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "tauri-mcp-testing" with this command: npx skills add xiaolai/vmark/xiaolai-vmark-tauri-mcp-testing

Tauri MCP E2E Testing

CRITICAL: For E2E testing of Tauri applications, ALWAYS use tauri_* MCP tools. NEVER use Chrome DevTools MCP - that's for browser pages only.

Quick Reference

Task MCP Tool

Connect to app tauri_driver_session

Take screenshot tauri_webview_screenshot

Find elements tauri_webview_find_element

Click/scroll/swipe tauri_webview_interact

Type text tauri_webview_keyboard

Wait for element tauri_webview_wait_for

Execute JS tauri_webview_execute_js

Get CSS styles tauri_webview_get_styles

Test IPC commands tauri_ipc_execute_command

Monitor IPC calls tauri_ipc_monitor

Read console logs tauri_read_logs

Manage windows tauri_manage_window

Prerequisites

  • MCP Bridge Plugin installed in the Tauri app

  • App running in development mode (pnpm tauri dev )

  • Port 9223 accessible (default MCP Bridge port)

If connection fails, run tauri_get_setup_instructions to get plugin installation guide.

Core Workflow

  1. START SESSION → Connect to running Tauri app
  2. VERIFY STATE → Screenshot + find elements
  3. INTERACT → Click, type, scroll
  4. WAIT → Wait for expected results
  5. VERIFY → Check IPC, logs, DOM state
  6. CLEANUP → Stop session when done

Session Management

Start Session

// Connect to app on default port tauri_driver_session({ action: 'start' })

// Connect to specific port tauri_driver_session({ action: 'start', port: 9224 })

// Connect to remote host (mobile testing) tauri_driver_session({ action: 'start', host: '<device-ip>', port: 9223 })

Check Status

tauri_driver_session({ action: 'status' }) // Returns: connected apps, default app, identifiers

Stop Session

// Stop all sessions tauri_driver_session({ action: 'stop' })

// Stop specific app tauri_driver_session({ action: 'stop', appIdentifier: 9223 })

Testing Patterns

Pattern 1: Visual Verification

// 1. Take screenshot to see current state tauri_webview_screenshot()

// 2. Take screenshot of specific element tauri_webview_screenshot({ uid: 'editor-content' })

// 3. Save to file for comparison tauri_webview_screenshot({ filePath: 'dev-docs/archive/test-screenshots/test-screenshot.png' })

Pattern 2: Element Interaction

// 1. Find element first tauri_webview_find_element({ selector: '.save-button' })

// 2. Click element tauri_webview_interact({ action: 'click', selector: '.save-button' })

// 3. Double-click tauri_webview_interact({ action: 'double-click', selector: '.editor' })

// 4. Long-press (touch simulation) tauri_webview_interact({ action: 'long-press', selector: '.item', duration: 500 })

// 5. Scroll tauri_webview_interact({ action: 'scroll', selector: '.content', scrollY: 500 })

// 6. Swipe tauri_webview_interact({ action: 'swipe', fromX: 300, fromY: 400, toX: 100, toY: 400, duration: 300 })

Pattern 3: Keyboard Input

// Type into focused element tauri_webview_keyboard({ action: 'type', selector: '.editor-input', text: '# Hello World' })

// Press key tauri_webview_keyboard({ action: 'press', key: 'Enter' })

// Key with modifiers tauri_webview_keyboard({ action: 'press', key: 's', modifiers: ['Control'] // Ctrl+S })

// Key combinations tauri_webview_keyboard({ action: 'press', key: 'z', modifiers: ['Meta', 'Shift'] // Cmd+Shift+Z (redo on macOS) })

Pattern 4: Wait for State

// Wait for element to appear tauri_webview_wait_for({ type: 'selector', value: '.success-toast', timeout: 5000 })

// Wait for text to appear tauri_webview_wait_for({ type: 'text', value: 'File saved successfully', timeout: 3000 })

// Wait for IPC event tauri_webview_wait_for({ type: 'ipc-event', value: 'file-saved', timeout: 5000 })

Pattern 5: IPC Testing

// Start monitoring IPC calls tauri_ipc_monitor({ action: 'start' })

// Perform action that triggers IPC tauri_webview_interact({ action: 'click', selector: '.save-button' })

// Get captured IPC calls tauri_ipc_get_captured({ filter: 'save_file' })

// Execute IPC command directly tauri_ipc_execute_command({ command: 'get_document_state', args: { id: 'doc-123' } })

// Emit event to test handlers tauri_ipc_emit_event({ eventName: 'file-changed', payload: { path: '/test/file.md' } })

// Stop monitoring tauri_ipc_monitor({ action: 'stop' })

Pattern 6: JavaScript Execution

// Get value from DOM (MUST use IIFE for return values) tauri_webview_execute_js({ script: '(() => { return document.querySelector(".editor").textContent; })()' })

// Check Tauri API available tauri_webview_execute_js({ script: '(() => { return typeof window.TAURI !== "undefined"; })()' })

// Get computed style tauri_webview_execute_js({ script: '(() => { return getComputedStyle(document.body).backgroundColor; })()' })

// Trigger custom event tauri_webview_execute_js({ script: 'document.dispatchEvent(new CustomEvent("test-event", { detail: { test: true } }))' })

Debugging

Read Console Logs

// Get recent console logs tauri_read_logs({ source: 'console', lines: 50 })

// Filter logs tauri_read_logs({ source: 'console', filter: 'error', lines: 100 })

// Logs since specific time tauri_read_logs({ source: 'console', since: '2024-01-01T10:00:00Z', lines: 50 })

Platform-Specific Logs

// Desktop system logs tauri_read_logs({ source: 'system', lines: 100 })

// Android logcat tauri_read_logs({ source: 'android', filter: 'vmark', lines: 100 })

// iOS simulator logs tauri_read_logs({ source: 'ios', lines: 100 })

Window Management

// List all windows tauri_manage_window({ action: 'list' })

// Get window info tauri_manage_window({ action: 'info', windowId: 'main' })

// Resize window for responsive testing tauri_manage_window({ action: 'resize', width: 800, height: 600 })

// Resize specific window tauri_manage_window({ action: 'resize', windowId: 'settings', width: 400, height: 300 })

Get CSS Styles

// Get all computed styles tauri_webview_get_styles({ selector: '.editor' })

// Get specific properties tauri_webview_get_styles({ selector: '.editor', properties: ['font-size', 'color', 'background-color'] })

// Get styles from multiple elements tauri_webview_get_styles({ selector: '.toolbar button', multiple: true, properties: ['opacity', 'visibility'] })

Common Test Scenarios

Scenario: File Operations

// 1. Connect tauri_driver_session({ action: 'start' })

// 2. Open file dialog tauri_webview_keyboard({ action: 'press', key: 'o', modifiers: ['Control'] })

// 3. Wait for content to load (using IPC) tauri_ipc_monitor({ action: 'start' }) // ... file selection happens externally or via mocked dialog ... tauri_ipc_get_captured({ filter: 'read_file' })

// 4. Verify content loaded tauri_webview_find_element({ selector: '.editor-content' }) tauri_webview_execute_js({ script: '(() => { return document.querySelector(".editor-content").textContent.length > 0; })()' })

Scenario: Editor Typing

// 1. Focus editor tauri_webview_interact({ action: 'click', selector: '.editor' })

// 2. Type content tauri_webview_keyboard({ action: 'type', selector: '.editor [contenteditable]', text: '# Test Document\n\nThis is a test.' })

// 3. Verify dirty state tauri_webview_find_element({ selector: '[data-dirty="true"]' })

// 4. Save with Ctrl+S tauri_webview_keyboard({ action: 'press', key: 's', modifiers: ['Control'] })

// 5. Verify saved tauri_webview_wait_for({ type: 'selector', value: '[data-dirty="false"]' })

Scenario: Responsive Testing

// Test mobile viewport tauri_manage_window({ action: 'resize', width: 375, height: 667 }) tauri_webview_screenshot({ filePath: 'dev-docs/archive/test-screenshots/mobile.png' }) tauri_webview_find_element({ selector: '.mobile-menu-button' })

// Test tablet viewport tauri_manage_window({ action: 'resize', width: 768, height: 1024 }) tauri_webview_screenshot({ filePath: 'dev-docs/archive/test-screenshots/tablet.png' })

// Test desktop viewport tauri_manage_window({ action: 'resize', width: 1920, height: 1080 }) tauri_webview_screenshot({ filePath: 'dev-docs/archive/test-screenshots/desktop.png' })

Troubleshooting

Issue Solution

Connection refused Ensure app is running with pnpm tauri dev

No elements found Check selector, take screenshot to verify DOM

IPC not captured Start monitor BEFORE the action

Timeout on wait Increase timeout, check if element ever appears

JS returns undefined Use IIFE syntax: (() => { return value; })()

Plugin not found Run tauri_get_setup_instructions

Reference Files

Topic File

Session management references/session-management.md

Webview testing references/webview-testing.md

IPC testing references/ipc-testing.md

Debugging references/debugging.md

Related Skills

  • tauri-app-dev — General Tauri 2.0 patterns (commands, state, plugins, security)

  • tauri-v2-integration — VMark-specific IPC patterns (invoke/emit bridges, menu accelerators)

  • rust-tauri-backend — VMark Rust backend implementation

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

General

tiptap-editor

No summary provided by upstream source.

Repository SourceNeeds Review
General

rust-tauri-backend

No summary provided by upstream source.

Repository SourceNeeds Review
General

tauri-mcp-test-runner

No summary provided by upstream source.

Repository SourceNeeds Review