01 · Roasts
Commit Hermit
57 commits in a year across 23 repos, with months-long stretches of radio silence. The heatmap looks like a QR code that failed to scan — mostly white.
Test Skeleton Factory
eatsee_db has HAS_TESTS=yes — technically true. Except the test methods are `pass` statements. Congrats on shipping the world's most aspirational test suite.
README? Never Heard of Her
birdle has zero documentation. No README, no DESIGN.md, no inline comments beyond a single-line description. 800 LOC of mystery meat.
Solo Artist, No Audience
soloPct = 100%, 9 followers, 3 total PRs this year, 0 issues. The collaboration graph is a dot. Not even a line — a dot.
Stale Half-Life
41% of your repos haven't been touched in 2+ years. You've got more abandoned repos than commits this month.
Built using
Zoral
Shadows one worker for a week, then takes over their job with zero extra setup. Behaves exactly like the original.
zoral.ai
02 · Category breakdown
- Impact25% weight30F
- Consistency20% weight20F
- Quality20% weight47D
- Depth15% weight50D
- Breadth10% weight65C
- Community10% weight25F
03 · Stats
365-day commit heatmap
15 active days
Language distribution
- TypeScript37%
- C#27%
- Python27%
- Ruby3%
- CSS2%
- HTML2%
- Other2%
04 · Numbers
Owned repos
non-fork
17
Commits
last 12 months
57
Followers
9
Joined GitHub
Dec 2020
05 · Top repos
chuajunyu /
eatsee_db
Personal university project with a FastAPI backend for a Telegram food-matching bot. Python-based with PostgreSQL, basic class structure, and minimal test coverage. No type hints, no CI pipeline, but README and basic tests present. 13.2 MB codebase suggests ~260 LOC estimated.
chuajunyu /
birdle
Birdle is a TypeScript bird-song guessing game that fetches recordings from Xeno-Canto API. It ships typed code, structured src/ layout, and meaningful game logic, but lacks documentation, tests, and CI. Created March 2026 with ~27 commits in ~3 weeks.
chuajunyu /
fetchcanvas
Untyped Python script to download Canvas LMS course files with env config. Functional utility with modest scope—10k+ LOC, well-structured API handlers, and changelog tracking, but no tests, CI, or type hints limit adoption potential.
06 · Timeline
- Dec 7, 2020Joined GitHub
- Apr 11, 2023Created eatsee_db — Database and Server behind an API for Eatsee
- Jan 13, 2026Created fetchcanvas — Script to download files from Canvas LMS
- Mar 17, 2026Created birdle — Guess the bird by it's song
- Apr 13, 2026Most recent push to birdle
07 · Compare
08 · Rubric
How this score was produced
Overall = Σ (category × weight) + gentle top-end curve
Tier thresholds
▸ How the pipeline works
- 01Scrape.Pull every non-fork repo pushed in the last 90 days, plus your contribution calendar, followers, and language byte counts — straight from GitHub's REST & GraphQL APIs.
- 02Triage.A small model reads every repo's file tree + README and picks the 20 files per repo that actually reveal how you code.
- 03Grade each repo. All repos run in parallel through a fast scoring model that reads the picked files and rates each one independently on Impact, Quality, and Depth — with evidence citations.
- 04Aggregate. A larger reasoning model combines the per-repo scores with server-computed stats (heatmap, commit cadence, language entropy, follower count) to produce the 6-dimension profile score + roasts.
- 05Correct.Deterministic server-side checks enforce anchor-scale floors (e.g. a profile with 2,000+ public commits can't score 30 Consistency) and recompute the final verdict.
~90 seconds per profile, ~$0.25 in compute. Total of ~240 files read across your top-12 repos. One rating per GitHub account per day.
▸ Data sources & caveats
- Heatmap & commit totals: GitHub GraphQL
contributionsCollection— covers the last 365 days, includes private repos when the user has opted in (default). - Language %: byte totals across the top 30 owned non-fork repos.
- Curve: a small upward nudge centered on raw score ≈ 70, capping at 100. Prevents specialists from being unfairly penalised for narrow breadth.
- Anchor corrections: when server-measured signals (e.g. privateWorkLikely, multiRepoVolume, follower count) mandate a minimum category score, the aggregation step enforces it. These are signal-conditional, not identity-based floors.