Skip to main content

An autonomous local-first AI agent that generates, executes, and self-heals Python unit tests in real-time.

Project description

Ghost: Autonomous Test Generation Agent

PyPI version Python Versions License Code Style

Ghost is a local-first autonomous agent designed to automate the unit testing lifecycle for Python applications. Functioning as a background daemon, it monitors filesystem events, generates context-aware pytest(or any other framework) suites, and autonomously resolves execution errors through a continuous feedback loop.

It is engineered for privacy and latency, supporting Ollama and LM Studio for fully local execution, alongside Groq, OpenAI, and Anthropic for cloud-based inference.

Core Capabilities

Context-Aware Code Analysis

Unlike generic AI coding assistants, Ghost parses the project's Abstract Syntax Tree (AST) to construct a dependency map. This ensures generated tests utilize correct imports, class hierarchies, and function signatures, significantly reducing runtime errors.

Autonomous Error Resolution (Self-Healing)

Ghost implements a closed-loop control system for test execution. When a generated test fails:

  1. Capture: stdout, stderr, and stack traces are intercepted.
  2. Analysis: The error context is analyzed against the source code.
  3. Patching: The agent generates and applies a fix (e.g., correcting imports, adjusting mocks).
  4. Verification: The test is re-executed to validate the patch.

Logic Verification Protocol ("The Judge")

To prevent regression validation—where tests are modified to match incorrect implementation logic—Ghost employs a secondary verification step. If an AssertionError occurs, a specialized "Judge" agent determines if the discrepancy stems from the test expectation or the source implementation. If the source code is deemed buggy, the agent halts and alerts the developer rather than altering the test.

Provider-Agnostic Architecture

Ghost decouples the agentic logic from the underlying LLM, allowing seamless switching between providers:

  • Groq: Recommended for high-frequency watch modes (low latency).
  • Ollama: Recommended for air-gapped or privacy-constrained environments.
  • OpenAI / Anthropic: Available for complex reasoning tasks.

Installation

Ghost is published to PyPI as ghosttest.

Global Installation (Recommended)

We recommend installing Ghost as a standalone tool using uv to ensure environment isolation.

uv tool install ghosttest

Standard Installation

pip install ghosttest

Quick Start

1. Initialization

Navigate to your project root and initialize the Ghost configuration. This generates a ghost.toml file and performs an initial AST scan of the codebase.

ghost init

2. Environment Configuration

If using cloud providers, export the necessary API keys. Local providers (Ollama/LM Studio) require no configuration.

# Example for Groq
export GROQ_API_KEY=gsk_...

# Example for OpenAI
export OPENAI_API_KEY=sk-...

3. Execution

Start the daemon. Ghost will monitor for file modifications and trigger the generation/healing loop automatically.

ghost watch

Configuration

Ghost is configured via ghost.toml.

[project]
name = "my-application"
language = "python"

[ai]
# Options: groq, ollama, openai, anthropic, lmstudio
provider = "groq"
model = "llama-3.3-70b-versatile"
rate_limit_rpm = 30

[scanner]
# Directories to exclude from context analysis
ignore_dirs = [".venv", "node_modules", "dist", "__pycache__"]
ignore_files = ["setup.py", "conftest.py"]

[tests]
framework = "pytest"
output_dir = "tests"
auto_heal = true
max_heal_attempts = 3
use_judge = true

Command Reference

Command Description
ghost init Initializes configuration and context map.
ghost watch Starts the filesystem monitor daemon.
ghost generate <file> Manually triggers test generation for a specific file.
ghost config Interactive configuration wizard.
ghost providers Lists supported providers and checks API connectivity.
ghost doctor Verifies installation health and dependencies.

License

This project is licensed under the MIT License.

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

ghosttest-0.2.2.2.tar.gz (37.8 kB view details)

Uploaded Source

Built Distribution

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

ghosttest-0.2.2.2-py3-none-any.whl (40.4 kB view details)

Uploaded Python 3

File details

Details for the file ghosttest-0.2.2.2.tar.gz.

File metadata

  • Download URL: ghosttest-0.2.2.2.tar.gz
  • Upload date:
  • Size: 37.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.11

File hashes

Hashes for ghosttest-0.2.2.2.tar.gz
Algorithm Hash digest
SHA256 25430d98b98057b0be232e8e0234dcd59b2257f08589778847f43151e4db1020
MD5 f42519368c74ef8fadd4736a2b93442e
BLAKE2b-256 4469b11e4c289d97e15e08d244b05b117e12191f586bfb0c4890d1ed078ae876

See more details on using hashes here.

File details

Details for the file ghosttest-0.2.2.2-py3-none-any.whl.

File metadata

  • Download URL: ghosttest-0.2.2.2-py3-none-any.whl
  • Upload date:
  • Size: 40.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.11

File hashes

Hashes for ghosttest-0.2.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 89531e1e1c229e3ffb484a70964d95c96e7e9e3db18c1f8a82d545fba464973c
MD5 d71b9d6a5a704d5bcb07ed2335eb49ab
BLAKE2b-256 b3c1ceafe8cae88b028d70d50527e939b864a04bdaf2700d52ea13e89a33f9be

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