Skip to main content

Test impact analysis and code intelligence for LLM agents

Project description

Chisel

Test impact analysis and code intelligence built for AI coding agents. Zero external dependencies, open source, MIT licensed.

Chisel maps tests to code, code to git history, and answers: what to run, what's risky, and who touched it. It runs as an MCP server alongside your agent — Claude Code, Cursor, Windsurf, Cline, or any MCP-compatible client.

Chisel analyzing a real project — risk map, churn, ownership, test gaps, and agent interpretation

What it does

Chisel builds a graph connecting your code, tests, and git history, then answers three questions:

1. What to run

You change engine.py:store_document(). Instead of running all 287 tests or guessing with -k "test_store", Chisel tells the agent exactly which tests are impacted — through direct edges and transitive import-chain coupling.

2. What's risky

Risk scores per file based on churn rate, coupling breadth, test coverage gaps, author concentration, and test instability. A file that changes often, has one author, and no tests? That's your highest risk.

3. Who touched it

Blame-based ownership (who wrote it) and commit-activity-based reviewer suggestions (who maintains it). Useful when multiple agents or developers work on the same codebase and you need to understand lineage.

Why it exists

When multiple LLM agents (or agents + humans) work on the same codebase, changes in one area can silently break another.

Chisel gives AI coding assistants the intelligence to understand the blast radius of their changes before they commit. One agent's refactor doesn't silently regress another agent's work — automated code quality checks that work at the speed of your agent.

Install

Available on PyPI:

pip install chisel-test-impact

Or from source:

git clone https://github.com/IronAdamant/Chisel.git
cd Chisel
pip install -e .

Use with Claude Code (MCP)

Add to your Claude Code MCP config (~/.claude/settings.json or project .mcp.json):

{
  "mcpServers": {
    "chisel": {
      "command": "chisel-mcp",
      "env": {
        "CHISEL_PROJECT_DIR": "/path/to/your/project"
      }
    }
  }
}

Run analyze first to build the project graph, then diff_impact after edits to see which tests to run. For large repos, analyze with force=True automatically falls back to a background job so you don't hit MCP timeouts. Working-tree analysis (--working-tree) reuses a cached static import index and falls back to fast stem-matching for untracked files to stay within timeout budgets.

Monorepo sharding: Split large codebases across multiple SQLite databases with the CHISEL_SHARDS environment variable or .chisel/shards.toml. Query tools automatically aggregate across shards; writes route to the correct shard by file path.

After running tests, call record_result so Chisel can track failure rates and test instability over time. Or use chisel run -- pytest tests/ to run tests and record results automatically.

There is also an installable Claude Code skill with the distilled agent protocol: copy skills/SKILL.md to ~/.claude/skills/chisel/SKILL.md.

Use with Cursor, Windsurf, Cline, or other MCP clients

Chisel exposes a standard MCP interface. For stdio-based clients:

pip install chisel-test-impact[mcp]
chisel-mcp

For HTTP-based clients:

chisel serve --port 8377

Quickstart (CLI)

# Analyze a project (builds the graph)
chisel analyze .

# What tests are impacted by my current changes?
chisel diff-impact

# What tests should I run for this file?
chisel suggest-tests engine.py

# Risk heatmap across the project
chisel risk-map

# Find code with no test coverage, sorted by risk
chisel test-gaps

# Who owns this code?
chisel ownership engine.py

# Run tests AND record pass/fail results in one step
chisel run -- pytest tests/

# Incremental update (near-instant when nothing changed)
chisel update

Try it on this repo

git clone https://github.com/IronAdamant/Chisel.git
cd Chisel
pip install -e .

chisel analyze .
chisel risk-map
chisel diff-impact
chisel test-gaps

MCP Tools

20 functional tools plus 6 advisory file-lock helpers for multi-agent coordination.

Tool What it does
analyze Full project scan — builds the code/test/git graph. Optional shard param for sharded monorepos
update Incremental re-analysis of changed files only. Optional shard param for sharded monorepos
diff_impact Detects your changes from git diff and returns impacted tests. working_tree=true enables full static import scanning for untracked files. auto_update=true refreshes stale DB inline
suggest_tests Ranks tests by relevance for a given file. Prefers same-directory tests via stem matching. auto_update=true refreshes stale DB inline
impact Which tests cover these files or functions?
risk_map Risk scores for all files (churn + coupling + coverage gaps). working_tree=true includes untracked files. exclude_new_file_boost=true suppresses the temporary boost. auto_update=true refreshes stale DB inline
test_gaps Code with zero test coverage, sorted by risk. working_tree=true elevates uncommitted files to the top. auto_update=true refreshes stale DB inline
triage Top risks + gaps + stale tests in one call. Supports exclude_new_file_boost and auto_update
churn How often does this file or function change?
coupling Files that change together or import each other
ownership Blame-based — who wrote this code?
who_reviews Commit-activity-based — who maintains this code?
stale_tests Tests pointing at code that no longer exists
history Commit history for a file
record_result Log test pass/fail outcomes for future prioritization
run CLI-only: run tests and auto-record results (pytest, Jest)
stats Database summary and diagnostic counts
start_job Run analyze/update in background (avoids MCP timeouts). Optional shard param
job_status Poll a background job until complete
cancel_job Request cooperative cancellation of a running background job
optimize_storage Compact and vacuum the SQLite database

Features

  • Zero dependencies — stdlib only, Python 3.11+, works anywhere
  • Multi-language — Python, JavaScript/TypeScript, Go, Rust, C#, Java, Kotlin, C/C++, Swift, PHP, Ruby, Dart
  • Framework-aware — pytest, Jest, Go test, Rust #[test], Playwright, xUnit/NUnit/MSTest, JUnit (incl. parameterized), XCTest + Swift Testing, PHPUnit, RSpec, Minitest, gtest, Dart test
  • Incremental — only re-processes changed files, not the whole repo; a no-change update is near-instant
  • gitignore-aware — ignored trees (vendored deps, build output, fixtures) are never scanned; untracked files still are (CHISEL_INCLUDE_IGNORED=1 to override)
  • Branch-awarediff_impact auto-detects feature branch vs main
  • Multi-agent safe — cross-process locks so parallel agents don't corrupt the graph
  • MCP + CLI — stdio and HTTP MCP servers, plus a full CLI with 28 subcommands
  • CI-friendly — real exit codes (chisel analyze && pytest just works); copy-paste GitHub Actions example in examples/github-actions/
  • Monorepo sharding — split analysis across per-directory SQLite databases (CHISEL_SHARDS)
  • Custom extractors — plug in tree-sitter or LSP via register_extractor() if you need it

Ecosystem

Chisel sits in the agent loop: impact -> tests -> record results -> refresh analysis. It works standalone or alongside Stele for semantic code context.

Docs: Agent playbook | Claude Code skill | Zero-dependency policy | Custom extractors

License

MIT

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

chisel_test_impact-0.14.0.tar.gz (178.4 kB view details)

Uploaded Source

Built Distribution

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

chisel_test_impact-0.14.0-py3-none-any.whl (117.3 kB view details)

Uploaded Python 3

File details

Details for the file chisel_test_impact-0.14.0.tar.gz.

File metadata

  • Download URL: chisel_test_impact-0.14.0.tar.gz
  • Upload date:
  • Size: 178.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for chisel_test_impact-0.14.0.tar.gz
Algorithm Hash digest
SHA256 69c07611ad759c8f88eb2e216926e06f0a175c5a3de76d17a8a68cd8b62204b4
MD5 111c21e78fb2b76e9dff2190bf3157b4
BLAKE2b-256 000efc2d6926aba9b323987745c12e3e03b74ba7f6b6a03c28a1f31bb01dc72d

See more details on using hashes here.

Provenance

The following attestation bundles were made for chisel_test_impact-0.14.0.tar.gz:

Publisher: publish.yml on IronAdamant/Chisel

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file chisel_test_impact-0.14.0-py3-none-any.whl.

File metadata

File hashes

Hashes for chisel_test_impact-0.14.0-py3-none-any.whl
Algorithm Hash digest
SHA256 79b2565bb17698146e8621f6ae1c9beb792fcc000df4baed64c171679cfcf252
MD5 6ecdca9567bf530c8792462d35f77cf2
BLAKE2b-256 09c70e6d7527203e2292c9959dea0eb096bae734b37c5e4303369cc8abcdc516

See more details on using hashes here.

Provenance

The following attestation bundles were made for chisel_test_impact-0.14.0-py3-none-any.whl:

Publisher: publish.yml on IronAdamant/Chisel

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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