Generates release checklists from components with readiness analysis and blocker detection
npm install @tpmjs/tools-release-checklistGenerates comprehensive release checklists from component information with readiness tracking and blocker detection.
``bash`
npm install @tpmjs/tools-release-checklist
`typescript
import { releaseChecklistTool } from '@tpmjs/tools-release-checklist';
const result = await releaseChecklistTool.execute({
components: [
{
name: 'UserService',
hasTests: true,
hasDocs: true,
version: '2.1.0'
},
{
name: 'AuthModule',
hasTests: false,
hasDocs: true,
version: '1.5.0'
},
{
name: 'PaymentAPI',
hasTests: true,
hasDocs: false,
version: 'invalid'
}
]
});
console.log(result.checklist);
// # Release Checklist
//
// ## Testing
//
// ### UserService
// - [x] 🔴 Unit tests passing
// - [ ] 🟡 Integration tests passing
// ...
console.log(result.blockers);
// [
// 'AuthModule: Missing tests (critical)',
// 'PaymentAPI: Missing documentation (high priority)',
// 'PaymentAPI: Version invalid follows semver (critical)'
// ]
console.log(result.summary);
// {
// totalComponents: 3,
// componentsReady: 1,
// componentsBlocked: 1,
// readinessPercentage: 33,
// criticalItems: 24,
// incompleteItems: 28
// }
`
- Markdown Checklist: Generates formatted markdown checklist with checkboxes and priority indicators
- Readiness Tracking: Calculates percentage of components ready for release
- Blocker Detection: Identifies critical issues preventing release
- Priority Levels: Categorizes items by critical, high, medium, and low priority
- Category Organization: Groups checklist items by testing, documentation, versioning, quality, and deployment
- Semver Validation: Validates version numbers follow semantic versioning
`typescript`
{
components: Array<{
name: string; // Component name
hasTests: boolean; // Whether component has tests
hasDocs: boolean; // Whether component has documentation
version: string; // Semantic version (e.g., "1.0.0")
}>
}
`typescript`
{
checklist: string; // Markdown-formatted checklist
items: Array<{
component: string; // Component name or "Release"
item: string; // Checklist item description
status: 'complete' | 'incomplete' | 'blocked';
priority: 'critical' | 'high' | 'medium' | 'low';
category: 'testing' | 'documentation' | 'versioning' | 'quality' | 'deployment';
}>;
readyCount: number; // Number of components ready for release
blockers: string[]; // List of release blockers
summary: {
totalComponents: number;
componentsReady: number;
componentsBlocked: number;
readinessPercentage: number;
criticalItems: number;
incompleteItems: number;
};
}
The tool generates items across five categories:
- 🔴 Critical: Must be completed before release
- 🟡 High: Should be completed before release
- 🔵 Medium: Nice to have
- ⚪ Low: Optional
A component is considered "ready" when:
- ✅ Has tests (hasTests: true)hasDocs: true
- ✅ Has documentation ()1.2.3
- ✅ Version follows semver format (e.g., )
`typescript
const result = await releaseChecklistTool.execute({
components: [
{ name: 'CoreAPI', hasTests: true, hasDocs: true, version: '3.0.0' },
{ name: 'UIKit', hasTests: true, hasDocs: true, version: '3.0.0' }
]
});
// result.summary.readinessPercentage === 100
// result.readyCount === 2
`
`typescript
const result = await releaseChecklistTool.execute({
components: [
{ name: 'BetaFeature', hasTests: false, hasDocs: false, version: 'v1' }
]
});
// result.blockers includes:
// - "BetaFeature: Missing tests (critical)"
// - "BetaFeature: Missing documentation (high priority)"
// - "BetaFeature: Version v1 follows semver (critical)"
`
`typescript
const components = [
{ name: 'Module1', hasTests: true, hasDocs: true, version: '2.0.0' },
{ name: 'Module2', hasTests: true, hasDocs: true, version: '2.0.0' },
// ... 10 more modules
];
const result = await releaseChecklistTool.execute({ components });
// Generates comprehensive checklist with:
// - 100+ checklist items
// - Organized by category and component
// - Clear blocker identification
``
- Pre-Release Planning: Assess release readiness before starting
- Release Progress Tracking: Monitor completion of release tasks
- Quality Gate Enforcement: Ensure all critical items are complete
- Team Coordination: Share checklist with stakeholders
- Post-Mortem Analysis: Review what was missed in previous releases
MIT