webapp-testing

composiohq/awesome-claude-skills · updated Apr 8, 2026

$npx skills add https://github.com/composiohq/awesome-claude-skills --skill webapp-testing
0 commentsdiscussion
summary

Native Python Playwright toolkit for testing and debugging local web applications with server lifecycle management.

  • Includes with_server.py helper script for managing single or multiple server instances automatically during test execution
  • Supports reconnaissance-then-action workflow: screenshot/inspect rendered DOM, identify selectors, then execute interactions
  • Provides example scripts covering element discovery, static HTML automation, and console log capture
  • Emphasizes waiting f
skill.md

Web Application Testing

To test local web applications, write native Python Playwright scripts.

Helper Scripts Available:

  • scripts/with_server.py - Manages server lifecycle (supports multiple servers)

Always run scripts with --help first to see usage. DO NOT read the source until you try running the script first and find that a customized solution is abslutely necessary. These scripts can be very large and thus pollute your context window. They exist to be called directly as black-box scripts rather than ingested into your context window.

Decision Tree: Choosing Your Approach

User task → Is it static HTML?
    ├─ Yes → Read HTML file directly to identify selectors
    │         ├─ Success → Write Playwright script using selectors
    │         └─ Fails/Incomplete → Treat as dynamic (below)
    └─ No (dynamic webapp) → Is the server already running?
        ├─ No → Run: python scripts/with_server.py --help
        │        Then use the helper + write simplified Playwright script
        └─ Yes → Reconnaissance-then-action:
            1. Navigate and wait for networkidle
            2. Take screenshot or inspect DOM
            3. Identify selectors from rendered state
            4. Execute actions with discovered selectors

Example: Using with_server.py

To start a server, run --help first, then use the helper:

Single server:

python scripts/with_server.py --server "npm run dev" --port 5173 -- python your_automation.py

Multiple servers (e.g., backend + frontend):

python scripts/with_server.py \
  --server "cd backend && python server.py" --port 3000 \
  --server "cd frontend && npm run dev" --port 5173 \
  -- python your_automation.py

To create an automation script, include only Playwright logic (servers are managed automatically):

from playwright.sync_api import sync_playwright

with sync_playwright() as p:
    browser = p.chromium.launch(headless=True) # Always launch chromium in headless mode
    page = browser.new_page()
    page.goto('http://localhost:5173') # Server already running and ready
    page.wait_for_load_state('networkidle') # CRITICAL: Wait for JS to execute
    # ... your automation logic
    browser.close()

Reconnaissance-Then-Action Pattern

  1. Inspect rendered DOM:

    page.screenshot(path='/tmp/inspect.png', full_page=True)
    content = page.content()
    page.locator('button').all()
    
  2. Identify selectors from inspection results

  3. Execute actions using discovered selectors

Common Pitfall

Don't inspect the DOM before waiting for networkidle on dynamic apps ✅ Do wait for page.wait_for_load_state('networkidle') before inspection

Best Practices

  • Use bundled scripts as black boxes - To accomplish a task, consider whether one of the scripts available in scripts/ can help. These scripts handle common, complex workflows reliably without cluttering the context window. Use --help to see usage, then invoke directly.
  • Use sync_playwright() for synchronous scripts
  • Always close the browser when done
  • Use descriptive selectors: text=, role=, CSS selectors, or IDs
  • Add appropriate waits: page.wait_for_selector() or page.wait_for_timeout()

Reference Files

  • examples/ - Examples showing common patterns:
    • element_discovery.py - Discovering buttons, links, and inputs on a page
    • static_html_automation.py - Using file:// URLs for local HTML
    • console_logging.py - Capturing console logs during automation

Discussion

Product Hunt–style comments (not star reviews)
  • No comments yet — start the thread.
general reviews

Ratings

4.853 reviews
  • Tariq Martin· Dec 28, 2024

    Useful defaults in webapp-testing — fewer surprises than typical one-off scripts, and it plays nicely with `npx skills` flows.

  • Soo Dixit· Dec 24, 2024

    I recommend webapp-testing for anyone iterating fast on agent tooling; clear intent and a small, reviewable surface area.

  • Pratham Ware· Dec 4, 2024

    Registry listing for webapp-testing matched our evaluation — installs cleanly and behaves as described in the markdown.

  • Tariq Yang· Nov 19, 2024

    I recommend webapp-testing for anyone iterating fast on agent tooling; clear intent and a small, reviewable surface area.

  • Sophia Bansal· Nov 15, 2024

    Useful defaults in webapp-testing — fewer surprises than typical one-off scripts, and it plays nicely with `npx skills` flows.

  • Ira Ghosh· Oct 10, 2024

    webapp-testing reduced setup friction for our internal harness; good balance of opinion and flexibility.

  • Sophia Menon· Oct 6, 2024

    webapp-testing has been reliable in day-to-day use. Documentation quality is above average for community skills.

  • Sakshi Patil· Sep 25, 2024

    webapp-testing reduced setup friction for our internal harness; good balance of opinion and flexibility.

  • Mia Perez· Sep 21, 2024

    Keeps context tight: webapp-testing is the kind of skill you can hand to a new teammate without a long onboarding doc.

  • Zara Liu· Sep 17, 2024

    webapp-testing is among the better-maintained entries we tried; worth keeping pinned for repeat workflows.

showing 1-10 of 53

1 / 6