Skip to main content

Pytest plugin framework with AI agent capabilities for multi-agent testing

Project description

pytest-agents

CI CodeQL Release GitHub Release PyPI Security Policy Python Version Coverage Tests Metrics License Docker Code Style

A pytest plugin framework with AI agent capabilities for project management, research, and code indexing.

Quick Start

# Install from PyPI
pip install pytest-agents

# Verify installation
pytest-agents verify

Features

  • Pytest Plugin: Extended pytest with custom markers and AI agent integration
  • PM Agent: TypeScript-based project management agent for task tracking and planning
  • Research Agent: AI-powered research and documentation analysis
  • Index Agent: Code indexing and intelligent search capabilities
  • Prometheus Metrics: Comprehensive observability with metrics collection and HTTP endpoint
  • Dependency Injection: Full DI implementation across Python and TypeScript components
  • Skills System: Extensible runtime skills for specialized tasks

Quick Start

Installation

From PyPI (Recommended):

pip install pytest-agents

From Docker:

docker pull ghcr.io/kmcallorum/pytest-agents:latest
docker run ghcr.io/kmcallorum/pytest-agents:latest pytest-agents verify

From Source:

# Clone repository
git clone https://github.com/kmcallorum/pytest-agents.git
cd claudelife

# Install with uv
make install

# Or manually
uv pip install -e ".[dev]"

Verify Installation

make verify

Run Tests

# All tests
make test

# Python only
make test-python

# TypeScript only
make test-ts

Project Structure

pytest-agents/
├── src/pytest_agents/   # Python pytest plugin package
├── tests/               # Python tests
├── pm/                  # TypeScript PM agent
├── research/            # TypeScript Research agent
├── index/               # TypeScript Index agent
├── skills/              # Runtime skills
├── commands/            # Command documentation
└── docs/                # Documentation

Usage

Using Custom Pytest Markers

import pytest

@pytest.mark.unit
def test_basic_functionality():
    assert True

@pytest.mark.integration
@pytest.mark.agent_pm
def test_with_pm_agent(pytest_agents_agent):
    result = pytest_agents_agent.invoke('pm', 'analyze_project')
    assert result['status'] == 'success'

Parallel Agent Execution

Run multiple agents concurrently for faster test execution:

def test_multi_agent_parallel(agent_coordinator):
    """Run multiple agents in parallel."""
    results = agent_coordinator.run_parallel([
        ('pm', 'track_tasks', {'path': './src'}),
        ('research', 'analyze_document', {'path': 'README.md'}),
        ('index', 'index_repository', {'path': './src'})
    ])

    assert all(r['status'] == 'success' for r in results)

Invoking Agents

# Via Python API
from pytest_agents.agent_bridge import AgentBridge

bridge = AgentBridge()
result = bridge.invoke_agent('pm', 'track_tasks', {'path': './src'})
# Via CLI
pytest-agents agent pm --action track_tasks --path ./src

Metrics and Observability

# Start Prometheus metrics server
pytest-agents metrics

# Custom port
pytest-agents metrics --port 8080

# Configure via environment
export PYTEST_AGENTS_METRICS_ENABLED=true
export PYTEST_AGENTS_METRICS_PORT=9090

View metrics at http://localhost:9090/metrics. See Metrics Documentation for Prometheus and Grafana integration.

Development

Code Quality

# Format code
make format

# Lint code
make lint

Health Check

make doctor

Docker Support

pytest-agents is fully containerized for easy deployment and development.

Quick Start with Docker

# Build and run verification
docker-compose up pytest-agents

# Run tests in Docker
docker-compose --profile test up pytest-agents-test

# Start development shell
docker-compose --profile dev run pytest-agents-dev

See Docker Documentation for complete deployment guide.

Security

pytest-agents implements enterprise-grade security practices:

Automated Security Scanning

  • CodeQL: Static analysis detecting 400+ security vulnerabilities in Python and TypeScript
  • Snyk Security: Continuous vulnerability scanning for dependencies and containers
  • Dependency Scanning: Automated vulnerability detection via Dependabot
  • Container Scanning: Docker image vulnerability assessment
  • Code Quality: Ruff linting with security-focused rules

Security Features

  • Multi-stage Docker builds with minimal attack surface
  • Dependency pinning for reproducible builds
  • Comprehensive test coverage (61%, 230 tests)
  • Automated security updates grouped by severity

Setup and Configuration

New to security scanning? See Security Setup Guide for step-by-step instructions to activate Snyk and Dependabot.

Reporting Vulnerabilities

Please report security vulnerabilities privately via GitHub Security Advisories.

See SECURITY.md for complete security policy and disclosure guidelines.

Documentation

See docs/ directory for detailed documentation:

License

MIT

Author

Kevin McAllorum

Security scanning now enabled!

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pytest_agents-1.0.16.tar.gz (298.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pytest_agents-1.0.16-py3-none-any.whl (25.3 kB view details)

Uploaded Python 3

File details

Details for the file pytest_agents-1.0.16.tar.gz.

File metadata

  • Download URL: pytest_agents-1.0.16.tar.gz
  • Upload date:
  • Size: 298.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pytest_agents-1.0.16.tar.gz
Algorithm Hash digest
SHA256 b941a9cc46951dd9b99535a90538e9a18c2ab9e4fbe0ba1aa8bbbbdd90872295
MD5 b344b2d4bf78589ad69f733e74c72025
BLAKE2b-256 8d6724fd0107728009d5051fb933715cca12b5bc526a1c2460f433598ff5d596

See more details on using hashes here.

File details

Details for the file pytest_agents-1.0.16-py3-none-any.whl.

File metadata

  • Download URL: pytest_agents-1.0.16-py3-none-any.whl
  • Upload date:
  • Size: 25.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pytest_agents-1.0.16-py3-none-any.whl
Algorithm Hash digest
SHA256 73b4c2485918a5192cb30e8dc9ffb9844482b9c5be79a54fa072e929090af471
MD5 8ed4516225e4753ec8c9b24de775887e
BLAKE2b-256 dddbeb236b84075f188b1f4e78d9c18206772a3618e6a2eeadcb2b541251fdad

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page