Agent skill
codescene-health-rules
Generate, modify, or audit `.codescene/code-health-rules.json` files that control CodeScene's code health scan behaviour. Use this skill whenever the user wants to customise CodeScene rule weights, disable specific smells, adjust metric thresholds, scope rules to test vs application code, apply language-specific overrides, or add in-source `@codescene` directives. Also trigger when the user asks why a CodeScene rule is firing, or wants to suppress a smell across a repo or folder subtree.
Install this agent skill to your Project
npx add-skill https://github.com/leynos/agent-helper-scripts/tree/main/skills/codescene-health-rules
SKILL.md
CodeScene Code Health Rules
CodeScene evaluates 25+ code health factors and aggregates them into a 1–10 score. You control that behaviour via two mechanisms:
.codescene/code-health-rules.json— repo-scoped (or global) overrides for rule weights and low-level thresholds.@codescenesource directives — per-function suppression as inline comments.
Workflow
When the user asks to generate or modify code-health-rules.json:
- Clarify scope — which files/paths need different rules? (test vs src, a specific language, a legacy subdirectory?)
- Clarify intent per rule — disable entirely (
0.0), down-weight (0.1–0.9), or tighten/loosen a raw threshold? - Emit only the overrides — omit rules the user wants kept at defaults; this is how CodeScene itself recommends it and it reduces config drift.
- Place the file at
.codescene/code-health-rules.jsonin the repo root and commit it alongside application code.
JSON Schema
{
"usage": "optional human note — ignored by CodeScene",
"rule_sets": [
{
// Required. Glob relative to repo root. Examples:
// "**" → all files
// "test/**" → top-level test directory
// "**/*.js" → all JavaScript files
// "src/legacy/**" → specific subtree
"matching_content_path": "<glob>",
// Optional — a prose note for humans, ignored by CodeScene.
"matching_content_path_doc": "Why this rule set exists",
// Zero or more rule weight overrides.
// Omit rules you want at their defaults.
"rules": [
{
"name": "<exact rule name>", // See references/rules-catalogue.md
"weight": 0.5 // 0.0 = disabled, 0.1–0.9 = partial, 1.0 = default
}
],
// Zero or more low-level threshold overrides.
// Only needed for granular control inside compound rules.
"thresholds": [
{
"name": "<threshold key>", // See references/thresholds.md
"value": 10
}
]
}
]
}
Multiple rule_sets are allowed in one file — each matching a different glob.
Precedence
local .codescene/code-health-rules.json
↳ global rules repo (configured in Project > Hotspots)
↳ CodeScene built-in defaults
A local repo file always wins. When updating global rules, trigger a full analysis before delta analyses pick up the changes.
Weight Semantics
weight |
Effect |
|---|---|
1.0 |
Default impact (no need to specify) |
0.5 |
Rule still fires; contributes at 50% of default severity |
0.1 |
Near-invisible; useful for "track but don't fail PR gates" |
0.0 |
Rule disabled: excluded from score, virtual review, and PR gates |
Do not disable the critical rules — see references/rules-catalogue.md for
which rules are advisory vs critical. Disabling a critical rule means you lose early
warning on the findings most correlated with defect density.
Common Patterns
Test code leniency
{
"rule_sets": [
{
"matching_content_path": "test/**",
"rules": [
{ "name": "Large Method", "weight": 0.0 },
{ "name": "Large Assertion Blocks", "weight": 0.0 },
{ "name": "Duplicated Assertion Blocks","weight": 0.0 },
{ "name": "Brain Method", "weight": 0.5 }
],
"thresholds": [
{ "name": "function_cyclomatic_complexity_warning", "value": 15 }
]
}
]
}
Language-specific overrides
{
"rule_sets": [
{
"matching_content_path": "**/*.js",
"matching_content_path_doc": "JS files — allow some Primitive Obsession given dynamic typing",
"rules": [
{ "name": "Primitive Obsession", "weight": 0.3 }
]
}
]
}
Multi-scope config (src + test + legacy)
{
"rule_sets": [
{
"matching_content_path": "**",
"rules": [
{ "name": "Developer Congestion", "weight": 0.5 }
]
},
{
"matching_content_path": "test/**",
"rules": [
{ "name": "Large Assertion Blocks", "weight": 0.0 },
{ "name": "Duplicated Assertion Blocks", "weight": 0.0 }
]
},
{
"matching_content_path": "src/legacy/**",
"matching_content_path_doc": "Legacy module — tracked but not gated",
"rules": [
{ "name": "Brain Class", "weight": 0.3 },
{ "name": "Low Cohesion", "weight": 0.3 }
]
}
]
}
In-Source @codescene Directives
For per-function suppression where a JSON config would be too broad:
// @codescene(disable:"Complex Method")
void parse_protocol_frame(Frame* f) { … }
// @codescene(disable:"Complex Method", disable:"Bumpy Road Ahead")
void execute(ProgramOptions* options) { … }
// @codescene(disable-all) Scheduled refactor — 2025-Q3
void legacy_dispatch(Event* e) { … }
Rules for directives:
- Applies to the function immediately following the comment.
- Works for function-level smells only — cannot suppress module-level issues (Lines of Code, Low Cohesion, Brain Class, etc.).
- The smell name must exactly match what the virtual code review shows. Note
that "Bumpy Road" appears as
"Bumpy Road Ahead"in directive context. - CodeScene surfaces all active directives in the PR review summary. Nothing flies under the radar.
- Always include a rationale and a date so future maintainers can reassess.
Reference Files
references/rules-catalogue.md— All named rules with category, criticality, and recommended handlingreferences/thresholds.md— Known threshold keys with descriptions and typical override values
Didn't find tool you were looking for?