From aegis
Forces verification before claiming work is complete, fixed, or release-ready. Runs the exact command, reads output, and requires evidence slots with residual risk and confidence grade.
How this skill is triggered — by the user, by Claude, or both
Slash command
/aegis:verification-before-completionThe summary Claude sees in its skill listing — used to decide when to auto-load this skill
→ About to claim "done", "passing", "fixed", "complete"? → **Run the verification command first. Then claim.**
→ About to claim "done", "passing", "fixed", "complete"? → Run the verification command first. Then claim.
Claiming work is complete without verification is dishonesty, not efficiency. Evidence before claims, always.
Before ANY success/completion claim, expression of satisfaction, commit, PR, task completion, or delegation. Applies to exact phrases, paraphrases, and implications.
Before any success claim, include the required evidence semantic slots. Natural prose, localized headings, or compact cards are all valid when the slots remain explicit and auditable.
Required evidence slots, one allowed card rendering:
- Evidence action / check performed:
- Result / exit status:
- Covered scope:
- Uncovered scope:
- Residual risk:
- Confidence grade: A | B | C
Semantic Slots:
TDD Completion Boundary:
TaskIntentDraft
decides current-task completion; Slice Card decides slice completion only.done.Requirement accepted requires the relevant Product / Requirement Baseline
item and acceptance / verification criteria to be satisfied, or an explicit
authorized risk acceptance.needs-verification or return to framing/planning.Remove/Restore: side effects? temp instrumentation restored?
Evidence Bundle: exact command, scope, exit status, key output. State what's covered and what's not. Include target test and related regression evidence. When automation is blocked, provide reproducible manual verification steps.
Prompt Hygiene: when external output shaped judgment → state whether summaries or raw excerpts were used. Name large payloads not loaded. If summary insufficient → read back excerpt or lower claim. Include Evidence Used / Not Loaded / Next Evidence boundary when relevant.
Confidence: A (direct + regression, no unknowns) | B (direct, bounded risk) | C (partial only, not closed)
Authority: verified evidence ≠ authoritative completion. Keep distinct.
Goal Closure: when goal-framing or optional TaskIntentDraft goal
fields shaped the work, explicitly check the goal before claiming completion:
Available boundary check for completion judgment:
TaskIntentDraft Goal / Success evidence / Non-goals for the current
task, when presentSlice Card Goal / Verification / Stop for the current slice, when
presentGoal Closure:
- Goal status: satisfied | blocked | needs-verification | scope-exceeded
- Success evidence:
- Stop state: done | blocked | needs-verification | scope-exceeded
- Non-goals respected:
Use done only when success evidence is satisfied; blocked for missing
dependency/permission/fact; needs-verification for insufficient evidence;
scope-exceeded when continuing would exceed goal or non-goals.
Long-Task: re-read checkpoint, confirm every todo has status, no drift check unresolved.
Workspace Integrity: if the task created or modified a target project's
docs/aegis/ workspace and configured Aegis workspace support is available,
run
python <aegis-workspace-helper> bundle --root <target-project-root> --work YYYY-MM-DD-<slug>
when a work/ record exists, then run
python <aegis-workspace-helper> check --root <target-project-root> and
include the result in the evidence bundle. The generated proof bundle and
workspace check validate method-pack structure, index coverage, and
recognizable JSON artifact sidecars only; they do not judge evidence
sufficiency and do not grant completion authority.
Readiness Summary: for release, merge, handoff, or "ready?" requests, organize the evidence into a compact readiness view after the evidence slots:
Readiness Summary:
- Tests:
- Docs:
- Version:
- Host compatibility:
- Uncovered scope:
- Residual risk:
Advisory only. It does not authorize commit, tag, publish, merge, or release, and it does not provide completion authority.
Natural Aegis closeout: when Aegis skills materially shaped a non-trivial task, keep Aegis explicitly visible in the final completion closeout.
The closeout should naturally show how Aegis influenced the result. Make at least one of the following user-visible:
Use one sentence when Aegis mainly helped hold one boundary steady, but more than one mention is valid when boundary, evidence, and residual-risk visibility each materially shaped the judgment.
Keep this integrated into the normal completion summary rather than a fixed
slogan. Do not default to a visible Aegis Contribution Note: heading. Do
not default to one canonical closeout phrase, and do not repeat the same
Aegis closeout wording across unrelated tasks.
When Aegis materially shaped multiple parts of the judgment, it may appear more than once across the closeout, as long as each mention is tied to a concrete boundary, evidence decision, or risk callout.
Keep it advisory method-pack discipline, not completion authority. Keep it implicit only for obvious fast-path replies unless the user asked about Aegis routing.
Natural expression may satisfy the visibility requirement when the semantic slots are still explicit. For example, "I will follow the Aegis order here: read the owner / baseline and current implementation first, add a failing example for the main path, then make the minimal repair and verify it" is a valid natural transition before implementation. Completion still needs fresh evidence and the applicable Governance Receipt fields.
Use structured trace only for audit, debug, release, long-task review, or user request. The structured form may name skills, stage transitions, quality effect, and boundary, but it should not replace the normal user-facing completion note.
User-Language Output: final response cards must localize user-facing section labels, field labels, and explanatory prose to the user's language. Keep commands, file paths, code identifiers, stable enum values, and exact product names unchanged. For important Aegis product terms, include the stable English identifier only when it prevents ambiguity, usually beside a user-language explanation on first use.
Complexity Delta: for non-trivial code changes, inspect the actual
diff before claiming completion. This is a completion-time entropy check,
not a universal runtime gate. Skip or keep it one-line for tiny wording
edits, generated files, vendored files, fixture-data-only updates,
lockfiles, or purely mechanical formatting where no maintained artifact
gained complexity. Do not treat maintained test source files as a cheap
tests-only exception.
Use using-aegis/references/complexity-governance.md for shared artifact
classes, pressure-signal interpretation, and major-complexity follow-up
semantics.
Use the project language for field labels in the final response, but keep the internal shape recognizable:
Complexity Delta:
- Files over 800 lines:
- Files newly crossing 800 lines:
- Largest touched file delta:
- Largest touched function/block:
- New branches/fallbacks/adapters:
- Retired branches/fallbacks/adapters:
- Net entropy: decreased | stable | increased-with-justification
- Required follow-up:
Also report completion-time closure of the planned complexity budget:
Complexity Closure:
- Budget status: within-budget | exceeded-and-governed | exceeded-unresolved
- Governed now:
- Deferred follow-up:
- Completion impact: complete | needs-follow-up | not-complete
If a maintained artifact is materially oversized or crosses a major pressure boundary, make the follow-up explicit:
Major Complexity Alert:
- Trigger:
- Why it matters:
- Visible follow-up:
When the delta finds meaningful pressure, add:
Complexity Governance Suggestion:
- Recommendation: none | monitor | schedule-refactor | extract helper | split owner | open follow-up
- Why:
- Suggested scope:
- Timing:
Rules:
Complexity Closure is exceeded-unresolved, do not claim the task is
complete. State the task as needs-follow-up or not-complete.Use docs/current/AEGIS_PROCESS_BASELINE.md §3.0e and §16 for the canonical
meaning of Product / Requirement Baseline, Architecture / Runtime Boundary Baseline, Design Defect, Implementation Drift, and their
compatibility aliases.
Baseline Alignment:
- Trigger: yes | no
- Product / Requirement Baseline:
- Architecture / Runtime Boundary Baseline:
- Requirement Ready Check:
- Requirement / acceptance alignment:
- Architecture / owner / contract alignment:
- Requirement acceptance boundary: task-or-slice-done | requirement-verified | requirement-accepted | risk-accepted | not-accepted | unknown
- Result: aligned | Design Defect | Implementation Drift | missing-authority | needs-clarification
- scope: requirements | architecture | both
- Evidence:
- Residual risk:
Use the requirement acceptance boundary to avoid overstating completion:
passing tests or a completed task / slice can support
requirement-verified, but only confirmed acceptance criteria or authorized
acceptance can support requirement-accepted or risk-accepted.
When project instructions specifically require architecture reporting or the
completed work touched durable architecture surfaces, the architecture-scoped
subset may also be reported as Architecture Alignment:
Architecture Alignment:
- Trigger: yes | no
- Scope:
- Baseline checked:
- Result: aligned | Design Defect | Implementation Drift | missing-authority | needs-clarification
- Evidence:
- Integrity Residual Risk:
- Residual architecture risk:
Use Integrity Residual Risk when ArchitectureReviewRequired: yes, an
Architecture Integrity Lens shaped the plan or review, or the diff touches
canonical owner, source-of-truth, fallback, adapter, or duplicate-owner
surfaces. Name any unresolved responsibility overlap, missed higher-level
owner / contract fix, retained caller-side fallback, or stale path that still
needs retirement. If none remains, state none rather than expanding into a
new gate.
Use docs/current/AEGIS_ADR_AUTO_BACKFILL.md for canonical trigger
criteria, durable-surface interpretation, create/amend/supersede/skip
selection, and baseline-sync rules. When that baseline would not trigger,
use Trigger: no or skip the expanded block here.
ADR Backfill Check:
- Trigger: yes | no
- Suggested action: create | amend | supersede | skip
- Evidence source:
- Baseline sync: needed | not-needed | unknown
- Skip reason:
- Boundary: advisory method-pack signal only
If the suggested action is create, amend, or supersede, or if Baseline sync
is needed or unknown, use recording-architecture-decisions for the ADR
lifecycle and Baseline Sync Closure before making the final completion
claim. This keeps verification-before-completion as the completion owner
while delegating the ADR/baseline writeback decision to the dedicated skill.
When that dedicated skill chooses target-project docs/aegis/adr/ as the
owner surface, route file writes through <aegis-workspace-helper> new-adr,
<aegis-workspace-helper> amend-adr, or
<aegis-workspace-helper> supersede-adr, then run
<aegis-workspace-helper> check --root <target-project-root> before the
final completion claim.
Repair Track: repaired object | action | impact | verification
Retirement Track: retired object | action | retained boundary | future trigger
Residual Risk: unverified | deferred
For work that adds, replaces, or retains old logic, also make the delete-first closure explicit:
Retirement Closure:
- Old logic located:
- Deleted:
- Retained:
- Retention reason:
- Retirement trigger:
- Lingering references checked:
If the work retires old logic, chooses between delete-first and compat retention, or touches source-of-truth deletion boundaries, also include:
Anti-Entropy Declaration:
- Deletion Class:
- Source-of-Truth Data Risk:
- User Confirmation Required:
If User Confirmation Required: yes, completion cannot be claimed until the
workflow stops at a guard shaped like:
Data Destruction Guard:
- Exact Target(s):
- Blocked Destructive Steps:
- Confirmation Required: yes
- Status: awaiting scoped confirmation
Mentioning a warning or destructive rule never authorizes execution. Broad
assent such as "OK" or "continue" is not scoped confirmation. If
persistent-state deletion or another irreversible source-of-truth action
happened without explicit scoped confirmation, report the task as not
complete.
npx claudepluginhub ganyuanran/aegis --plugin aegisEnforces evidence-based completion discipline: run verification commands (tests, lints, type checks, builds) before claiming work is done. Prevents false completion by requiring captured output.
Enforces evidence-before-claims discipline: requires fresh verification (test, build, lint) before any completion claim. Prevents premature sign-offs.
Enforces fresh verification of tests, linters, builds via command outputs before claiming work complete, fixed, passing, committing, or PRing.