Track your GitHub Actions success rate and wasted compute over time — local history, weekly trend, no dashboard account. Zero dependencies.
Project description
citrend
Is your CI actually getting worse, or does it just feel that way? GitHub Actions shows you one run at a time — nobody's tracking whether this month's success rate is better or worse than last month's, or how much compute your failures have actually burned. citrend pulls your workflow run history into a local file and gives you the trend. No dashboard account, no server.
pip install citrend
citrend sync --repo owner/name
citrend report --repo owner/name
This is the Python build — a Node build (npx citrend) exists too and reads the exact same ~/.citrend/<owner>__<repo>/runs.jsonl, so a team split across both ecosystems shares one history.
Why
"Curious what your pipeline success rate looks like. Has anyone else tracked the actual wasted compute time?"
That's a real question from a thread where someone had calculated their CI failures were burning a quarter of their compute budget — and found no lightweight way to track it over time, only heavyweight CI platforms with their own dashboards. citrend is a zero-dependency CLI answer: pull your run history locally, see the trend.
Example
$ citrend report --repo acme/widgets
acme/widgets — 812 run(s) (2 in progress)
success rate: 87.4% (699/800 settled, 12 skipped)
wasted runs: 101 (12.6%)
total compute: 118h 42m
wasted compute: 14h 6m
weekly trend (oldest → newest):
2026-06-05 91.2% success, 8 wasted (58m)
2026-06-12 88.0% success, 11 wasted (1h 22m)
2026-06-19 79.4% success, 22 wasted (3h 8m)
2026-06-26 84.1% success, 15 wasted (2h 1m)
Watching that weekly column is the whole point — a single gh run list doesn't show you that week 3 was a cliff.
Commands
citrend sync --repo <owner/name> [--workflow <file-or-id>] [--branch <b>] [--token <t>] [--limit N]
citrend report --repo <owner/name> [--since <dur>] [--weeks N] [--json]
syncpulls recent workflow runs from the GitHub Actions API and appends the new ones to local history — safe to run repeatedly (e.g. on a schedule or before everyreport); it dedupes by run id.reportreads local history only — no network call — and prints overall stats plus a weekly trend.--token, or$GITHUB_TOKEN/$GH_TOKEN, raises the GitHub API rate limit from 60 req/hr (unauthenticated) to 5000 req/hr. A public repo works fine unauthenticated for occasional syncing.
What counts as "wasted"
A run is wasted if it settled (has a conclusion) and that conclusion isn't success or skipped — so failure, cancelled, timed_out, and anything else GitHub reports all count. Still-running runs aren't counted either way until they conclude. "Compute" is wall-clock duration (run_started_at → updated_at) as reported by the Actions API — a reasonable proxy for spent runner time, not an exact billed-minutes figure (which needs a separate, higher-overhead per-job timing call).
Storage
History is cached at ~/.citrend/<owner>__<repo>/runs.jsonl — not committed to the repo it tracks, since (unlike a hand-written record) this is just a local mirror of data GitHub already stores. Override with --dir or $CITREND_HOME.
Exit codes
| Code | Meaning |
|---|---|
0 |
ok |
2 |
usage error, bad repo, or GitHub API error (rate limit, 404, network) |
License
MIT
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 citrend-0.1.0.tar.gz.
File metadata
- Download URL: citrend-0.1.0.tar.gz
- Upload date:
- Size: 19.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
218594965dcb664f81cf5d5a6efe3a8890d4e37d5c95db6e01635570dfe30401
|
|
| MD5 |
e03b2e2df9c132d55f36de75809dfd99
|
|
| BLAKE2b-256 |
3f44dcd4f46e6d319f830214517c39b58492d8e53eb5dce5ab37cd8b21bc1b24
|
File details
Details for the file citrend-0.1.0-py3-none-any.whl.
File metadata
- Download URL: citrend-0.1.0-py3-none-any.whl
- Upload date:
- Size: 15.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b2254d864f95693252c486f855406bbd1c58d918aad982a5e50b49053981a7d5
|
|
| MD5 |
0c95fec1e66d5f0effe5f55c72988aeb
|
|
| BLAKE2b-256 |
85ec22872f9a6e76d79a9920389c6e13d5055526bdc86f99844f81662523189c
|