← Back to Skills Marketplace
Test Runner
by
alexwoo-awso
· GitHub ↗
· v1.0.1
· MIT-0
173
Downloads
0
Stars
1
Active Installs
1
Versions
Install in OpenClaw
/install test-runner-codex
Description
Write and run tests across languages and frameworks.
README (SKILL.md)
Test Runner
Core workflow
- Detect the language, package manager, and existing test framework before changing anything.
- Prefer the project's current test stack over introducing a new one.
- Run the smallest relevant test scope first, then widen coverage after the failure is understood.
- When fixing bugs, start with a failing test, make the smallest code change that passes, then refactor.
- After changes, run the narrow test again and then a broader suite if the local workflow supports it.
Framework selection
Use the existing framework when one is already configured. If the project has no test stack, prefer:
| Language | Unit tests | Integration | End-to-end |
|---|---|---|---|
| TypeScript / JavaScript | Vitest | Supertest | Playwright |
| Python | pytest | pytest + httpx | Playwright |
| Swift | XCTest | XCTest | XCUITest |
Command guide
Vitest
npm install -D vitest @testing-library/react @testing-library/jest-dom
npx vitest
npx vitest run
npx vitest --coverage
Use this baseline config when a project needs one:
import { defineConfig } from 'vitest/config'
export default defineConfig({
test: {
globals: true,
environment: 'jsdom',
setupFiles: './tests/setup.ts',
},
})
Jest
npm install -D jest @types/jest ts-jest
npx jest
npx jest --watch
npx jest --coverage
npx jest path/to/test
pytest
uv pip install pytest pytest-cov pytest-asyncio httpx
pytest
pytest -v
pytest -x
pytest --cov=app
pytest tests/test_api.py -k "test_login"
pytest --tb=short
XCTest
swift test
swift test --filter MyTests
swift test --parallel
Playwright
npm install -D @playwright/test
npx playwright install
npx playwright test
npx playwright test --headed
npx playwright test --debug
npx playwright test --project=chromium
npx playwright show-report
Red-green-refactor
- Red: write a failing test for the behavior you need.
- Green: implement the smallest change that makes it pass.
- Refactor: clean up without changing behavior.
Test patterns
Arrange, act, assert
test('calculates total with tax', () => {
const cart = new Cart([{ price: 100, qty: 2 }])
const total = cart.totalWithTax(0.08)
expect(total).toBe(216)
})
Async tests
test('fetches user data', async () => {
const user = await getUser('123')
expect(user.name).toBe('Colt')
})
Mocking with Vitest
import { vi } from 'vitest'
const mockFetch = vi.fn().mockResolvedValue({
json: () => Promise.resolve({ id: 1, name: 'Test' }),
})
vi.stubGlobal('fetch', mockFetch)
API tests in Python
import pytest
from httpx import AsyncClient
from app.main import app
@pytest.mark.asyncio
async def test_get_users():
async with AsyncClient(app=app, base_url="http://test") as client:
response = await client.get("/users")
assert response.status_code == 200
assert isinstance(response.json(), list)
React component tests
import { fireEvent, render, screen } from '@testing-library/react'
import { Button } from './Button'
test('calls onClick when clicked', () => {
const handleClick = vi.fn()
render(\x3CButton onClick={handleClick}>Click me\x3C/Button>)
fireEvent.click(screen.getByText('Click me'))
expect(handleClick).toHaveBeenCalledOnce()
})
Coverage commands
# JavaScript / TypeScript
npx vitest --coverage
npx jest --coverage
# Python
pytest --cov=app --cov-report=html
pytest --cov=app --cov-report=term
pytest --cov=app --cov-fail-under=80
What to test
Always test:
- Public APIs and exported functions
- Edge cases such as empty input, null, and boundary values
- Error handling such as invalid input or network failures
- Business logic such as calculations and state transitions
Usually skip:
- Private implementation details
- Framework internals
- Trivial getters and setters
- Third-party library behavior
Usage Guidance
This skill is coherent for its purpose, but take ordinary precautions before running it: 1) Review the repository's tests before executing them—tests run project code and can execute arbitrary logic. 2) Install and run tests in an isolated environment (container, virtualenv, or CI worker) so dependency installs and browser downloads (Playwright) don't affect your host. 3) Be aware npm/pip installs will add dev dependencies to the project; run package manager commands only in the intended project directory. 4) There is a small typo in the SKILL.md ("uv pip install...") — treat that as a documentation mistake, not a runtime action. If you plan to allow autonomous agent invocation, ensure the agent's execution environment is appropriately sandboxed.
Capability Analysis
Type: OpenClaw Skill
Name: test-runner-codex
Version: 1.0.1
The skill bundle provides standard instructions and commands for writing and running tests across multiple languages (JavaScript, Python, Swift). The content in SKILL.md and README.md consists of legitimate testing workflows, framework recommendations (e.g., Vitest, pytest, Playwright), and common code patterns without any evidence of malicious intent, data exfiltration, or unauthorized command execution.
Capability Assessment
Purpose & Capability
Name and description ('Write and run tests across languages and frameworks') match the SKILL.md content: test framework guidance and commands for JS/TS, Python, Swift, and Playwright. It does not request unrelated credentials, binaries, or config paths.
Instruction Scope
Instructions focus on detecting test stacks, selecting frameworks, running test commands, and writing tests. They do tell the agent to run common package manager and test commands (npm, npx, pytest, swift, playwright) but do not instruct reading unrelated files, exfiltrating data, or contacting unknown endpoints.
Install Mechanism
No install spec and no code files — this is instruction-only. The SKILL.md suggests running standard package manager commands (npm, pip, npx, swift) which is expected for a test-runner. Nothing is downloaded from arbitrary URLs by the skill itself.
Credentials
The skill requests no environment variables, credentials, or config paths. Recommended commands will install dev dependencies locally in a project — that is proportional to a testing tool. (Note: Playwright and some test tools may download browser binaries when run; this is a normal side effect of those tools, not a credential request.)
Persistence & Privilege
always:false and user-invocable: true. The skill does not request persistent privileges or modify other skills or system-wide agent settings. Autonomous invocation is allowed by default but not elevated here.
How to Use
- Make sure OpenClaw is installed (local or Docker)
- Run the install command in chat:
/install test-runner-codex - After installation, invoke the skill by name or use
/test-runner-codex - Provide required inputs per the skill's parameter spec and get structured output
Version History
v1.0.1
Initial release.
- Provides a unified guide for writing and running tests across TypeScript, Python, and Swift projects.
- Includes framework selection advice and preferred stacks for unit, integration, and end-to-end tests.
- Step-by-step workflow for detecting existing setups and minimizing changes.
- Offers quick command references for Vitest, Jest, pytest, XCTest, and Playwright.
- Covers common test patterns, coverage commands, and practical tips on what to test.
Metadata
Frequently Asked Questions
What is Test Runner?
Write and run tests across languages and frameworks. It is an AI Agent Skill for Claude Code / OpenClaw, with 173 downloads so far.
How do I install Test Runner?
Run "/install test-runner-codex" in the OpenClaw or Claude Code chat to install it in one step — no extra setup required.
Is Test Runner free?
Yes, Test Runner is completely free, licensed under MIT-0. You can download, install and use it at no cost.
Which platforms does Test Runner support?
Test Runner is cross-platform and runs anywhere OpenClaw / Claude Code is available (cross-platform).
Who created Test Runner?
It is built and maintained by alexwoo-awso (@alexwoo-awso); the current version is v1.0.1.
More Skills