Claude-powered git pre-push diff reviewer for indie OSS projects.
Project description
build-quality-agent
English | 中文
Claude-powered git pre-push reviewer for indie OSS projects. Stops the bad commit before it costs you a Vercel build minute.
Built by Alex Ji — solo founder shipping VibeXForge and Orallexa. Born from this thought:
I just spent $131.92 in Vercel build minutes this month because I keep pushing commits with type errors and missing imports.
What it does
Before every git push, it runs Claude over the diff and decides:
- PASS — push proceeds
- BLOCK — push is aborted, you fix the issue locally
That's the whole pitch. No CI loop. No remote build that fails 6 minutes in. Catches the obvious stuff (type errors, removed imports, hardcoded secrets, reverted auth checks) before your laptop fan even spins up.
--build flag (v0.3+) — also run the actual build
--build runs the project's local build before review (auto-detects: npm/pnpm/bun/yarn run build for JS, python -m build, cargo check, go build). If the build fails, the build log is appended to the Claude prompt for a unified explanation, and the push is always BLOCKed.
build-quality-agent --build # one-off
BUILD_AGENT_BUILD=1 git push # default for this push
The 4-minute build cap is generous; most local builds for indie projects are 30-90s. Combined cost of --build + diff review: ~$0.0006 + ~30-60s of laptop time, vs ~$0.12/min × 6min = $0.72 saved per build that would have failed remotely.
Install
# 1. Clone
git clone https://github.com/alex-jb/build-quality-agent.git
cd build-quality-agent
pip install -e .
# 2. Set your Anthropic key (graceful no-op without it)
export ANTHROPIC_API_KEY=sk-ant-...
# 3. Wire into a target repo
cd ~/path/to/your/repo
bash ~/Desktop/build-quality-agent/scripts/install-hook.sh
That's it. Next git push will trigger a review.
Bypass
If the agent is wrong (it sometimes is — Claude reviews a diff, not a full repo, so context-free changes occasionally trip it):
BUILD_AGENT_SKIP=1 git push
This is the explicit, loud bypass. --no-verify also works but is silent. We prefer loud.
Usage examples
# Manual run on the most recent commit
python3 -m build_quality_agent --diff-range HEAD~1..HEAD
# Review without blocking (advisory mode)
python3 -m build_quality_agent --no-block
# Quiet unless something's wrong
python3 -m build_quality_agent --quiet
# Force a specific model
BUILD_AGENT_MODEL=claude-sonnet-4-6 python3 -m build_quality_agent
# Token + cost report (aggregates ~/.build-quality-agent/usage.jsonl)
python3 -m build_quality_agent --usage
Design choices
- Default Haiku 4.5, not Sonnet. Diff review is a fast cheap task — Haiku gets ~10s response and pennies per push. Sonnet only kicks in if you set
BUILD_AGENT_MODEL. - PASS by default on any internal failure. Network down, key missing, Claude flake — the agent prints a warning and lets the push through. Better unverified push than blocking real work.
- 50kB diff cap, junk paths excluded. Lockfiles (
package-lock.json,bun.lock, etc.), generated types (next-env.d.ts), build output (.next/,dist/), and binary assets (images, fonts, MP4s) are stripped before review so the budget gets spent on real source. - Vercel-aware prompt. The agent specifically looks for the patterns that crash Next.js / Vercel builds: missing
default exportonpage.tsx/layout.tsx, client hooks without"use client", server-only imports leaking into client components, undefined symbols, hardcoded secrets. - Reads git's pre-push stdin. When invoked as a hook, the agent parses the
<local_ref> <local_oid> <remote_ref> <remote_oid>lines git passes in. That makes the review range exactly match what's being pushed — including new branches without upstream tracking. - No build runner inside the hook. Running
npm run buildin pre-push would add 5-6 min to every push. Out of scope here. This agent reviews intent + obvious bugs; a separate CI build still catches everything.
Cost tracking
Every review writes a row to ~/.build-quality-agent/usage.jsonl. Run python3 -m build_quality_agent --usage to see total runs, pass/block split, token counts, and an estimated dollar cost (Haiku 4.5: $1/MTok in, $5/MTok out).
Roadmap
- v0.1 — Pre-push hook · Claude diff review · graceful degradation
- v0.2 —
pip install -e .portability · git stdin parsing · junk-path filter · Vercel-aware prompt · pytest suite ·--usagecost report - v0.3 — Project-specific rule files (
.build-quality-agent.toml) - v0.4 —
--buildflag for projects that want the slow runtime build - v0.5 — Auto-suggested fix (Claude proposes the smallest patch that would PASS)
MCP server (Claude Desktop / Cursor / Zed)
Review a diff inline from your AI assistant.
pip install 'build-quality-agent[mcp]'
Then in ~/Library/Application Support/Claude/claude_desktop_config.json:
{
"mcpServers": {
"build-quality": {
"command": "build-quality-mcp",
"env": { "ANTHROPIC_API_KEY": "..." }
}
}
}
Tools: review_diff(diff) · review_range(diff_range) · usage_summary()
License
MIT.
🧩 Part of the Solo Founder OS stack
A growing collection of MIT-licensed agents that share solo-founder-os as their base — Source/MetricSample contracts, HITL queue, AnthropicClient, notifiers, scheduler. Each agent is independently useful; together they cover the full solo-founder workflow.
| Agent | What it does |
|---|---|
| solo-founder-os | The shared base lib (Source/MetricSample, AnthropicClient, HITL queue, notifiers, sfos-doctor / sfos-evolver / sfos-eval / sfos-retro / sfos-bus / sfos-inbox) |
| customer-discovery-agent | Reddit pain-point scraper + Claude clustering for product validation |
| funnel-analytics-agent | Daily brief + real-time alerts across 9 sources (Vercel, GitHub, Supabase, etc.) |
| vc-outreach-agent | Investor cold email drafter with HITL queue + SMTP sender |
| cost-audit-agent | Monthly bill audit across 6 providers with dollar-tagged waste findings |
| bilingual-content-sync-agent | EN ⇄ ZH i18n diff + Claude translate + HITL apply |
| orallexa-marketing-agent | AI marketing agent for OSS founders — auto-generate platform-specific marketing posts |
Each agent's own row is omitted from its README. Install whichever solve real problems for you.
Project details
Release history Release notifications | RSS feed
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 build_quality_agent-0.5.0.tar.gz.
File metadata
- Download URL: build_quality_agent-0.5.0.tar.gz
- Upload date:
- Size: 21.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
772f815521e6723cff59871a36af4d093eafc58f095233a25b2ae5f79c5e7c4f
|
|
| MD5 |
0e47414d90c9208bc729ddf260175d99
|
|
| BLAKE2b-256 |
dccfe4f6bfe437cec62b1c56c8b47e9f3c0dc197d2061db551ed518a46f44e3c
|
Provenance
The following attestation bundles were made for build_quality_agent-0.5.0.tar.gz:
Publisher:
release.yml on alex-jb/build-quality-agent
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
build_quality_agent-0.5.0.tar.gz -
Subject digest:
772f815521e6723cff59871a36af4d093eafc58f095233a25b2ae5f79c5e7c4f - Sigstore transparency entry: 1478060252
- Sigstore integration time:
-
Permalink:
alex-jb/build-quality-agent@cc4441305a92ed63115f60660f9eef6cd5b8a95a -
Branch / Tag:
refs/tags/v0.5.0 - Owner: https://github.com/alex-jb
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@cc4441305a92ed63115f60660f9eef6cd5b8a95a -
Trigger Event:
push
-
Statement type:
File details
Details for the file build_quality_agent-0.5.0-py3-none-any.whl.
File metadata
- Download URL: build_quality_agent-0.5.0-py3-none-any.whl
- Upload date:
- Size: 17.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c8396f2d1bfab7e9518df412704f03da658e1255b2500132fccb8954a4f3c597
|
|
| MD5 |
b98e797baef533bee59cac4d50d8fbe6
|
|
| BLAKE2b-256 |
aa3b26f243e9826f30dfb47a65ee1a6b29bc8cfb91987118b56e040a9b238f55
|
Provenance
The following attestation bundles were made for build_quality_agent-0.5.0-py3-none-any.whl:
Publisher:
release.yml on alex-jb/build-quality-agent
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
build_quality_agent-0.5.0-py3-none-any.whl -
Subject digest:
c8396f2d1bfab7e9518df412704f03da658e1255b2500132fccb8954a4f3c597 - Sigstore transparency entry: 1478060699
- Sigstore integration time:
-
Permalink:
alex-jb/build-quality-agent@cc4441305a92ed63115f60660f9eef6cd5b8a95a -
Branch / Tag:
refs/tags/v0.5.0 - Owner: https://github.com/alex-jb
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@cc4441305a92ed63115f60660f9eef6cd5b8a95a -
Trigger Event:
push
-
Statement type: