Skip to content

fix(signals): classify C# protobuf stubs as generated#3437

Merged
gittensory-orb[bot] merged 1 commit into
JSONbored:mainfrom
jimcody1995:fix/path-matchers-pb-cs-generated
Jul 5, 2026
Merged

fix(signals): classify C# protobuf stubs as generated#3437
gittensory-orb[bot] merged 1 commit into
JSONbored:mainfrom
jimcody1995:fix/path-matchers-pb-cs-generated

Conversation

@jimcody1995

Copy link
Copy Markdown
Contributor

Summary

Scope

  • Conventional Commit title format.
  • Focused — path-matchers + unit tests only.
  • Follows CONTRIBUTING.md.
  • No linked issue needed.

Validation

  • git diff --check
  • npm run test:ci on Node 22
  • npm audit --audit-level=moderate — 0 vulnerabilities
  • Unit test covers proto/messages.pb.cs as generated and src/MainForm.cs as non-generated

Safety

  • No secrets, auth, or UI changes.
  • N/A for UI Evidence.

UI Evidence

N/A — backend path classifier only.

Notes

Conflict avoidance: Touches only src/signals/path-matchers.ts and test/unit/path-matchers.test.ts. Zero overlap with open PRs (#3435/#3406 engine, #3434 enrichment, #3433 integrations, #3432 repo-policy tests, #3431 rees release, #3429 release workflow, #3414 review-evasion, #3314 miner, #3305 enrichment-wire, #3304 queue/gate). Merges cleanly after any of those land without rebase.

Made with Cursor

protoc's C# plugin emits .pb.cs message stubs; slop already treated
.pb.kt/.pb.dart as generated but missed .pb.cs, so machine output was
miscounted as substantive source.

Co-authored-by: Cursor <cursoragent@cursor.com>
@jimcody1995 jimcody1995 requested a review from JSONbored as a code owner July 5, 2026 07:05
@superagent-security

Copy link
Copy Markdown

Superagent didn't find any vulnerabilities or security issues in this PR.

@gittensory-orb gittensory-orb Bot added the gittensor:bug Gittensor-scored bug fix — scores a 0.5x multiplier. label Jul 5, 2026
@gittensory-orb

gittensory-orb Bot commented Jul 5, 2026

Copy link
Copy Markdown

Warning

🟨🟨🟨🟨🟨🟨🟨🟨🟨🟨🟨🟨

⏸️ Gittensory review result - manual review recommended

Review updated: 2026-07-05 07:11:04 UTC

2 files · 1 AI reviewer · no blockers · readiness 80/100 · CI green · clean

⏸️ Suggested Action - Manual Review

Review summary
This focused change extends the generated-file matcher to classify C# protobuf stubs ending in `.pb.cs` the same way as the existing protobuf outputs, and the normalization/lowercasing path means mixed-case or Windows-style inputs follow the existing behavior. The added unit case exercises the actual `isGeneratedFile` helper that feeds `classifyChangedFile`, so the core behavior is covered; I do not see a reachable correctness break in the diff. The only cleanup I would ask for is tightening the comment/test coverage around the hot-path classifier so the PR documents and verifies the claimed `classifyChangedFile` effect directly.

Nits — 5 non-blocking
  • nit: `src/signals/path-matchers.ts:55` now has a slightly awkward duplicate comment line listing only `.pb.dart`/`.pb.kt`/`.pb.cs`; fold it into the preceding protoc sentence or change it to a generic statement that the `.pb` infix protects hand-written sources.
  • nit: `test/unit/path-matchers.test.ts:81` proves `isGeneratedFile("proto/messages.pb.cs")`, but the PR description specifically calls out `classifyChangedFile` miscounting, so add one representative classifier assertion to keep the hot-path contract explicit.
  • In `test/unit/path-matchers.test.ts` under `classifyChangedFile`, add `["proto/messages.pb.cs", "generated"]` to the representative cases so the claimed signals path is covered directly.
  • In `src/signals/path-matchers.ts`, simplify the protoc comment to something like `The .pb infix keeps hand-written sources in these languages from matching.`
  • Code changes lack test evidence — Add focused regression tests or explain why existing coverage is sufficient.
Signal Result Evidence
Code review ✅ No blockers 1 reviewer
Linked issue ✅ No-issue rationale PR body explains why no issue is linked.
Related work ✅ No active overlap found No same-issue or scoped active PR overlap found.
Change scope ✅ 20/20 Low review scope from cached public metadata (no linked issue context).
Validation posture ❌ 5/25 Preflight is holding this PR: the review lane is unavailable, so it is not ready for automated review.
Contributor workload ✅ 10/10 Author activity: 58 registered-repo PR(s), 31 merged, 0 issue(s).
Contributor context ✅ Confirmed Gittensor contributor jimcody1995; Gittensor profile; 58 PR(s), 0 issue(s).
Gate result ✅ Passing No configured blocker found.
Review context
  • Author: jimcody1995
  • Role context: outside_contributor
  • Public audience mode: oss maintainer
  • Lane context: Repository registration is not available in the local Gittensory cache.
  • Public profile languages: TypeScript, JavaScript
  • Official Gittensor activity: 58 PR(s), 0 issue(s).
  • PR-specific overlap: none found.
Contributor next steps
  • Await review-lane availability.
  • Refresh registry data or choose a registered active repo.
  • Link the issue being solved, or explicitly explain why this is a no-issue PR.
Signal definitions
  • Related work = same linked issue, overlapping active PRs, or title/path similarity.
  • Change scope = cached public metadata such as size labels, draft state, and review-burden hints.
  • Validation posture = whether the PR provides enough public validation/test evidence for maintainer review.
  • Contributor workload = public contributor activity and cleanup pressure, not a repo-wide quality failure.
  • Contributor context = public GitHub/Gittensor identity context; non-Gittensor status is not a blocker.

🟩 Safe / merged · 🟦 Advisory · 🟨 Held for review · 🟥 Blocked / closed


💰 Earn for open-source contributions like this. Gittensor lets GitHub contributors earn for the work they already do — register to start earning →.

Checked by Gittensory, a quiet PR intelligence layer for OSS maintainers.

  • Re-run Gittensory review

@codecov

codecov Bot commented Jul 5, 2026

Copy link
Copy Markdown

Codecov Report

✅ All modified and coverable lines are covered by tests.
✅ Project coverage is 93.47%. Comparing base (1ad5b35) to head (3a84b80).
⚠️ Report is 4 commits behind head on main.

Additional details and impacted files
@@           Coverage Diff           @@
##             main    #3437   +/-   ##
=======================================
  Coverage   93.47%   93.47%           
=======================================
  Files         292      292           
  Lines       30797    30797           
  Branches    11225    11225           
=======================================
  Hits        28786    28786           
  Misses       1355     1355           
  Partials      656      656           
Files with missing lines Coverage Δ
src/signals/path-matchers.ts 88.46% <ø> (ø)
🚀 New features to boost your workflow:
  • 📦 JS Bundle Analysis: Save yourself from yourself by tracking and limiting bundle sizes in JS merges.

@gittensory-orb gittensory-orb Bot left a comment

Copy link
Copy Markdown

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Gittensory approves — the gate is satisfied and CI is green.

@gittensory-orb gittensory-orb Bot merged commit c72d97d into JSONbored:main Jul 5, 2026
8 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

gittensor:bug Gittensor-scored bug fix — scores a 0.5x multiplier.

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant