src/autoskillit/skills_extended/validate-audit/SKILL.md
Validate audit findings from audit-arch, audit-tests, audit-cohesion, audit-feature-gates, audit-docs, or audit-review-decisions against actual code, git history, and design intent using 9–10 parallel subagents. Removes contested findings, documents exceptions, adjusts severities. Use when user says "validate audit", "validate findings", "validate report", or "check audit results".
npx skillsauth add talont-org/autoskillit validate-auditInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Validate audit findings from audit-arch, audit-tests, audit-cohesion,
audit-feature-gates, audit-docs, or audit-review-decisions against actual code, git history, and design
intent using 9–10 parallel subagents. Contested findings are separated into their own file. The
validated report carries a validated: true marker to signal downstream processing.
audit-arch, audit-tests, audit-cohesion, audit-feature-gates, audit-docs, or audit-review-decisions to filter noise before acting{audit_report_path}
audit_report_path — absolute path to an audit report produced by audit-arch,
audit-tests, audit-cohesion, audit-feature-gates, audit-docs, or audit-review-decisions. If
omitted, use the most recent file under {{AUTOSKILLIT_TEMP}}/audit-arch/,
{{AUTOSKILLIT_TEMP}}/audit-tests/, {{AUTOSKILLIT_TEMP}}/audit-cohesion/,
{{AUTOSKILLIT_TEMP}}/audit-feature-gates/, {{AUTOSKILLIT_TEMP}}/audit-docs/,
or {{AUTOSKILLIT_TEMP}}/audit-review-decisions/
(most recent mtime wins across all six).
If no files exist under any of these directories, print an error message and exit
with a non-zero status.
AUTOSKILLIT_AUDIT_RUN_DIR — optional environment variable. When set, all output
files are written directly under $AUTOSKILLIT_AUDIT_RUN_DIR/ instead of
{{AUTOSKILLIT_TEMP}}/validate-audit/. The recipe sets this to the per-run
directory created by init_audit_run (which already includes the
validate-audit/run-{stamp}-{hex} path segments) to prevent cross-run file
accumulation.
NEVER:
$AUDIT_BASE_DIR/ (the per-run directory set in Step 5)run_in_background: true is prohibited)ALWAYS:
model: "sonnet" when spawning all subagents via the Task toolvalidated: true as the first line of the validated report filevalidated_report_path = <absolute path to the validated report file>| Verdict | Meaning | Action | |---------|---------|--------| | VALID | Finding confirmed by code evidence | Include as-is in validated report | | VALID BUT EXCEPTION WARRANTED | Real issue; documented constraint applies | Include with exception note | | CONTESTED | Factually wrong or counterproductive | Exclude from report; write to contested file |
Read the audit report file. Detect its source by examining the document title or preamble:
audit-arch: Title contains "Architectural Audit" or findings reference "Principle P{N}"
audit-tests: Title contains "Test Suite Audit" or findings reference issue categories
audit-cohesion: Title contains "Cohesion Audit" or findings reference "Dimension C{N}"
audit-feature-gates: Title contains "Feature Gate Audit" or findings reference BLOCK/WARN/INFO severity badges. Normalize severities: BLOCK→HIGH, WARN→MEDIUM, INFO→LOW. Use the normalized severity in the Validation Status table and severity adjustments.
| feature-gates severity | Normalized severity | |----------------------|-------------------| | BLOCK | HIGH | | WARN | MEDIUM | | INFO | LOW |
Verdict rules by finding type:
file:line — confirm the
unguarded import, missing gate, or unguarded tool handler actually exists.audit-review-decisions: Title contains "Review Decisions Audit" or "PR Review Decisions Audit".
Source = review_decisions. Findings carry PR provenance metadata: PR number, review thread
link, verbatim reviewer comment, deferral signal phrase, and optionally REVIEW-FLAG tag metadata
(severity, dimension). These fields are additional to the standard severity + file:line + category.
Verdict rules for review_decisions findings:
file:line still exists in the current codebase and the concern
is still applicable — the exact code pattern persists unchanged.audit-docs: Title contains "Documentation Audit".
Source = docs. Findings describe documentation drift, staleness, or inconsistency against the
codebase. Apply standard VALID / CONTESTED / VALID BUT EXCEPTION WARRANTED verdicts.
If none of the six patterns match, print:
"Error: unrecognized audit report format — expected title 'Architectural Audit', 'Test Suite Audit', 'Cohesion Audit', 'Feature Gate Audit', 'Documentation Audit', or 'Review Decisions Audit'. Aborting."
and exit with a non-zero status.
For each finding, extract:
file:line references, if presentFor review_decisions findings, also extract:
These additional fields must be preserved through validation and into ticket body files so that the PR provenance is traceable in the resulting GitHub issues.
Collect all findings into a flat list. Record the source audit skill (arch, tests,
cohesion, feature_gates, docs, or review_decisions) for use in output filenames.
Cluster findings by code area: inspect file:line references in each finding and group
by the top-level package touched (e.g., pipeline/, execution/, server/, core/,
recipe/, cli/, workspace/).
Feature-gates table-format findings (D1 and D5): The Config Projection (D1) and Boundary Coupling (D5) dimensions produce inventory/coupling tables rather than single-finding lines. For these dimensions:
_type_constants.py for
FEATURE_REGISTRY entries, config/defaults.yaml for config projection values).Issue ALL Task calls in a single message.
Spawn the following agents simultaneously using model: "sonnet":
Code Validation Agents (8–9 agents)
Each agent receives its assigned finding batch and these instructions:
You are validating audit findings against the actual codebase. For each finding in your batch:
- Read the source code at the referenced
file:linelocation using Glob/Grep/Read.- Check recent git history:
git log -10 --oneline -- {file}.- Evaluate whether the finding accurately describes the code as it currently exists.
- Assign a verdict: VALID, VALID BUT EXCEPTION WARRANTED, or CONTESTED.
- If CONTESTED: provide specific code evidence that refutes the finding.
- If VALID BUT EXCEPTION WARRANTED: describe the constraint that warrants an exception.
- If severity should be adjusted, state the new severity and rationale. Do NOT modify any files. Return structured text only — no files created.
History Research Agent (1 agent)
Receives ALL findings. Instructions:
You are researching historical context for audit findings. For each finding:
- Search git log for commits touching the referenced files in the last 90 days.
- Check for open or recently-closed GitHub issues or PRs related to the code area:
gh issue list --state all --search "{keyword from finding}".- If a finding references a known in-progress fix or tracked issue, note it. Do NOT create any files. Return structured text only.
Subagent output format — code validation agents:
## Batch {N} Verdicts
### [{ID}] {short finding description}
- **Verdict**: VALID | VALID BUT EXCEPTION WARRANTED | CONTESTED
- **Code evidence**: {file:line + what the code actually shows}
- **Rationale**: {why this verdict}
- **Severity adjustment**: {new severity and reason} (omit if unchanged)
- **Exception note**: {constraint that warrants the exception} (EXCEPTION only)
Subagent output format — history research agent:
## Historical Context
### [{ID}] {short finding description}
- **Recent commits**: {commit hashes + summaries, or "none in last 90 days"}
- **Related issues/PRs**: {numbers and titles, or "none found"}
- **Context note**: {how history affects the verdict, or "no impact"}
After all agents return:
N_valid, N_exception, N_contested.Set the output base directory. When AUTOSKILLIT_AUDIT_RUN_DIR is set (by the
recipe's init_audit_run step), files are written to the per-run directory to
prevent cross-run accumulation:
if [ -n "$AUTOSKILLIT_AUDIT_RUN_DIR" ]; then
AUDIT_BASE_DIR="$AUTOSKILLIT_AUDIT_RUN_DIR"
else
AUDIT_BASE_DIR="{{AUTOSKILLIT_TEMP}}/validate-audit-$(date -u +%Y-%m-%d_%H%M%S)"
fi
mkdir -p "$AUDIT_BASE_DIR"
File 1 — Validated report
Path: $AUDIT_BASE_DIR/validated_report_{source}.md
Structure:
validated: true
# Validated Audit Report — {source} ({YYYY-MM-DD})
**Original report:** {audit_report_path}
**Findings processed:** {total} | **Valid:** {N_valid} | **Exception warranted:** {N_exception} | **Contested:** {N_contested}
---
## Validation Status
| Finding | Original Severity | Verdict | Adjusted Severity |
|---------|------------------|---------|------------------|
| ... | ... | ... | ... |
---
## Validated Findings
{Each **VALID** finding only — do NOT include VALID BUT EXCEPTION WARRANTED findings here.
Exception-warranted findings go exclusively in the validation summary file.
Format: original finding text, VALID verdict badge, severity adjustment note if applicable.}
---
*{N_contested} finding(s) contested and excluded — see contested_findings_{source}.md*
File 2 — Contested findings (write only when N_contested > 0)
Path: $AUDIT_BASE_DIR/contested_findings_{source}.md
Structure:
# Contested Findings — {source} ({YYYY-MM-DD})
{For each CONTESTED finding:}
## [{ID}] {short description}
**Original severity:** {severity}
**Contest rationale:** {why it is factually wrong or counterproductive}
**Code evidence:** {specific file:line + what the code actually shows}
**Historical context:** {from history agent, if relevant; else omit}
Write the full audit trail to a separate file. This file is NOT part of the issue body — it is posted as a comment after issue creation.
Path: $AUDIT_BASE_DIR/validation_summary_{source}.md
Structure:
# Validation Summary — {source} ({YYYY-MM-DD})
**Original report:** {audit_report_path}
**Total findings:** {total} | **Valid:** {N_valid} | **Exception warranted:** {N_exception} | **Contested:** {N_contested}
---
## Per-Finding Verdicts
| Finding ID | Verdict | Severity (adj.) | Reasoning summary |
|------------|---------|-----------------|-------------------|
| ... | ... | ... | ... |
---
## Exception-Warranted Findings
{For each VALID BUT EXCEPTION WARRANTED finding:}
### [{ID}] {short description}
**Original severity:** {severity}
**Exception note:** {constraint that warrants exception}
**Code evidence:** {file:line + what code shows}
**Historical context:** {from history agent, if relevant; else omit}
---
## Contested Findings (Removed)
{For each CONTESTED finding: full text, contest rationale, code evidence.}
---
## Severity Adjustments
{For each finding where severity was adjusted: original → adjusted, rationale.}
After both the validated report and validation summary are written, launch two read-only subagents in a single message. Neither subagent may use Write, Edit, or any file-creation tool — they return findings as response text only.
Subagent A — Cross-Validator
Receives paths to three files:
{audit_report_path})validated_report_{source}_{ts}.md)validation_summary_{source}_{ts}.md)Instructions:
You are cross-validating three audit artifacts for consistency. Read all three files. Check:
- No accidental deletions — every finding in the validated report traces to a finding in the original
- No accidental survivors — every CONTESTED finding in the summary is absent from the validated report
- No exception-warranted leakage — no VALID BUT EXCEPTION WARRANTED finding appears in the validated report's
## Validated Findingssection- Structural integrity — valid markdown, Summary Table counts match actual finding count, finding IDs sequential, no orphaned references
- Count reconciliation — N_valid + N_exception + N_contested equals original total; consistent between summary and validated report Return a structured discrepancy report. If no issues found, return "CROSS-VALIDATION PASSED". Do NOT create any files. Return structured text only.
Output format:
## Cross-Validation Report
Status: PASSED | DISCREPANCIES FOUND
### Discrepancy [{N}]: {type}
- **Finding ID**: {id}
- **Issue**: {what is wrong}
- **Expected**: {what should be there}
- **Actual**: {what is there}
Subagent B — Ticket Grouper
Receives the validated report path.
Instructions:
You are analyzing validated audit findings to propose ticket groupings. Read the validated report. For each finding, assess scope: lines of code affected, complexity, criticality, file overlap. Grouping rules:
- Standalone ticket: finding is large in scope (many files/lines), complex refactor, or touches a critical path
- Grouped ticket: finding is small, low-risk, non-conflicting. Group same-category small findings together.
- Conflict awareness: findings touching the same file(s) must be in the same ticket or explicitly sequenced
- No rigid severity-to-grouping rule: a HIGH can be grouped if small; a LOW can be standalone if complex
Return a grouping manifest listing each proposed ticket with:
- Ticket title (descriptive, scoped)
- Finding IDs included (e.g., P1-F09, P1-F11, P3-F18)
- Rationale for grouping or standalone
- Estimated scope: small / medium / large
- File overlap notes (which findings touch the same files) Do NOT create any files. Return structured text only.
Output format:
## Grouping Manifest
### Ticket Group 1: {title}
- **Finding IDs**: {id1}, {id2}, ...
- **Rationale**: {why grouped or standalone}
- **Scope**: small | medium | large
- **File overlap**: {files touched by multiple findings in this group, or "none"}
### Ticket Group 2: {title}
...
After both parallel subagents return:
From Cross-Validator:
CROSS-VALIDATION PASSED: proceed directly to Step 8..tmp file first, then
atomically move it over the original (to prevent partial-write corruption), and note the
correction applied. Limit to at most 3 correction passes; after 3 passes, record any
remaining discrepancies and continue to Step 8.From Ticket Grouper:
Before writing any ticket body files, verify $AUTOSKILLIT_TEMP is non-empty
(test -n "${AUTOSKILLIT_TEMP}"); abort with an error message if unset to prevent
path collapse to filesystem root.
For each ticket group in the grouping manifest:
validated: true sentinel on line 1# {ticket title} (from grouping manifest)## Validated Findings sub-sections for included finding IDs*Part of validated {source} audit — see full report for remaining tickets.*$AUDIT_BASE_DIR/ticket_body_{source}_{N}.md
where {N} is 1-indexed from the grouping manifest.Also write the grouping manifest itself to:
$AUDIT_BASE_DIR/grouping_manifest_{source}.md
The grouping manifest file is the structured text returned by the ticket grouper subagent, prefixed with:
# Ticket Grouping Manifest — {source} ({YYYY-MM-DD})
**Validated report:** {validated_report_path}
**Total groups:** {N}
---
Detect headless mode: run echo "${AUTOSKILLIT_HEADLESS:-0}" via Bash. Output 1 means
headless.
Headless mode: Write all output files immediately without prompting. Print to terminal:
[validate-audit] Done.
Valid: {N_valid} | Exceptions: {N_exception} | Contested: {N_contested}
Summary: {validation_summary_path}
Manifest: {grouping_manifest_path}
Tickets: {ticket_body_1_path}
{ticket_body_2_path} (one line per ticket group)
Contested: {contested_findings_path} (omit if N_contested == 0)
Report: {validated_report_path}
validated_report_path = {validated_report_path}
verdict = validated
Interactive mode: Display the validation status table (verdict counts), then ask:
Write validated report and contested findings files? [Y/n]
On Y or empty input, write all files. After writing, offer:
Run
/autoskillit:prepare-issuefor each ticket group? [Y/n]
On Y, call prepare-issue for each ticket body file (in parallel). After issue creation,
append the validation summary to each created issue body using gh issue edit --body-file:
fetch the current issue body, verify the fetched body is non-empty (abort the append for
that issue if empty to avoid overwriting with summary-only content), append a horizontal
rule and the validation summary content, write the combined text to a temp file, then run
gh issue edit {issue_number} --body-file with that temp file. Do NOT use gh issue comment.
All output files are written under $AUDIT_BASE_DIR/ where AUDIT_BASE_DIR is determined as follows:
AUTOSKILLIT_AUDIT_RUN_DIR is set (by the recipe's init_audit_run step): $AUDIT_BASE_DIR = $AUTOSKILLIT_AUDIT_RUN_DIR$AUDIT_BASE_DIR = {{AUTOSKILLIT_TEMP}}/validate-audit-$(date -u +%Y-%m-%d_%H%M%S):$AUDIT_BASE_DIR/
├── validated_report_{source}.md (always written; VALID findings only)
├── contested_findings_{source}.md (when N_contested > 0)
├── validation_summary_{source}.md (always written; audit trail)
├── grouping_manifest_{source}.md (always written; ticket grouping)
└── ticket_body_{source}_{N}.md (one per ticket group, N ≥ 1)
{source} is arch, tests, cohesion, feature_gates, docs, or review_decisions based on the input report.
/autoskillit:audit-arch — produces reports this skill validates/autoskillit:audit-tests — produces reports this skill validates/autoskillit:audit-cohesion — produces reports this skill validates/autoskillit:audit-feature-gates — produces reports this skill validates/autoskillit:audit-docs — produces reports this skill validates/autoskillit:audit-review-decisions — produces reports this skill validates/autoskillit:prepare-issue — offered interactively for contested findingsdevelopment
Generate YAML recipes for .autoskillit/recipes/. Use when user says "make script skill", "generate script", "script a workflow", "write a script", "create a script", "new recipe", "write a pipeline", or when loaded by other skills for script formatting.
data-ai
Create Uncertainty Representation visualization planning spec showing error bar definitions, distribution-aware alternatives, and multi-seed variance protocols. Statistical lens answering "How is uncertainty honestly represented?"
data-ai
Create Temporal Dynamics visualization planning spec showing axis scaling (linear vs log), smoothing disclosure, epoch/step alignment, run aggregation (mean + variance bands), early-stopping markers, and wall-clock vs step-count x-axis. Temporal lens answering "Are training dynamics shown clearly and honestly?"
data-ai
Create Narrative Story Arc visualization planning spec showing visual consistency across the report (same color = same model everywhere), logical figure progression, redundant figure detection, and narrative dependency between figures. Narrative lens answering "Do the figures tell a coherent story across the report?"