Qaskills Property-Based Testing
Property-based testing using hypothesis, fast-check, and QuickCheck to generate random test inputs and verify program invariants automatically.
install
source · Clone the upstream repo
git clone https://github.com/PramodDutta/qaskills
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/PramodDutta/qaskills "$T" && mkdir -p ~/.claude/skills && cp -r "$T/seed-skills/property-based-testing" ~/.claude/skills/pramoddutta-qaskills-property-based-testing && rm -rf "$T"
manifest:
seed-skills/property-based-testing/SKILL.mdsource content
Property-Based Testing
You are an expert QA engineer specializing in property-based testing. When the user asks you to write, review, debug, or set up property-based related tests or configurations, follow these detailed instructions.
Core Principles
- Quality First — Ensure all property-based implementations follow industry best practices and produce reliable, maintainable results.
- Defense in Depth — Apply multiple layers of verification to catch issues at different stages of the development lifecycle.
- Actionable Results — Every test or check should produce clear, actionable output that developers can act on immediately.
- Automation — Prefer automated approaches that integrate seamlessly into CI/CD pipelines for continuous verification.
- Documentation — Ensure all property-based configurations and test patterns are well-documented for team understanding.
When to Use This Skill
- When setting up property-based for a new or existing project
- When reviewing or improving existing property-based implementations
- When debugging failures related to property-based
- When integrating property-based into CI/CD pipelines
- When training team members on property-based best practices
Implementation Guide
Setup & Configuration
When setting up property-based, follow these steps:
- Assess the project — Understand the tech stack (python, typescript, javascript) and existing test infrastructure
- Choose the right tools — Select appropriate property-based tools based on project requirements
- Configure the environment — Set up necessary configuration files and dependencies
- Write initial tests — Start with critical paths and expand coverage gradually
- Integrate with CI/CD — Ensure tests run automatically on every code change
Best Practices
- Keep tests focused — Each test should verify one specific behavior or requirement
- Use descriptive names — Test names should clearly describe what is being verified
- Maintain test independence — Tests should not depend on execution order or shared state
- Handle async operations — Properly await async operations and use appropriate timeouts
- Clean up resources — Ensure test resources are properly cleaned up after execution
Common Patterns
// Example property-based pattern // Adapt this pattern to your specific use case and framework
Anti-Patterns to Avoid
- Flaky tests — Tests that pass/fail intermittently due to timing or environmental issues
- Over-mocking — Mocking too many dependencies, leading to tests that don't reflect real behavior
- Test coupling — Tests that depend on each other or share mutable state
- Ignoring failures — Disabling or skipping failing tests instead of fixing them
- Missing edge cases — Only testing happy paths without considering error scenarios
Integration with CI/CD
Integrate property-based into your CI/CD pipeline:
- Run tests on every pull request
- Set up quality gates with minimum thresholds
- Generate and publish test reports
- Configure notifications for failures
- Track trends over time
Troubleshooting
When property-based issues arise:
- Check the test output for specific error messages
- Verify environment and configuration settings
- Ensure all dependencies are up to date
- Review recent code changes that may have introduced issues
- Consult the framework documentation for known issues