skills/review-backlog/SKILL.md
Use when reviewing user stories, auditing backlog quality, or checking story consistency before sprint planning. Use when docs/backlog.yaml and docs/issues/ exist and need quality validation.
npx skillsauth add razbakov/skills review-backlogInstall 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.
Parallel quality audit of all user stories in a backlog. Dispatches one sub-agent per epic to review every story file against a standard checklist, then consolidates findings into a single report with ratings, systemic issues, and prioritized fixes.
user-story skill to validate qualitydocs/backlog.yaml exists with phases and story referencesdocs/issues/*.md story files exist (one per story)estimation, story, jira), Context, User Story, Acceptance CriteriaRead docs/backlog.yaml to get:
docs/issues/)Organize stories into groups for parallel review. Each group becomes one sub-agent task. Group by phase from the backlog (not by epic from the story map) since phases represent implementation order.
Launch one sub-agent per phase using the Task tool. All agents run in parallel.
Each sub-agent receives:
After all agents return, compile:
Each sub-agent evaluates every story against these criteria:
| # | Criterion | What to check |
|---|-----------|---------------|
| 1 | Frontmatter | Has estimation, story, jira fields? Values populated? |
| 2 | Context | Is the "why" clearly explained? Grounded in user need? |
| 3 | User Story | Follows "As a [persona], I want [action], so that [benefit]"? |
| 4 | Acceptance Criteria | Concrete, testable, checkbox-ready? Enough criteria for the scope? |
| 5 | Edge Cases | Missing error states? Empty/zero-result states? Failure paths? |
| 6 | Consistency | Story number, persona, and scope match the story map? |
| 7 | Estimation | Points reasonable for the described scope? Assumptions documented? |
### File: `<filename>` (Story <id>)
**Rating: [Good | Needs improvement | Problem]**
**Issues:**
- Numbered list of specific problems
**Suggestions:**
- Concrete improvements with example wording
After all stories in the group, the sub-agent outputs:
Use this when dispatching each sub-agent:
Review the user story files for [Phase Name]. Read each file and evaluate against these criteria:
1. **Frontmatter**: Does it have `estimation`, `story`, and `jira` fields?
2. **Context**: Is the "why" clearly explained?
3. **User Story**: Follows "As a [persona], I want [action], so that [benefit]" format?
4. **Acceptance Criteria**: Are they concrete, testable, and checkbox-ready? Are there enough criteria? Are any missing edge cases?
5. **Consistency**: Does the story match what's described in the story map (story number, persona, scope)?
6. **Estimation**: Does the story point estimate seem reasonable for the scope described?
Files to review:
- [list of absolute file paths]
For each story, output:
- **File**: filename
- **Rating**: Good / Needs improvement / Problem
- **Issues**: List specific problems or missing items
- **Suggestions**: Concrete improvements
At the end, provide a summary of common patterns across this phase.
These problems recur across most backlogs. Flag them in the consolidated report:
The final consolidated report should include:
| Epic | Story | Key | Rating | |------|-------|-----|--------|
X Good, Y Need improvement, Z Problems
Numbered list of cross-cutting problems with specific examples from the stories.
Ordered by impact. Each fix should be actionable (e.g., "Add empty state criteria to every story" not "improve stories").
development
Seed a new or empty Instagram account with a 9-post grid (3×3) so the profile looks established the moment a new visitor lands. Designed for festivals, new businesses, product launches, conferences, communities — any time an empty IG profile would hurt conversion from external traffic (QR scans, flyer drops, cross-promo). Generates assets via /image-from-gemini (per content-publishing rules — never HTML), writes captions with hashtag sets, and outputs a posting order + cadence plan. Trigger generously: phrases like '9 posts for instagram', 'fill my IG', 'starter grid', 'launch grid', 'instagram seed', '9-post grid', 'IG account not to look empty', 'first instagram posts', 'feed bootstrap', '3x3 grid', 'instagram launch content'. Even if the user mentions only one piece (just the images, just the captions, just the order), use this skill — the grid only works as an integrated bundle.
testing
Translate one English blog post into multiple target languages via parallel sub-agents, preserving frontmatter conventions, hero image, and brand voice. Use when the user shares a published English post URL or markdown path and says 'translate it', 'add other languages', 'publish in DE/ES/RU/UK', 'translate to 5 languages', or asks for localized versions of a specific post.
development
Build a complete press kit for an event, product launch, or campaign — in multiple languages — and publish it as a shareable Google Drive folder ready to send to journalists, partners, or a delegate. Produces press releases (typically DE/EN/ES, or configurable), uploads press photos and flyers, creates an Overview document for at-a-glance briefing, and creates a Handover document with pending tasks, contacts, risks, and decisions so press distribution can be delegated. Use when the user says 'I need a press release', 'create a press kit', 'press release in X languages', 'set up a Drive folder for press', 'handover doc for someone else to run press', or has an upcoming announcement that needs to be sent to media. Trigger generously: even partial requests (just a press release, just a flyer folder) typically evolve into the full kit.
development
Track ticket sales for a live event (concert, festival, conference, workshop) with daily snapshots, generate a burndown chart comparing actual sales to ideal-linear targets and tier-cumulative milestones, and report whether the event is on pace. Use when the user asks how sales are going, wants to know if their event will sell out, asks for a daily sales report, wants to set up sales tracking for an upcoming event, or asks about ticket pace / velocity / projection. Trigger generously: phrases like 'how is concert sales going', 'burndown for my event', 'are we going to sell out', 'sales velocity', 'daily ticket chart', 'how many tickets do we need to sell', or any case where the user has a ticketed event with a fixed sales window and wants visibility on pacing.