Agent skill
release-notes
Structured release notes creation that translates technical changes into user-benefit-oriented communication.
Install this agent skill to your Project
npx add-skill https://github.com/borghei/Claude-Skills/tree/main/project-management/execution/release-notes
Metadata
Additional technical details for this skill
- author
- borghei
- domain
- pm-execution
- updated
- 1772582400
- version
- 1.0.0
- category
- project-management
- tech stack
- release-management, changelog, semantic-versioning
- python tools
-
[ "scripts/release_notes_generator.py" ]
SKILL.md
Release Notes Expert
Overview
Transform raw technical changes -- tickets, changelogs, git logs, PRDs -- into clear, user-benefit-oriented release notes. This skill ensures every release communicates value to the right audience in the right tone.
When to Use
- Product Releases -- Announcing new versions to customers, partners, or internal stakeholders.
- Sprint Demos -- Summarizing what shipped for sprint review audiences.
- Changelog Maintenance -- Keeping a running log of changes across releases.
- Customer Communication -- Preparing release announcements for email, in-app, or documentation.
Methodology
Step 1: Gather Raw Input
Collect all changes from the release cycle:
- Jira/Linear tickets -- Completed stories, bugs, and tasks
- Git log -- Merge commits since last release tag
- PRD references -- Feature specs that shipped
- Hotfix records -- Emergency fixes deployed between releases
Step 2: Classify Each Change
Assign every change to exactly one category:
| Category | Definition | Example |
|---|---|---|
| New Features | Net-new capabilities that did not exist before | New export-to-PDF option |
| Improvements | Enhancements to existing functionality | Faster dashboard loading |
| Bug Fixes | Corrections to broken or incorrect behavior | Fixed login redirect loop |
| Breaking Changes | Changes that require user action to adapt | API v2 replaces v1 endpoints |
| Deprecations | Features scheduled for future removal | Legacy CSV import will be removed in v4.0 |
Classification rules:
- If a change adds something entirely new, it is a New Feature.
- If it makes something existing better (faster, easier, more reliable), it is an Improvement.
- If it fixes something that was wrong, it is a Bug Fix.
- If users must change their behavior, configuration, or integration, it is a Breaking Change.
- If a feature still works but will be removed later, it is a Deprecation.
Step 3: Rewrite for User Benefit
The most critical step. Every entry must lead with the benefit to the user, not the technical change.
Rewriting principles:
- Lead with the outcome. What can the user do now that they could not before, or what is better for them?
- Use plain language. Avoid internal jargon, code references, or implementation details.
- Keep it to 1-3 sentences. One sentence for minor items, up to three for significant features.
- Include context when needed. If users need to take action, tell them exactly what to do.
Before and after examples:
| Technical (Bad) | User-Benefit (Good) |
|---|---|
| Implemented Redis caching layer for dashboard queries | Dashboards now load up to 3x faster |
| Refactored authentication module to use OAuth 2.0 PKCE flow | Sign-in is now more secure and works reliably across all browsers |
| Fixed null pointer exception in report export handler | Report exports no longer fail when date ranges include empty days |
| Migrated user preferences API from v1 to v2 schema | Action required: Update your API calls to use the new /v2/preferences endpoint by April 30. See migration guide. |
| Added feature flag for beta dashboard | You can now opt into the redesigned dashboard from Settings > Beta Features |
Red flags that an entry needs rewriting:
- Mentions a class name, function, or library
- Starts with "Refactored," "Migrated," or "Updated" without stating impact
- Uses acronyms the target audience would not know
- Describes what the team did instead of what the user gains
Step 4: Adjust Tone for Audience
| Audience | Tone | Style Notes |
|---|---|---|
| B2B / Enterprise | Professional, precise | Emphasize reliability, security, compliance. Avoid casual language. |
| Consumer | Friendly, conversational | Use "you" and "your." Celebrate new features. Keep it light. |
| Developer / API | Technical, direct | Include endpoint names, SDK versions, code snippets. Be specific. |
| Internal | Detailed, context-rich | Include ticket IDs, team names, technical details as needed. |
Step 5: Assemble the Release Notes
Use the output template below. Include only categories that have entries -- do not show empty sections.
Output Template
# [Product Name] v[X.Y.Z] Release Notes
**Release Date:** [YYYY-MM-DD]
---
## New Features
- **[Feature Name]** -- [1-3 sentence description of user benefit]. ([TICKET-ID])
## Improvements
- **[Improvement Name]** -- [1-2 sentence description of what is better]. ([TICKET-ID])
## Bug Fixes
- **[Bug Fix Name]** -- [1 sentence describing what was broken and that it is now fixed]. ([TICKET-ID])
## Breaking Changes
> **Action Required:** The following changes require updates on your end.
- **[Change Name]** -- [Description of what changed and exactly what the user must do]. ([TICKET-ID])
## Deprecations
> **Planned Removal:** The following features will be removed in a future release.
- **[Feature Name]** -- [What is being deprecated and when it will be removed. Recommend alternative if available]. ([TICKET-ID])
---
**Full changelog:** [link]
**Questions?** [support link or contact]
Python Tool
Use scripts/release_notes_generator.py to generate formatted release notes from structured input.
# Generate from JSON input
python scripts/release_notes_generator.py --input changes.json --product-name "Acme App" --version "2.5.0"
# Run with demo data
python scripts/release_notes_generator.py --demo --product-name "Acme App" --version "1.0.0"
# Output as JSON instead of markdown
python scripts/release_notes_generator.py --input changes.json --format json --product-name "Acme App" --version "2.5.0"
See scripts/release_notes_generator.py --help for full usage.
Integration with Other Skills
- Use
summarize-meeting/to capture release planning discussions. - Use
job-stories/orwwas/to trace features back to their original motivation. - Pair with
../senior-pm/for stakeholder communication planning around major releases.
Troubleshooting
| Symptom | Likely Cause | Resolution |
|---|---|---|
| Tool flags too many entries as "technical language" | TECHNICAL_PATTERNS regex is broad, catching common words like "update" or "add" | Review the flagged entries; the tool provides suggestions, not mandates -- ignore false positives for user-facing descriptions |
| All entries classified as same type | Input JSON uses wrong type values or inconsistent casing | Use exact lowercase types: feature, improvement, bugfix, breaking, deprecation |
| Empty sections appear in output | No entries of that type exist but template still renders the section | The tool only renders sections with entries; empty sections indicate a data issue in input |
| Breaking changes not highlighted prominently | Entries marked as improvement instead of breaking |
Review classification rules: if users must change behavior, config, or integration, it is breaking, not improvement |
| Release notes sound like commit messages | Descriptions written from developer perspective, not user perspective | Apply the rewriting principles: lead with outcome, use plain language, 1-3 sentences per entry |
--demo flag requires --product-name and --version |
These are required arguments regardless of input source | Always provide both: --demo --product-name "App" --version "1.0.0" |
| JSON output missing rewriting suggestions | No entries triggered technical language detection patterns | This is expected behavior; suggestions only appear when TECHNICAL_PATTERNS match entry descriptions |
Success Criteria
- Every release has structured notes published within 24 hours of deployment
- All entries lead with user benefit, not technical implementation details
- Breaking changes include explicit migration instructions with deadlines
- Deprecations include removal timeline and recommended alternatives
- Technical language flags reviewed and addressed before publication
- Release notes tone matches the target audience (B2B/consumer/developer/internal)
- Entries traceable to tickets via ticket_id for audit and context
Scope & Limitations
In Scope:
- Structured release note generation from JSON input with 5 entry categories
- Automatic technical language detection with rewriting suggestions
- Markdown and JSON output formatting with category grouping
- Audience tone guidance (B2B, consumer, developer, internal)
- Classification rules for New Features, Improvements, Bug Fixes, Breaking Changes, and Deprecations
Out of Scope:
- Automatic extraction of changes from git history (see
sprint-retrospective/for git analysis) - Jira/Linear ticket integration for pulling completed stories (manual JSON input required)
- Changelog maintenance across multiple releases (this tool generates per-release notes)
- Distribution to email, in-app, or documentation channels (output is markdown/JSON for further processing)
Important Caveats:
- The rewriting suggestions are pattern-based heuristics. They catch common technical language but cannot assess whether a description truly communicates user benefit.
- Semantic versioning alignment is the user's responsibility. The tool does not validate that version numbers follow semver conventions relative to the change types present.
- Breaking changes require special care. Always include: what changed, what the user must do, and by when. Vague breaking change notes erode user trust.
Integration Points
| Integration | Direction | Description |
|---|---|---|
sprint-retrospective/ |
Receives from | Sprint commit data and type distribution inform what changes to include |
senior-pm/ |
Complements | Stakeholder communication plans guide release note audience and tone |
execution/create-prd/ |
Receives from | PRD feature descriptions (Section 7) become release note entry drafts |
scrum-master/ |
Receives from | Sprint review outputs identify what shipped and needs documentation |
summarize-meeting/ |
Receives from | Release planning meeting summaries capture context for release notes |
job-stories/ / wwas/ |
Receives from | User story descriptions inform user-benefit framing of entries |
Tool Reference
release_notes_generator.py
Generates formatted release notes from structured JSON input. Groups entries by category, formats into markdown or JSON, and flags entries that may need user-benefit rewriting.
| Flag | Type | Default | Description |
|---|---|---|---|
--input |
string | (optional) | Path to JSON file containing release entries |
--demo |
flag | off | Run with built-in demo data (8 entries across all types) |
--product-name |
string | (required) | Product name for the release notes header |
--version |
string | (required) | Version string (e.g., 2.5.0) |
--format |
choice | text |
Output format: text (markdown) or json |
--date |
string | today | Release date in YYYY-MM-DD format |
Input JSON schema:
{
"entries": [
{
"title": "Feature Name",
"description": "User-benefit description (1-3 sentences)",
"type": "feature|improvement|bugfix|breaking|deprecation",
"ticket_id": "PROJ-123 (optional)"
}
]
}
References
- See
references/release-notes-guide.mdfor best practices, audience guidance, and examples. - See
assets/release_notes_template.mdfor a ready-to-use document template.
Recommended Agent Skills
Expand your agent's capabilities with these related and highly-rated skills.
churn-prevention
SaaS churn reduction covering cancel flow design, dynamic save offers, exit survey architecture, dunning sequences, payment recovery, win-back campaigns, and churn impact modeling.
popup-cro
Popup and modal optimization for conversion. Covers exit-intent, slide-ins, banners, timing optimization, frequency capping, audience targeting, compliance, and A/B testing frameworks for lead capture, promotions, and announcements.
competitor-alternatives
Competitor comparison and alternative page creation for SEO and sales enablement. Covers 4 page formats (singular alternative, plural alternatives, vs pages, competitor vs competitor), content architecture, research methodology, and centralized competitor data management.
contract-and-proposal-writer
Generate production-ready business documents including freelance contracts, project proposals, SOWs, NDAs, and MSAs with jurisdiction-aware clauses. Covers US (Delaware), EU (GDPR), UK, and DACH (German law) legal frameworks. Includes contract templates, clause libraries, and DOCX conversion. Use when starting client engagements, writing proposals, drafting partnership agreements, or needing GDPR-compliant data processing addenda.
pricing-strategy
SaaS pricing design and optimization covering value metric selection, tier architecture, price point research, pricing page design, price increase execution, and competitive pricing analysis.
referral-program
Referral and affiliate program design covering referral loop architecture, incentive design, trigger moment optimization, viral coefficient modeling, affiliate program structure, and optimization playbook.
Didn't find tool you were looking for?