Ghost - An autonomous local-first AI Agent that generates, runs, and self-heals Python unit tests in real-time. Supports Ollama, Groq, and many frameworks such as pytest.
Project description
Ghost: Autonomous Test Generation Agent
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 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:
- Capture: stdout, stderr, and stack traces are intercepted.
- Analysis: The error context is analyzed against the source code.
- Patching: The agent generates and applies a fix (e.g., correcting imports, adjusting mocks).
- 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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file ghosttest-0.2.2.0.tar.gz.
File metadata
- Download URL: ghosttest-0.2.2.0.tar.gz
- Upload date:
- Size: 37.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a2621f2f98aab1f5ad821770a246bc88d49ae88731ea35a360843f471d1ff254
|
|
| MD5 |
275dceb02f6789721d73315db046649f
|
|
| BLAKE2b-256 |
dea71ce8ce333257dbd6c5a8a9ff38ed33b61c587aa45e2331ca59d7217fe9cd
|
File details
Details for the file ghosttest-0.2.2.0-py3-none-any.whl.
File metadata
- Download URL: ghosttest-0.2.2.0-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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bd8afeccb9202c78a0cc33175f438825f709c658c5dac693284cc70da61ea440
|
|
| MD5 |
bc76887eb85af5161520f16201565d9a
|
|
| BLAKE2b-256 |
6649cd54931817a55357bc94e69022b9606d984f57deeb5f8d9e7d7d8f40f286
|