Testing Anti-Patterns
About
This skill helps developers avoid common testing anti-patterns like testing mock behavior instead of real functionality and adding test-only methods to production code. It provides guidance for writing effective tests, properly mocking dependencies, and applying TDD principles. Use it when writing tests, adding mocks, or reviewing test failures to ensure your tests verify actual system behavior.
Documentation
Testing Anti-Patterns
Overview
Tests must verify real behavior, not mock behavior. Mocks are a means to isolate, not the thing being tested.
Core principle: Test what the code does, not what the mocks do.
Following strict TDD prevents these anti-patterns. See test-driven-development skill for the complete TDD workflow.
When to Use This Skill
Activate this skill when you're:
- Writing or changing tests - Verify you're testing real behavior
- Adding mocks - Ensure mocking is necessary and correct
- Reviewing test failures - Check if mock behavior is the issue
- Tempted to add test-only methods - STOP and reconsider
- Tests feel overly complex - Sign of over-mocking
The Iron Laws
1. NEVER test mock behavior
2. NEVER add test-only methods to production classes
3. NEVER mock without understanding dependencies
4. NEVER create incomplete mocks
5. NEVER treat tests as afterthought
Core Anti-Pattern Categories
1. Testing Mock Behavior
Asserting on mock elements instead of real behavior. Fix: Test real component or don't mock it. → core-anti-patterns.md
2. Test-Only Methods in Production
Methods in production classes only used by tests. Fix: Move to test utilities. → core-anti-patterns.md
3. Mocking Without Understanding
Mocking without understanding dependencies/side effects. Fix: Understand first, mock minimally. → core-anti-patterns.md
4. Incomplete Mocks
Partial mocks missing fields downstream code needs. Fix: Mirror complete API structure. → completeness-anti-patterns.md
5. Tests as Afterthought
Implementation "complete" without tests. Fix: TDD - write test first. → completeness-anti-patterns.md
Quick Detection Checklist
Run this checklist before committing any test:
□ Am I asserting on mock elements? (testId='*-mock')
→ If yes: STOP - Test real component or unmock
□ Does this method only exist for tests?
→ If yes: STOP - Move to test utilities
□ Do I fully understand what I'm mocking?
→ If no: STOP - Run with real impl first, then mock minimally
□ Is my mock missing fields the real API has?
→ If yes: STOP - Mirror complete API structure
□ Did I write implementation before test?
→ If yes: STOP - Delete impl, write test first (TDD)
□ Is mock setup >50% of test code?
→ If yes: Consider integration test with real components
See: detection-guide.md for comprehensive red flags and warning signs.
The Bottom Line
Mocks are tools to isolate, not things to test.
If you're testing mock behavior, you've gone wrong. Fix: Test real behavior or question why you're mocking at all.
TDD prevents these patterns. Write test first → Watch fail → Minimal implementation → Pass → Refactor.
Navigation
Detailed Anti-Pattern Analysis
- Core Anti-Patterns - Patterns 1-3: Mock behavior, test-only methods, uninformed mocking
- Completeness Anti-Patterns - Patterns 4-5: Incomplete mocks, tests as afterthought
Detection & Prevention
- Detection Guide - Red flags, warning signs, gate functions
- TDD Connection - How test-driven development prevents these patterns
Related Skills
- test-driven-development - Complete TDD workflow (prevents these patterns)
- verification-before-completion - Testing is part of "done"
Key Reminders
- Mocks isolate, don't prove - Test real code, not mocks
- Production ignores tests - No test-only methods
- Understand before mocking - Know dependencies and side effects
- Complete mocks only - Mirror full API structure
- Tests ARE implementation - Not optional afterthought
Red Flags - STOP
STOP immediately if you find yourself:
- Asserting on
*-mocktest IDs - Adding methods only called in test files
- Mocking "just to be safe" without understanding
- Creating mocks from memory instead of API docs
- Saying "tests can wait" or "ready for testing"
When mocks become too complex: Consider integration tests with real components. Often simpler and more valuable.
Integration with Other Skills
Prerequisite: test-driven-development - TDD prevents anti-patterns Complementary: verification-before-completion - Tests = done Domain-specific: webapp-testing, backend-testing for framework patterns
Quick Install
/plugin add https://github.com/bobmatnyc/claude-mpm/tree/main/testing-anti-patternsCopy and paste this command in Claude Code to install this skill
GitHub 仓库
Related Skills
evaluating-llms-harness
TestingThis Claude Skill runs the lm-evaluation-harness to benchmark LLMs across 60+ standardized academic tasks like MMLU and GSM8K. It's designed for developers to compare model quality, track training progress, or report academic results. The tool supports various backends including HuggingFace and vLLM models.
webapp-testing
TestingThis Claude Skill provides a Playwright-based toolkit for testing local web applications through Python scripts. It enables frontend verification, UI debugging, screenshot capture, and log viewing while managing server lifecycles. Use it for browser automation tasks but run scripts directly rather than reading their source code to avoid context pollution.
finishing-a-development-branch
TestingThis skill helps developers complete finished work by verifying tests pass and then presenting structured integration options. It guides the workflow for merging, creating PRs, or cleaning up branches after implementation is done. Use it when your code is ready and tested to systematically finalize the development process.
go-test
MetaThe go-test skill provides expertise in Go's standard testing package and best practices. It helps developers implement table-driven tests, subtests, benchmarks, and coverage strategies while following Go conventions. Use it when writing test files, creating mocks, detecting race conditions, or organizing integration tests in Go projects.
