npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

playwright-mcp-wsl

v1.0.0

Published

Drop-in WSL-safe wrapper for @playwright/mcp. Prevents GPU crashes on Windows Subsystem for Linux by disabling Chromium GPU acceleration through the dxg bridge.

Downloads

115

Readme

playwright-mcp-wsl

Drop-in WSL-safe wrapper for @playwright/mcp. Prevents Chromium GPU crashes on Windows Subsystem for Linux.

The Problem

Running Claude Code (or any Playwright-based browser automation) on WSL2 with parallel browser sessions causes cascading crashes:

  1. Chromium tries to allocate GPU memory through WSL's dxg bridge
  2. Multiple browser instances exhaust GPU memory allocations
  3. Chrome processes SEGFAULT (signal 11)
  4. Crash cascade takes down the entire WSL instance

This is invisible to users — WSL just "crashes" or "freezes" with no clear error.

The Fix

This package wraps @playwright/mcp and automatically injects GPU-safe flags when running on WSL:

--disable-gpu
--disable-software-rasterizer
--disable-dev-shm-usage

On non-WSL systems, it passes through to @playwright/mcp unchanged. No performance impact — GPU acceleration is meaningless for headless browser automation.

Installation

Claude Code (recommended)

Add to your Claude Code settings (.claude/settings.json or global settings):

{
  "mcpServers": {
    "playwright": {
      "command": "npx",
      "args": ["playwright-mcp-wsl@latest"]
    }
  }
}

This replaces the default @playwright/mcp entry.

Manual / Other MCP Hosts

npx playwright-mcp-wsl@latest

All @playwright/mcp CLI flags are supported:

npx playwright-mcp-wsl@latest --headless --viewport-size 1440x900

Programmatic

const { createConnection } = require('playwright-mcp-wsl');
// Same API as @playwright/mcp, with WSL-safe defaults

How It Works

  1. Detects WSL by reading /proc/version for Microsoft/WSL kernel strings
  2. If WSL: sets PLAYWRIGHT_MCP_CONFIG to a bundled config that adds --disable-gpu and related flags to Chromium launch args
  3. If not WSL: passes through to @playwright/mcp with zero modifications
  4. If user has custom config: merges WSL-safe args into existing config (no overwrite)

What It Disables

| Flag | Why | |------|-----| | --disable-gpu | Prevents GPU memory allocation through the dxg bridge | | --disable-software-rasterizer | Prevents fallback software GPU that still uses dxg | | --disable-dev-shm-usage | Uses /tmp instead of /dev/shm (often undersized on WSL) |

What It Doesn't Affect

  • Page rendering quality (identical for headless automation)
  • JavaScript execution
  • Network requests
  • Screenshot quality
  • DOM interaction
  • Any Playwright MCP functionality

Compatibility

  • WSL1 and WSL2
  • Windows 10 and Windows 11
  • Node.js 18+
  • All @playwright/mcp versions >= 0.0.60
  • Claude Code, Cursor, Windsurf, or any MCP-compatible host

Verifying It Works

When running on WSL, you'll see in stderr:

[playwright-mcp-wsl] Detected WSL2 + dxg bridge. Injecting GPU-safe config.

When running on non-WSL:

[playwright-mcp-wsl] Not running in WSL. Passing through to @playwright/mcp.

Background

This package was created after diagnosing cascading WSL crashes during parallel browser automation with Claude Code's PAI system. The root cause was Chromium's GPU memory allocation through WSL2's dxg (DirectX Graphics) bridge — a kernel-level GPU passthrough layer not designed for concurrent headless browser load.

Crash signature in dmesg:

misc dxg: dxgk: dxgvmb_send_create_allocation: send_create_allocation failed ffffffb5
misc dxg: dxgk: dxgkio_create_allocation: Ioctl failed: -75
chrome: potentially unexpected fatal signal 11
WSL (CaptureCrash): Capturing crash for pid: ..., executable: chrome, signal: 11

License

Apache-2.0 — same as Playwright.