Skip to main content

Deterministic PR readiness detection for AI coding agents

Project description

Good To Go

PyPI version Python 3.9+ License: MIT Test Coverage

Deterministic PR readiness detection for AI coding agents

"Is the PR ready to merge?" — Finally, a definitive answer.

Documentation · PyPI · Contributing


Why Good To Go?

AI agents can write code, fix bugs, and respond to reviews. But they all struggle with one question: "Am I done yet?"

  • CI is running... check again... still running...
  • CodeRabbit left 12 comments — which ones are blocking?
  • Reviewer wrote "consider X" — is that a request or a suggestion?
  • Threads are unresolved — but the fix is already pushed

Good To Go answers this definitively:

gtg 123
OK PR #123: READY
   CI: success (5/5 passed)
   Threads: 3/3 resolved

One command. One status. No guessing.

How It Works

flowchart LR
    PR[Pull Request] --> GTG[gtg]
    GTG --> CI[CI Status]
    GTG --> Comments[Comment Analysis]
    GTG --> Threads[Thread Resolution]

    CI --> Status{Status}
    Comments --> Status
    Threads --> Status

    Status --> READY[✓ READY]
    Status --> ACTION[! ACTION_REQUIRED]
    Status --> UNRESOLVED[? UNRESOLVED_THREADS]
    Status --> FAILING[✗ CI_FAILING]

Good To Go combines three analyses:

Analysis What It Does
CI Status Aggregates all checks into pass/fail/pending
Comment Classification Identifies actionable vs. informational comments
Thread Resolution Tracks which discussions are truly blocking

Intelligent Comment Classification

Not all comments need action. Good To Go classifies each one:

Classification Examples Action
ACTIONABLE "Critical: SQL injection vulnerability" Must fix
NON_ACTIONABLE "LGTM!", nitpicks, resolved items Ignore
AMBIGUOUS "Consider using X", questions Human review

Built-in support for: CodeRabbit, Greptile, Claude, Cursor/Bugbot

Quick Start

# Install
pip install gtg

# Set GitHub token
export GITHUB_TOKEN=ghp_...

# Check a PR (auto-detects repo)
gtg 123

# Explicit repo
gtg 123 --repo owner/repo

Output Formats

Text (Human-Readable)

gtg 123 --format text
!! PR #456: ACTION_REQUIRED
   CI: success (5/5 passed)
   Threads: 8/8 resolved

Action required:
   - Fix CRITICAL comment from coderabbit in src/db.py:42

JSON (For Agents)

gtg 123 --format json
{
  "status": "ACTION_REQUIRED",
  "action_items": ["Fix CRITICAL comment from coderabbit in src/db.py:42"],
  "actionable_comments": [...],
  "ci_status": {"state": "success", "passed": 5, "total_checks": 5}
}

Exit Codes

Default (AI-friendly) — parse the JSON for details:

Code Meaning
0 Any analyzable state
4 Error

With -q or --semantic-codes — for shell scripts:

Code Status
0 READY
1 ACTION_REQUIRED
2 UNRESOLVED_THREADS
3 CI_FAILING
4 ERROR

Use as CI Gate

Make gtg a required check to block merges until PRs are truly ready:

# .github/workflows/pr-check.yml
- name: Check PR readiness
  run: gtg ${{ github.event.pull_request.number }} --semantic-codes

See USAGE.md for full workflow setup.

For AI Agents

import subprocess
import json

result = subprocess.run(
    ["gtg", "123", "--format", "json"],
    capture_output=True, text=True
)
data = json.loads(result.stdout)

if data["status"] == "READY":
    print("Merge it!")
else:
    for item in data["action_items"]:
        print(f"TODO: {item}")

Or use the Python API:

from goodtogo import PRAnalyzer, Container

container = Container.create_default(github_token="ghp_...")
analyzer = PRAnalyzer(container)
result = analyzer.analyze("owner", "repo", 123)

State Persistence

Track handled comments across sessions:

gtg 123 --state-path .goodtogo/state.db  # Remember dismissed comments
gtg 123 --refresh                         # Force fresh analysis

Documentation

License

MIT License — see LICENSE


Made with Claude Code
by David Sifry

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

gtg-0.7.2.tar.gz (55.7 kB view details)

Uploaded Source

Built Distribution

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

gtg-0.7.2-py3-none-any.whl (66.3 kB view details)

Uploaded Python 3

File details

Details for the file gtg-0.7.2.tar.gz.

File metadata

  • Download URL: gtg-0.7.2.tar.gz
  • Upload date:
  • Size: 55.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for gtg-0.7.2.tar.gz
Algorithm Hash digest
SHA256 6322f89de6a28c1b00c9957e9b026bc9b7660ad591b804652f61cc1b752728ea
MD5 d554c2dbc6e99fd8c6ff0edc92cd1a98
BLAKE2b-256 a09d73b1a9e9e93cc0230630cad14f92e4ea0b19dd9be097237e8bfd34a895b7

See more details on using hashes here.

Provenance

The following attestation bundles were made for gtg-0.7.2.tar.gz:

Publisher: publish.yml on dsifry/goodtogo

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

File details

Details for the file gtg-0.7.2-py3-none-any.whl.

File metadata

  • Download URL: gtg-0.7.2-py3-none-any.whl
  • Upload date:
  • Size: 66.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for gtg-0.7.2-py3-none-any.whl
Algorithm Hash digest
SHA256 3039b9618af4d7d6ea1d33b884078d6cdb2f66b2a88ac88712abbaec6638219c
MD5 81a294b120c42d3c289df6eb3c6f072d
BLAKE2b-256 8ee7c2a206c5c8f2d4c9ab54d4a9a47517e3fe10e2b504c0b2bfb6d3f1b4c3ec

See more details on using hashes here.

Provenance

The following attestation bundles were made for gtg-0.7.2-py3-none-any.whl:

Publisher: publish.yml on dsifry/goodtogo

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