test-first-bugs
SKILL.md
Test-first bug fixing
Enforce a disciplined bug-fixing workflow that prevents regression and parallelizes fix attempts.
Core workflow
When a bug is reported, follow these steps in order:
Phase 1: Reproduce and document
- Understand the bug — Gather details about expected vs actual behavior
- Identify the test location — Determine where tests live in the project (check for
tests/,__tests__/,spec/,*.test.*,*.spec.*patterns) - Write a failing test — Create a test that demonstrates the bug
Phase 2: Fix with subagents
- Launch fix subagents — Use the Task tool with
subagent_type=general-purposeto attempt fixes - Run the test — Verify the fix by running the specific test
- Iterate if needed — If test still fails, launch additional subagents with new approaches
Phase 3: Verify and complete
- Run full test suite — Ensure no regressions were introduced
- Report success — Confirm the bug is fixed with passing test as proof
Writing the failing test
Test naming convention
Name the test to describe the bug:
# Python (pytest)
def test_user_login_fails_when_email_has_uppercase():
...
# Python (unittest)
def test_should_handle_empty_input_without_crashing(self):
...
// JavaScript (Jest/Vitest)
it('should not crash when input array is empty', () => { ... });
test('handles special characters in username', () => { ... });
// TypeScript
describe('UserService', () => {
it('returns null when user not found instead of throwing', () => { ... });
});
Test structure
Every bug reproduction test follows this pattern:
def test_bug_description():
# 1. ARRANGE - Set up the conditions that trigger the bug
input_data = create_problematic_input()
# 2. ACT - Perform the action that causes the bug
result = function_under_test(input_data)
# 3. ASSERT - Verify the expected (correct) behavior
assert result == expected_value # This should FAIL initially
Finding the right test file
Check the project structure for existing test patterns:
# Find test files
find . -name "*.test.*" -o -name "*.spec.*" -o -name "test_*.py" | head -20
# Find test directories
ls -la tests/ __tests__/ spec/ test/ 2>/dev/null
# Check package.json for test command
grep -A5 '"test"' package.json
Launching fix subagents
Use the Task tool to parallelize fix attempts:
Task tool parameters:
- subagent_type: "general-purpose"
- description: "Fix [bug description]"
- prompt: Include:
1. The bug description
2. The failing test location and contents
3. Suspected cause (if known)
4. Constraint: "Run the test to verify your fix works"
Parallel fix strategies
Launch multiple subagents with different approaches:
- Direct fix agent — Focus on the immediate code causing the bug
- Root cause agent — Investigate deeper architectural issues
- Edge case agent — Look for similar bugs in related code
When projects lack tests
If the project has no test infrastructure:
- Set up minimal test framework first
- Create the test file in a sensible location
- Document the test setup for future use
Quick test setup commands
# Python
pip install pytest
mkdir -p tests && touch tests/__init__.py
# JavaScript/TypeScript
npm install --save-dev jest
# or
npm install --save-dev vitest
# Go
# Tests are built-in, create *_test.go files
Verifying the fix
After subagent reports completion:
# Run the specific test
pytest tests/test_module.py::test_bug_description -v
npm test -- --grep "bug description"
go test -run TestBugDescription -v
# Run full suite to check for regressions
pytest
npm test
go test ./...
Example workflow
User reports: "The login function crashes when email has spaces"
Phase 1 — Write failing test:
# tests/test_auth.py
def test_login_handles_email_with_spaces():
"""Bug: Login crashes when email contains spaces"""
auth = AuthService()
# This should return an error, not crash
result = auth.login("user @example.com", "password")
assert result.success == False
assert "invalid email" in result.error.lower()
Run test to confirm it fails:
pytest tests/test_auth.py::test_login_handles_email_with_spaces -v
# Expected: FAILED (demonstrates the bug)
Phase 2 — Launch subagent:
Task tool:
- subagent_type: "general-purpose"
- description: "Fix email space crash"
- prompt: "Fix the login crash when email contains spaces.
Bug: AuthService.login() crashes instead of returning error when email has spaces.
Failing test: tests/test_auth.py::test_login_handles_email_with_spaces
After fixing, run: pytest tests/test_auth.py::test_login_handles_email_with_spaces -v
The test must pass to confirm the fix."
Phase 3 — Verify:
# Specific test passes
pytest tests/test_auth.py::test_login_handles_email_with_spaces -v
# PASSED
# No regressions
pytest tests/test_auth.py -v
# All tests pass
Integration with hooks
The bug-report-detector hook in this plugin automatically:
- Detects when a user reports a bug
- Reminds Claude to follow the test-first workflow
- Blocks Edit/Write tools until a test file has been created or modified
Additional resources
Reference files
references/test-frameworks.md— Framework-specific test patternsreferences/common-bugs.md— Common bug patterns and test strategies
Example files
examples/python-bug-test.py— Python pytest exampleexamples/js-bug-test.js— JavaScript Jest example
Scripts
scripts/find-tests.sh— Locate test infrastructure in a project
Weekly Installs
29
Repository
jamditis/claude…urnalismGitHub Stars
56
First Seen
Feb 6, 2026
Security Audits
Installed on
codex28
opencode27
gemini-cli27
cursor27
github-copilot26
kimi-cli26