JSPM

  • Created
  • Published
  • Downloads 265
  • Score
    100M100P100Q127703F
  • License Apache-2.0

MCP server for Chrome extension development with Web Store automation. Fork of chrome-devtools-mcp with extension-specific tools.

Package Exports

    This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (chrome-devtools-mcp-for-extension) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

    Readme

    Chrome DevTools MCP for Extension Development

    npm chrome-devtools-mcp-for-extension package

    AI-powered Chrome extension development with automated testing, debugging, and Web Store submission

    System extensions auto-load, development extensions easy to configure.

    Built for: Claude Code, Cursor, VS Code Copilot, Cline, and other MCP-compatible AI tools


    ๐ŸŽฏ Why This Tool?

    The Problem

    • Puppeteer/Playwright: Disable extensions by default, require complex configuration
    • Traditional Testing: Hours of setup, maintaining separate test profiles
    • Extension Development: Can't test in real user environments

    The Solution

    • โœ… System extensions auto-load: Your installed Chrome extensions work automatically
    • โœ… Easy dev extension setup: Simple --loadExtensionsDir configuration for development
    • โœ… Real environment: Tests with your actual extensions and settings
    • โœ… Independent instance: Runs alongside your regular Chrome without conflicts

    ๐Ÿš€ Quick Start

    1. Add Configuration

    Add the following to ~/.claude.json:

    {
      "mcpServers": {
        "chrome-devtools-extension": {
          "type": "stdio",
          "command": "npx",
          "args": ["chrome-devtools-mcp-for-extension@latest"],
          "env": {}
        }
      }
    }

    Note: For other MCP clients (Cursor, VS Code Copilot, Cline), add to your client's global configuration file.

    2. Restart Your AI Client

    3. Test It

    Ask your AI:

    "List all my Chrome extensions"

    โœ… You should see your installed Chrome extensions


    ๐Ÿ”ง Load Development Extensions (Optional)

    To test your own extensions under development, add --loadExtensionsDir:

    {
      "mcpServers": {
        "chrome-devtools-extension": {
          "command": "npx",
          "args": [
            "chrome-devtools-mcp-for-extension@latest",
            "--loadExtensionsDir=/path/to/your/extensions"
          ]
        }
      }
    }

    Directory structure example:

    /path/to/your/extensions/
    โ”œโ”€โ”€ my-extension-1/
    โ”‚   โ””โ”€โ”€ manifest.json
    โ”œโ”€โ”€ my-extension-2/
    โ”‚   โ””โ”€โ”€ manifest.json

    More options: See MCP Configuration Guide


    โœจ Core Capabilities

    • ๐Ÿงฉ Extension Development: Load, debug, and reload Chrome extensions during development
    • ๐Ÿช Automated Web Store Submission: Complete publishing workflow with form filling and screenshots
    • ๐Ÿ”ง Browser Testing: Test extensions across real websites with full Chrome functionality
    • ๐Ÿ› Advanced Debugging: Service worker inspection, console monitoring, error detection
    • ๐Ÿ“ธ Screenshot Generation: Auto-create store listing images in all required formats

    ๐Ÿ“š Common Workflows

    Create & Test Extension

    1. "Create a Chrome extension that blocks ads on YouTube"
    2. "List extensions to verify it loaded"
    3. "Test the extension on youtube.com"
    4. "Show any errors from the extension"

    Debug Extension Issues

    1. "List extensions and show any errors"
    2. "Inspect service worker for my-ad-blocker"
    3. "Show console messages from the extension"
    4. "Reload the extension with latest changes"

    Publish to Web Store

    1. "Generate screenshots for my extension"
    2. "Validate my manifest for Web Store compliance"
    3. "Submit my extension to Chrome Web Store"

    Performance Testing

    1. "Start performance trace on current page"
    2. "Test the extension's impact on page load"
    3. "Show performance insights"

    ๐Ÿ” Check Installed Version

    To verify which version is being used by your AI client:

    "What version of chrome-devtools-mcp-for-extension are you using?"

    The AI will call the tool with --version flag to check.

    Troubleshooting cache issues:

    • If you're not getting the latest version with @latest:
      • Clear npx cache: npx clear-npx-cache or rm -rf ~/.npm/_npx
      • Or use specific version: chrome-devtools-mcp-for-extension@0.8.1
      • Restart your AI client completely

    Direct check (manual):

    npx chrome-devtools-mcp-for-extension@latest --version

    ๐Ÿ› ๏ธ Extension Development Tools

    Quick reference for the 3 core extension tools:

    Tool Purpose Example Command
    list_extensions View all extensions with status "List all my Chrome extensions"
    reload_extension Hot-reload during development "Reload my-extension"
    inspect_service_worker Debug background scripts "Debug service worker for my-extension"

    ๐Ÿ“Š How It Compares

    Feature This Tool Puppeteer/Playwright Original chrome-devtools-mcp
    Extension Support โœ… Always enabled โŒ Disabled by default โš ๏ธ Manual config required
    Setup Required โŒ None โœ… Complex config files โœ… Multiple flags needed
    Real User Profile โœ… Direct access โŒ Temporary profiles โš ๏ธ Optional
    Profile Copying โŒ No copying needed โš ๏ธ Manual setup โš ๏ธ Manual setup
    Web Store Automation โœ… Built-in โŒ None โŒ None
    Extension Debugging โœ… Service worker + console โš ๏ธ Limited โŒ None

    ๐Ÿ“– Detailed Tool Documentation

    list_extensions - Extension Inventory

    Purpose: Comprehensive extension status monitoring Technical: Accesses chrome://extensions/ via shadow DOM manipulation Output: Extension metadata, enabled/disabled status, version, error detection Use Case: "List all my Chrome extensions" โ†’ Shows development and installed extensions

    reload_extension - Development Hot-Reload

    Purpose: Streamlined extension development workflow Technical: Finds extensions by name/partial match, triggers reload via Chrome extension API Output: Confirmation of reload success/failure with error details Use Case: "Reload my ad-blocker extension" โ†’ Instantly applies code changes

    inspect_service_worker - Debug Integration

    Purpose: Deep debugging of extension background processes Technical: Opens DevTools for service workers, supports Manifest V2/V3 architectures Output: Direct DevTools access to extension console, network, sources Use Case: "Debug why my content script isn't working" โ†’ Opens debugging interface


    โš™๏ธ Advanced Configuration

    Auto-load Development Extension

    Add to ~/.claude.json:

    {
      "mcpServers": {
        "chrome-devtools-extension": {
          "type": "stdio",
          "command": "npx",
          "args": [
            "chrome-devtools-mcp-for-extension@latest",
            "--loadExtension=/path/to/your/extension"
          ],
          "env": {}
        }
      }
    }

    โš ๏ธ Note: --loadExtension flag may be deprecated in Chrome 137+. Using system profile (default) is recommended.

    Debug Mode

    Add to ~/.claude.json:

    {
      "mcpServers": {
        "chrome-devtools-extension": {
          "type": "stdio",
          "command": "npx",
          "args": ["chrome-devtools-mcp-for-extension@latest"],
          "env": {
            "DEBUG": "mcp:*"
          }
        }
      }
    }

    Custom Chrome Channel

    Add to ~/.claude.json:

    {
      "mcpServers": {
        "chrome-devtools-extension": {
          "type": "stdio",
          "command": "npx",
          "args": [
            "chrome-devtools-mcp-for-extension@latest",
            "--channel=canary"
          ],
          "env": {}
        }
      }
    }

    Options: stable (default), beta, dev, canary

    Isolated Profile Mode

    Add to ~/.claude.json:

    {
      "mcpServers": {
        "chrome-devtools-extension": {
          "type": "stdio",
          "command": "npx",
          "args": [
            "chrome-devtools-mcp-for-extension@latest",
            "--isolated"
          ],
          "env": {}
        }
      }
    }

    Forces temporary profile instead of system profile.


    ๐Ÿ—๏ธ Technical Architecture & Implementation

    What Makes This Different

    This fork significantly restructures the original Chrome DevTools MCP for extension-focused development:

    System Profile Architecture (v0.6.0+)

    Zero-Config Design:

    // Automatically detects and uses system Chrome profile
    if (!isolated && !userDataDir) {
      const systemProfile = detectSystemChromeProfile(channel) || detectAnySystemChromeProfile();
    
      if (systemProfile) {
        userDataDir = systemProfile.path;  // Direct access, no copying
        usingSystemProfile = true;
      }
    }

    Profile Paths:

    • macOS: ~/Library/Application Support/Google/Chrome
    • Windows: %LOCALAPPDATA%\Google\Chrome\User Data
    • Linux: ~/.config/google-chrome

    Detection Priority:

    1. Specified channel (via --channel flag)
    2. Fallback: stable โ†’ beta โ†’ dev โ†’ canary
    3. Last resort: Creates temporary isolated profile

    Extension Loading Architecture

    Unconditional Extension Enablement (v0.6.1+):

    // Always remove --disable-extensions flag
    ignoreDefaultArgs: ['--disable-extensions', '--enable-automation']

    Why this design:

    • Puppeteer's default --disable-extensions conflicts with extension development
    • Previous versions used conditional logic (buggy, removed in v0.6.1)
    • Current approach: Always enable all extensions for predictable behavior

    Chrome Security Challenges Solved

    Chrome 137+ Breaking Changes

    • Problem: Chrome 137+ disabled --load-extension in automation contexts
    • Solution: Added --disable-features=DisableLoadExtensionCommandLineSwitch bypass
    • Impact: Development extensions can still be loaded via CLI flags

    Automation Detection Bypass

    • Problem: Chrome blocks many operations when detecting automated control
    • Solution: --disable-blink-features=AutomationControlled for real-world testing
    • Use Case: Google login, OAuth flows, Web Store submission

    Profile Management Strategy

    • Default: Direct system profile access (no copying, instant sync)
    • Fallback: Temporary profile with bookmarks copy (when Chrome is already running)
    • Override: --isolated flag for completely separate profile

    Architecture Diagram

    Extension Development Flow:
    โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”    โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”    โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
    โ”‚ AI Assistant    โ”‚โ”€โ”€โ”€โ–ถโ”‚ MCP Server       โ”‚โ”€โ”€โ”€โ–ถโ”‚ Chrome Browser  โ”‚
    โ”‚ (Claude/Cursor) โ”‚    โ”‚ (Extension Tools)โ”‚    โ”‚ + Extensions    โ”‚
    โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜    โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜    โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜
                                  โ”‚                         โ”‚
                                  โ–ผ                         โ–ผ
                           โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”    โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
                           โ”‚ Web Store        โ”‚    โ”‚ System Profile  โ”‚
                           โ”‚ Automation       โ”‚    โ”‚ (Direct Access) โ”‚
                           โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜    โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜

    Web Store Automation Tools

    Submission Workflow (submit_to_webstore)

    1. Manifest Validation: Manifest V3 compliance, permission security analysis
    2. Package Creation: ZIP generation with optimized compression, development file exclusion
    3. Store Listing: Auto-generated descriptions based on manifest permissions
    4. Browser Automation: Login flow, form population, file upload, error detection

    Screenshot Generation (generate_extension_screenshots)

    • Primary: 1280x800 (Web Store requirement)
    • Promotional Tiles: Small (440x280), Large (920x680), Marquee (1400x560)
    • Smart Capture: Extension popup, options page, in-context usage

    Manifest Validation System

    interface ManifestValidation {
      required: string[];      // name, version, manifest_version
      warnings: string[];      // description length, icon sizes
      security: string[];      // dangerous permissions analysis
      suggestions: string[];   // optimization recommendations
    }

    Validation Features:

    • Manifest V3 compliance enforcement
    • Permission analysis with security implications
    • Icon size recommendations (16x16, 48x48, 128x128)
    • Service worker file verification
    • Host permission optimization suggestions

    Added Dependencies

    • archiver (7.0.1): ZIP package creation for extension submission
    • puppeteer-core (24.22.3): Chrome automation with extension support
    • @modelcontextprotocol/sdk (1.18.1): MCP server implementation

    MCP Server Coexistence

    • Server Name: chrome-devtools-extension (vs original chrome-devtools)
    • Package Name: chrome-devtools-mcp-for-extension
    • Purpose: Allows both servers to run simultaneously for different use cases

    ๐Ÿ‘จโ€๐Ÿ’ป Developer Reference

    Supported Extension Types

    • Manifest V3: Full support (recommended)
    • Service Workers: Background script debugging
    • Content Scripts: Page interaction testing
    • Popup Extensions: UI testing and screenshots
    • Options Pages: Settings interface validation

    Browser Compatibility

    • Chrome: Primary target (latest stable)
    • Chrome Canary: Development testing
    • Chromium: Community builds
    • Edge: Chromium-based versions

    Technical Requirements

    • Node.js: 22.12.0+ (for latest Chrome DevTools Protocol)
    • Chrome: Any version with extension support
    • Storage: ~50MB for dependencies
    • Network: Required for Web Store automation

    Extension Loading Capabilities

    • Startup Loading: Extensions loaded at Chrome startup via --loadExtension
    • System Extensions: Auto-loads all extensions from Chrome profile (default)
    • Manual Reloading: Update extensions via reload_extension MCP tool
    • Multi-Extension: Support for multiple extensions simultaneously

    โš ๏ธ Note: Runtime extension installation not supported. Extensions must be loaded at startup.

    Security & Privacy Considerations

    • System Profile Access: Uses system Chrome profile by default (includes cookies, sessions, history, bookmarks)
    • Profile Isolation: Use --isolated flag for temporary profile without personal data
    • Extension Sandboxing: Extension permissions are sandboxed per Chrome security model
    • Web Store Auth: Uses standard Google OAuth flow (no credentials stored)

    โš ๏ธ Warning: When using system profile, the MCP server has access to all data in your Chrome profile. Use --isolated mode for testing sensitive operations.


    โ“ Troubleshooting

    Extension Not Loading

    Check manifest.json:

    "List extensions and show any errors"

    Verify extension is in correct directory:

    • Manifest must be at root: /your-extension/manifest.json
    • Not: /your-extension/dist/manifest.json

    Solution:

    Update ~/.claude.json:

    {
      "mcpServers": {
        "chrome-devtools-extension": {
          "type": "stdio",
          "command": "npx",
          "args": [
            "chrome-devtools-mcp-for-extension@latest",
            "--loadExtension=/correct/path"
          ],
          "env": {}
        }
      }
    }

    Service Worker Not Inspecting

    Extension may not be active:

    "List extensions"  // Check if enabled
    "Reload my-extension"  // Restart extension

    DevTools window not appearing:

    • Service worker only runs when needed
    • Trigger extension action first (click popup, run content script)

    Web Store Submission Fails

    Manifest V3 compliance:

    "Validate my manifest for Web Store compliance"

    Common issues:

    • Missing required icons (16x16, 48x48, 128x128)
    • Invalid permissions (host_permissions format)
    • Service worker not specified

    Extensions Disabled After Chrome Update

    Chrome 137+ breaking change:

    • --load-extension may be restricted in newer Chrome versions
    • Solution: Use system profile (default) instead of --loadExtension flag

    System Extensions Loading (v0.7.1+)

    How does the MCP server handle Chrome extensions?

    The MCP server uses an isolated profile with --load-extension to provide system extensions while maintaining independence:

    Default Behavior

    • โœ… Independent Chrome Instance: Runs separately from your main Chrome browser
    • โœ… System Extensions Loaded: Your installed Chrome extensions are automatically loaded via --load-extension
    • โœ… Concurrent Usage: Works alongside your regular Chrome browser without conflicts
    • ๐Ÿ”’ Isolated Login State: First launch requires Google login (for security)
    • ๐Ÿ”’ Isolated Profile: Uses ~/.cache/chrome-devtools-mcp/chrome-profile/

    What Works

    • โœ… Extensions: All system Chrome extensions are dynamically loaded
    • โœ… Bookmarks: Accessible via MCP tools (list_bookmarks, navigate_bookmark)
    • โœ… Login State: Preserved in isolated profile after first login

    What Doesn't Work

    • โŒ Bookmarks in Browser UI: Not displayed in browser bookmarks bar (use MCP tools instead)
    • โŒ Shared Login State: System Chrome login state is not shared (first login required)

    Profile Location

    ~/.cache/chrome-devtools-mcp/chrome-profile/
    โ””โ”€โ”€ Default/
        โ”œโ”€โ”€ Cookies        (isolated)
        โ”œโ”€โ”€ Login Data     (isolated)
        โ””โ”€โ”€ ...            (all files isolated)

    First Launch

    • Extensions: Automatically loaded from system Chrome via --load-extension
    • Google Login required: You'll need to log in once (login state is isolated for security)
    • Subsequent launches: Login state is preserved in the isolated profile

    Isolated Mode (No Extensions)

    To run without any extensions:

    npx chrome-devtools-mcp-for-extension@latest --isolated

    ๆ—ฅๆœฌ่ชž / Japanese

    Chromeๆ‹กๅผตๆฉŸ่ƒฝ้–‹็™บ็”จใฎAIๆ”ฏๆดMCPใ‚ตใƒผใƒใƒผ

    ใ‚ทใ‚นใƒ†ใƒ ๆ‹กๅผตๆฉŸ่ƒฝใ‚’่‡ชๅ‹•ใƒญใƒผใƒ‰ใ€้–‹็™บ็”จๆ‹กๅผตๆฉŸ่ƒฝใ‚‚็ฐกๅ˜่จญๅฎš

    ใ‚ฏใ‚คใƒƒใ‚ฏใ‚นใ‚ฟใƒผใƒˆ

    1. ่จญๅฎšใ‚’่ฟฝๅŠ 

    ~/.claude.json ใซไปฅไธ‹ใ‚’่ฟฝๅŠ :

    {
      "mcpServers": {
        "chrome-devtools-extension": {
          "type": "stdio",
          "command": "npx",
          "args": ["chrome-devtools-mcp-for-extension@latest"],
          "env": {}
        }
      }
    }

    2. AIใ‚ฏใƒฉใ‚คใ‚ขใƒณใƒˆใ‚’ๅ†่ตทๅ‹•

    3. ๅ‹•ไฝœ็ขบ่ช

    AIใซ่ณชๅ•:

    ใ€ŒChromeๆ‹กๅผตๆฉŸ่ƒฝใ‚’ไธ€่ฆง่กจ็คบใ—ใฆใ€

    โœ… ใ‚คใƒณใ‚นใƒˆใƒผใƒซๆธˆใฟใฎๆ‹กๅผตๆฉŸ่ƒฝใŒ่กจ็คบใ•ใ‚Œใพใ™


    ้–‹็™บ็”จๆ‹กๅผตๆฉŸ่ƒฝใฎใƒญใƒผใƒ‰๏ผˆ--loadExtensionsDirใ‚ใ‚Š๏ผ‰

    ้–‹็™บไธญใฎๆ‹กๅผตๆฉŸ่ƒฝใ‚’ใƒ†ใ‚นใƒˆใ™ใ‚‹ๅ ดๅˆ:

    {
      "mcpServers": {
        "chrome-devtools-extension": {
          "command": "npx",
          "args": [
            "chrome-devtools-mcp-for-extension@latest",
            "--loadExtensionsDir=/path/to/your/extensions"
          ]
        }
      }
    }

    ไธปใชๆฉŸ่ƒฝ

    • ๐Ÿงฉ ๆ‹กๅผตๆฉŸ่ƒฝใฎ้–‹็™บใƒปใƒ‡ใƒใƒƒใ‚ฐใƒปใƒชใƒญใƒผใƒ‰: ใƒฉใ‚คใƒ–้–‹็™บ็’ฐๅขƒ
    • ๐Ÿช Chrome Web Store ใธใฎ่‡ชๅ‹•็”ณ่ซ‹: ใ‚นใ‚ฏใƒชใƒผใƒณใ‚ทใƒงใƒƒใƒˆ็”Ÿๆˆไป˜ใ
    • ๐Ÿ”ง ๅฎŸ็’ฐๅขƒใงใฎใƒ–ใƒฉใ‚ฆใ‚ถใƒ†ใ‚นใƒˆ: ๆ—ขๅญ˜ใฎๆ‹กๅผตๆฉŸ่ƒฝใจๅ…ฑๅญ˜
    • ๐Ÿ› ้ซ˜ๅบฆใชใƒ‡ใƒใƒƒใ‚ฐ: ใ‚ตใƒผใƒ“ใ‚นใƒฏใƒผใ‚ซใƒผๆคœๆŸปใ€ใ‚ณใƒณใ‚ฝใƒผใƒซ็›ฃ่ฆ–

    ไฝฟ็”จไพ‹

    ใ€Œๅบƒๅ‘Šใƒ–ใƒญใƒƒใ‚ฏๆ‹กๅผตๆฉŸ่ƒฝใ‚’ไฝœๆˆใ—ใฆใ€
    ใ€Œๆ‹กๅผตๆฉŸ่ƒฝใฎใ‚จใƒฉใƒผใ‚’็ขบ่ชใ—ใฆใ€
    ใ€Œใ‚ตใƒผใƒ“ใ‚นใƒฏใƒผใ‚ซใƒผใ‚’ใƒ‡ใƒใƒƒใ‚ฐใ—ใฆใ€
    ใ€ŒWeb Storeใซ็”ณ่ซ‹ใ—ใฆใ€

    ใใฎไป–ใฎ่ฉณ็ดฐใฏ่‹ฑ่ชžใ‚ปใ‚ฏใ‚ทใƒงใƒณใ‚’ๅ‚็…งใ—ใฆใใ ใ•ใ„ใ€‚


    Version: 0.6.2 Repository: https://github.com/usedhonda/chrome-devtools-mcp License: Apache-2.0 Original: Chrome DevTools MCP by Google LLC