Marketplace python-pytest-patterns
pytest testing patterns for Python. Triggers on: pytest, fixture, mark, parametrize, mock, conftest, test coverage, unit test, integration test, pytest.raises.
install
source · Clone the upstream repo
git clone https://github.com/aiskillstore/marketplace
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/aiskillstore/marketplace "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/0xdarkmatter/python-pytest-patterns" ~/.claude/skills/aiskillstore-marketplace-python-pytest-patterns && rm -rf "$T"
manifest:
skills/0xdarkmatter/python-pytest-patterns/SKILL.mdsource content
Python pytest Patterns
Modern pytest patterns for effective testing.
Basic Test Structure
import pytest def test_basic(): """Simple assertion test.""" assert 1 + 1 == 2 def test_with_description(): """Descriptive name and docstring.""" result = calculate_total([1, 2, 3]) assert result == 6, "Sum should equal 6"
Fixtures
import pytest @pytest.fixture def sample_user(): """Create test user.""" return {"id": 1, "name": "Test User"} @pytest.fixture def db_connection(): """Fixture with setup and teardown.""" conn = create_connection() yield conn conn.close() def test_user(sample_user): """Fixtures injected by name.""" assert sample_user["name"] == "Test User"
Fixture Scopes
@pytest.fixture(scope="function") # Default - per test @pytest.fixture(scope="class") # Per test class @pytest.fixture(scope="module") # Per test file @pytest.fixture(scope="session") # Entire test run
Parametrize
@pytest.mark.parametrize("input,expected", [ (1, 2), (2, 4), (3, 6), ]) def test_double(input, expected): assert double(input) == expected # Multiple parameters @pytest.mark.parametrize("x", [1, 2]) @pytest.mark.parametrize("y", [10, 20]) def test_multiply(x, y): # 4 test combinations assert x * y > 0
Exception Testing
def test_raises(): with pytest.raises(ValueError) as exc_info: raise ValueError("Invalid input") assert "Invalid" in str(exc_info.value) def test_raises_match(): with pytest.raises(ValueError, match=r".*[Ii]nvalid.*"): raise ValueError("Invalid input")
Markers
@pytest.mark.skip(reason="Not implemented yet") def test_future_feature(): pass @pytest.mark.skipif(sys.platform == "win32", reason="Unix only") def test_unix_feature(): pass @pytest.mark.xfail(reason="Known bug") def test_buggy(): assert broken_function() == expected @pytest.mark.slow def test_performance(): """Custom marker - register in pytest.ini.""" pass
Mocking
from unittest.mock import Mock, patch, MagicMock def test_with_mock(): mock_api = Mock() mock_api.get.return_value = {"status": "ok"} result = mock_api.get("/endpoint") assert result["status"] == "ok" @patch("module.external_api") def test_with_patch(mock_api): mock_api.return_value = {"data": []} result = function_using_api() mock_api.assert_called_once()
pytest-mock (Recommended)
def test_with_mocker(mocker): mock_api = mocker.patch("module.api_call") mock_api.return_value = {"success": True} result = process_data() assert result["success"]
conftest.py
# tests/conftest.py - Shared fixtures import pytest @pytest.fixture(scope="session") def app(): """Application fixture available to all tests.""" return create_app(testing=True) @pytest.fixture def client(app): """Test client fixture.""" return app.test_client()
Quick Reference
| Command | Description |
|---|---|
| Run all tests |
| Verbose output |
| Stop on first failure |
| Run matching tests |
| Run marked tests |
| Rerun last failed |
| Coverage report |
| Parallel (pytest-xdist) |
Additional Resources
- Factory fixtures, autouse, conftest patterns./references/fixtures-advanced.md
- Mock, patch, MagicMock, side_effect./references/mocking-patterns.md
- pytest-asyncio patterns./references/async-testing.md
- pytest-cov, branch coverage, reports./references/coverage-strategies.md
- Database fixtures, API testing, testcontainers./references/integration-testing.md
- Hypothesis framework, strategies, shrinking./references/property-testing.md
- Test pyramid, organization, isolation strategies./references/test-architecture.md
Scripts
- Run tests with recommended options./scripts/run-tests.sh
- Generate conftest.py boilerplate./scripts/generate-conftest.sh
Assets
- Recommended pytest configuration./assets/pytest.ini.template
- Common fixture patterns./assets/conftest.py.template
See Also
Related Skills:
- Type-safe test codepython-typing-patterns
- Async test patterns (pytest-asyncio)python-async-patterns
Testing specific frameworks:
- TestClient, API testingpython-fastapi-patterns
- Database fixtures, transactionspython-database-patterns