Agent skill
review-story-alignment
Adversarial review of generated stories against the Discovery Session Brief, referenced DECs, and Epic DoR. Detects contradictions, omissions, and intent drift BEFORE stories reach Delivery. Produces a structured verdict (PASS/FAIL) with specific findings per story. Triggers after generate-stories, before backlog registration as refined.
Install this agent skill to your Project
npx add-skill https://github.com/Fr-e-d/GAAI-framework/tree/main/.gaai/core/skills/discovery/review-story-alignment
Metadata
Additional technical details for this skill
- id
- SKILL-RSA-001
- tags
-
review alignment session-brief quality-gate adversarial discovery
- track
- discovery
- author
- gaai-framework
- status
- stable
- version
- 1.0
- category
- discovery
- updated at
- 1774137600
SKILL.md
Review Story Alignment (SKILL-RSA-001)
Purpose
Stories generated by Discovery may contradict, omit, or drift from what was discussed during the human ↔ agent conversation. This skill acts as an adversarial reviewer — a separate agent that checks stories against the Discovery Session Brief BEFORE they reach Delivery.
This skill does NOT check format (that is validate-artefacts). It checks alignment — does the story faithfully represent what was decided, observed, and agreed during the Discovery session?
When to Activate
- After
generate-storieshas produced story files - After
validate-artefactshas PASSED (format is already correct) - Before stories are registered in the backlog as
refined - Always — for every story creation or modification, regardless of batch size, origin, or whether a Session Brief exists
Do NOT activate:
- For stories that are already
refinedordone(unless being modified)
Reduced-Scope Mode (no Session Brief)
When no Discovery Session Brief is provided, the gate runs in reduced-scope mode:
- Pass A (Session Brief contradictions): SKIPPED — produce "SKIPPED — no Session Brief provided" in the verdict. No findings generated for this pass.
- Pass B (DEC constraint check): RUNS NORMALLY — DECs are always available from story frontmatter
related_decs. - Pass C (DoR check): RUNS NORMALLY — Epic
mandatory_ac_categoriesis always available.
Reduced-scope mode ensures that DEC cross-referencing and DoR enforcement are never bypassed, even for single-story amendments or bug-triage stories created outside a full Discovery session.
Architecture — Isolated Reviewer
This skill is executed by the Review Sub-Agent (SUB-AGENT-REVIEW-001) during Tier 2 review. The Review Sub-Agent already runs in an isolated context window with an adversarial prompt — this skill defines the 3-pass process it follows for story alignment specifically.
If invoked standalone (outside the Review Sub-Agent context), this skill MUST still run as a sub-agent in an isolated context window (via the Agent tool). The reviewer must NOT be the same agent instance that wrote the stories.
Why isolation matters: The author of the stories has confirmation bias — it wrote the stories believing they were correct. A separate agent with fresh context is more likely to detect contradictions.
The reviewer receives ONLY:
- The Discovery Session Brief (full 7-category block)
- The story files to review
- The parent Epic (for DoR categories)
- The referenced DEC files (full content, not just IDs)
The reviewer does NOT receive:
- The conversation history
- The codebase
- Other stories from other Epics
- Project memory beyond the referenced DECs
Invocation Template
The Discovery Agent MUST invoke the reviewer using this prompt structure (via the Agent tool):
You are an adversarial story reviewer. Your job is to find contradictions,
omissions, and drift — not to confirm correctness. Assume stories contain
errors until proven otherwise.
DISCOVERY SESSION BRIEF (human-validated):
══════════════════════════════════════════
{paste the full structured Brief with D-N, O-N, H-N, T-N, S-N, C-N, Q-N items}
EPIC (for DoR categories):
{paste Epic frontmatter including mandatory_ac_categories}
STORIES TO REVIEW:
{paste each story file content}
REFERENCED DECs:
{paste full content of each DEC listed in related_decs}
Execute the review-story-alignment process: 3 passes per story
(Session Brief contradictions, DEC constraints, DoR coverage).
For each finding, reference the Brief item by ID (e.g., "contradicts D-1")
and the story element by AC number (e.g., "AC3 in {story_id}").
Produce a structured verdict per story.
If a Session Brief exists, it MUST be included verbatim in the prompt — with all item IDs (D-N, O-N, etc.). The Brief is the source of truth for Pass A.
If no Session Brief exists (single-story amendment, bug-triage, DEC amendment): replace the Brief block with DISCOVERY SESSION BRIEF: NONE — reduced-scope mode (Passes B+C only). The reviewer skips Pass A and produces "SKIPPED — no Session Brief provided" in the verdict. Passes B and C run normally.
Process
Step 1 — Load Review Context
Load all inputs:
- Read the Discovery Session Brief
- Read each story file
- Read the parent Epic (extract
mandatory_ac_categories) - For each story's
related_decs, read the full DEC file
Step 2 — Per-Story Alignment Check (3 passes)
For EACH story, run three passes:
Pass A: Session Brief Contradiction Check
Compare every item in the Session Brief against every AC and Context section in the story.
For each Session Brief item, ask:
- "Does any AC in this story CONTRADICT this item?"
- "Does the story's Context section CONTRADICT this item?"
- "Does the story's User Story (As a / I want / so that) CONTRADICT this item?"
Contradiction = any statement in the story that implies the OPPOSITE of a Session Brief item.
Examples:
- Brief: "Dashboard = admin-first" → Story: "end-user-facing dashboard" → CONTRADICTION
- Brief: "EN only for V1" → Story has zero i18n ACs → OMISSION (not contradiction, caught in Pass C)
- Brief: "Pro tier = experiment" → Story treats Pro as guaranteed pillar → DRIFT
Classification:
CONTRADICTION— story says the opposite of the brief (severity: CRITICAL)DRIFT— story subtly reinterprets the brief (severity: HIGH)UNRELATED— story doesn't touch this brief item (severity: NONE — acceptable)
Pass B: DEC Constraint Check
For each DEC in the story's related_decs:
- Read the DEC's decision statement
- Check: does any AC in the story violate the DEC's constraint?
- Check: should additional ACs exist to enforce the DEC?
Also perform a DEC coverage scan:
- Read the story's keywords (from title, User Story, ACs)
- Scan ALL DEC titles provided
- Flag any DEC that SHOULD be referenced but ISN'T in
related_decs
Classification:
DEC_VIOLATION— AC contradicts a referenced DEC (severity: CRITICAL)DEC_MISSING— a relevant DEC is not cross-referenced (severity: HIGH)DEC_PARTIAL— DEC is referenced but not all constraints are reflected in ACs (severity: MEDIUM)
Pass C: Definition of Ready (DoR) Check
Read the Epic's mandatory_ac_categories. For each category:
- Does the story have at least one AC that explicitly addresses this category?
- "Explicitly" means the AC mentions the category's concern — not that a related word appears somewhere
Classification:
DOR_MISSING— mandatory AC category has zero coverage (severity: HIGH)DOR_WEAK— category is mentioned but AC is vague or untestable (severity: MEDIUM)
Step 3 — Produce Verdict
For each story, produce a structured verdict:
## Review: {story_id}
**Verdict: PASS | FAIL**
### Findings
| # | Type | Severity | Brief Item | Story Element | Finding |
|---|------|----------|-----------|---------------|---------|
| 1 | CONTRADICTION | CRITICAL | **D-1** (Dashboard = admin-first) | AC1 | Story says "end-user-facing" — contradicts D-1 |
| 2 | DEC_MISSING | HIGH | **C-1** (DEC-5: EN only) | related_decs | DEC-5 should be referenced — story has URL routing implications |
| 3 | DOR_MISSING | HIGH | DoR: `error-handling` | No AC | No AC addresses error handling |
| 4 | DRIFT | HIGH | **Q-2** (actionable errors) | AC5 | AC says "return error code" — Q-2 requires actionable guidance, not just codes |
### Refinement Guidance
For each FAIL finding, state:
- What needs to change in the story
- Whether the Discovery Agent has enough information (from the Session Brief) to make the fix autonomously
- If NOT enough information → what question to ask the human
Step 4 — Aggregate Verdict
## Batch Review Summary
Stories reviewed: N
PASS: X
FAIL: Y
Critical findings: Z (must be resolved before any story reaches backlog)
Reviewer Stance
The reviewer is adversarial by design. Its instruction set:
"You are a reviewer, not a validator. Your job is to find problems, not confirm correctness. Assume the stories contain errors until proven otherwise. For every Session Brief item, actively look for the contradiction — don't look for confirmation. When in doubt, it's a FAIL, not a PASS. A false positive (flagging something that's actually fine) costs 5 minutes to dismiss. A false negative (missing a real problem) costs hours of wrong implementation."
Calibration: The reviewer should err on the side of strictness. 1-2 false positives per batch is acceptable. Zero false negatives is the target.
Quality Checks
- Every Session Brief item was checked against every story (no items skipped)
- Every referenced DEC was read in full (not just the title)
- DoR categories from Epic were verified per story
- Each finding includes a specific reference (Brief item # or DEC ID or category name)
- Each FAIL finding includes refinement guidance (what to change + info sufficiency)
- Verdict is binary per story (PASS or FAIL — no "conditional pass")
- Reviewer did not modify any story file (review only, no edits)
Non-Goals
- Does not check format — that is validate-artefacts (SKILL-VALIDATE-ARTEFACTS-001)
- Does not refine stories — it produces findings; the Discovery Agent decides how to act
- Does not replace human judgment — Discovery escalates to the human when it lacks information to resolve a finding, but a PASS verdict is sufficient for stories to enter the backlog as
refined - Does not check implementation feasibility — that is Delivery's Planning Sub-Agent
- Does not skip when no Session Brief exists — runs in reduced-scope mode (Passes B+C only). DEC and DoR checks are always valuable.
Recommended Agent Skills
Expand your agent's capabilities with these related and highly-rated skills.
ci-watch-and-fix
Watch GitHub Actions CI after PR creation, detect failures, extract logs, apply minimal fixes, and re-push — keeping the delivery session alive until CI resolves or escalating after 3 cycles. Activate immediately after gh pr create and before marking the story done.
qa-review
Validate that implemented code fully satisfies Story acceptance criteria, respects rules, and introduces no regressions. This is the hard quality gate — no pass means no delivery. Activate after implementation is complete.
compose-team
Assemble the context bundles for each sub-agent based on evaluate-story output. Produces spawn-ready packages for Planning, Implementation, QA, or MicroDelivery sub-agents. Activate after evaluate-story, before spawning any sub-agent.
coordinate-handoffs
Validate sub-agent handoff artefacts, sequence phase transitions, and manage retry and escalation logic. Activate after each sub-agent terminates to determine next action.
implement
Generate correct, minimal, maintainable code that satisfies a validated Story's acceptance criteria against an execution plan. Activate when a Story is validated, a plan exists, and all prerequisites are unambiguous.
delivery-high-level-plan
Transform validated Stories into a clear, minimal, governed execution plan. Used by the Planning Sub-Agent as the first planning pass before prepare-execution-plan for Tier 2/3, or as the sole planning output for simple Stories.
Didn't find tool you were looking for?