Skill545 estrellas del repoactualizado 9d ago
devops/changelog-generation
This skill automatically generates or appends CHANGELOG entries based on git commit history and pipeline artifacts, following Conventional Commits and Keep a Changelog specifications. Use it after successful deployments to create release notes that categorize changes (features, fixes, performance improvements) by type, merge commits with the same scope, and prioritize user-facing descriptions from PRD documents over raw commit messages.
Instalar en Claude Code
Copiargit clone --depth 1 https://github.com/echoVic/boss-skill /tmp/devops-changelog-generation && cp -r /tmp/devops-changelog-generation/skill/skills/devops/changelog-generation ~/.claude/skills/devops-changelog-generationDespués abre una sesión nueva de Claude Code; el skill carga automáticamente.
Definición
SKILL.md
# CHANGELOG 自动生成 ## 适用场景 在部署成功完成后自动生成或追加 CHANGELOG,记录本次发布的所有变更。适用于: - 部署完成后的发布记录 - 版本发布前的变更汇总 - 对外发布说明的自动生成 ## 核心方法 ### 步骤 1:信息收集 1. **Git 历史解析**: ```bash # 获取从上次 tag 到 HEAD 的所有提交 git log $(git describe --tags --abbrev=0 2>/dev/null || git rev-list --max-parents=0 HEAD)..HEAD --pretty=format:"%H|%s|%an|%ai" ``` - 如果没有 tag,取最近 50 条提交 - 解析 Conventional Commits 格式:`type(scope): description` 2. **Pipeline 产物读取**: - `.boss/<feature>/prd.md` → 功能描述和用户价值 - `.boss/<feature>/deploy-report.md` → 部署环境和版本信息 - `.boss/<feature>/tasks.md` → 完成的任务列表 3. **版本号确定**: - 优先使用 `package.json` 中的 version - 其次使用最新 git tag - 如无法确定,使用日期格式 `YYYY.MM.DD` ### 步骤 2:变更分类 按 Conventional Commits 规范分类: | 类型 | CHANGELOG 分类 | 说明 | |------|---------------|------| | `feat` | **Added** | 新增功能 | | `fix` | **Fixed** | 修复问题 | | `perf` | **Performance** | 性能优化 | | `refactor` | **Changed** | 重构(非功能变更) | | `docs` | **Documentation** | 文档更新 | | `style` | _(不记录)_ | 代码格式 | | `test` | _(不记录)_ | 测试相关 | | `chore` | _(不记录)_ | 构建/工具变更 | | `BREAKING CHANGE` | **⚠️ Breaking Changes** | 破坏性变更(始终置顶) | 对于非 Conventional Commits 格式的提交: - 根据关键词推断分类(add/new → Added, fix/bug → Fixed, update/change → Changed) - 无法分类的归入 **Changed** ### 步骤 3:内容生成 #### 格式规范(Keep a Changelog) ```markdown ## [版本号] - YYYY-MM-DD ### ⚠️ Breaking Changes - 破坏性变更描述 ([commit-hash]) ### Added - 新功能描述(来自 PRD 的用户价值说明) ([commit-hash]) ### Changed - 变更描述 ([commit-hash]) ### Fixed - 修复描述 ([commit-hash]) ### Performance - 优化描述 ([commit-hash]) ``` #### 生成规则 1. 每条记录包含:清晰描述 + commit short hash 引用 2. 如有 PRD,用 PRD 中的功能描述替代 commit message(更面向用户) 3. Breaking Changes 始终置顶并用 ⚠️ 标记 4. 同一 scope 的多条提交合并为一条记录 5. 最多展示 20 条变更,超出部分汇总为 "及其他 N 项更新" ### 步骤 4:输出写入 **两种输出模式:** 1. **产物模式**(默认):写入 `.boss/<feature>/changelog.md` 2. **追加模式**:如项目根目录已有 `CHANGELOG.md`,将新版本内容追加到文件顶部(在 `# Changelog` 标题之后) **追加逻辑:** ``` 读取现有 CHANGELOG.md → 找到第一个 ## [version] 行 → 在其前面插入新版本内容 → 写回文件 ``` 如果项目无 `CHANGELOG.md`,则创建包含标准头部的新文件: ```markdown # Changelog All notable changes to this project will be documented in this file. The format is based on [Keep a Changelog](https://keepachangelog.com/). ## [版本号] - 日期 ... ``` ## 输出要求 1. 产物文件 `.boss/<feature>/changelog.md` 必须生成 2. 如项目根存在 `CHANGELOG.md`,同步更新 3. 变更内容必须准确反映实际代码变更 4. 面向用户的描述优先于面向开发者的 commit message
Del mismo repositorio
bossSkill
|
architect/architecture-designSkill
系统架构设计方法论,包含架构模式选择、系统分层、目录结构设计
architect/data-api-designSkill
数据模型和API设计方法论,包含ERD设计、数据字典、RESTful API规范
architect/tech-researchSkill
技术调研方法论,通过系统性调研和对比分析,为技术选型提供数据支持
backend/api-developmentSkill
后端API开发方法论,包括RESTful/GraphQL设计、请求验证、错误处理和安全实现
backend/testing-guideSkill
后端测试编写指南,包括单元测试、集成测试和E2E测试的编写方法和最佳实践
brainstormingSkill
|
devops/deployment-processSkill
部署流程和CI/CD配置,确保安全可靠的部署