-
Notifications
You must be signed in to change notification settings - Fork 1k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Automate to prepare release note with next version (#711)
To create release notes, the following steps are necessary, but currently, they cannot be enforced: 1. Decide on a title. 2. Create a version following semver. 3. Revise the automatically generated release notes. This change automates the creation of a draft release, forcing the release creator to complete steps 1 and 2. The version is automatically determined with a `v` prefix by simply choosing from major/minor/patch. The title will be a combination of steps 1 and 2. About 3, drafted note shows actor name, so I believe almost all of us can realize we need to revise note.(but I know it's not perfect) ### When we run the workflow When the workflow is executed, a draft like the following will be created. ![スクリーンショット 2024-11-25 15 55 00](https://github.com/user-attachments/assets/adf62705-55da-4096-a8ac-2bb4bb158fc8) By revising this and making a release, it will result in the same as usual. ![スクリーンショット 2024-11-25 15 55 20](https://github.com/user-attachments/assets/1ba38c80-5bdc-4627-8957-a8e9a32ae3ec)
- Loading branch information
Showing
1 changed file
with
117 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,117 @@ | ||
name: Create Draft Release with Auto-Generated Notes | ||
|
||
on: | ||
workflow_dispatch: | ||
inputs: | ||
version_type: | ||
description: "Select the version type to increment (major, minor, patch)" | ||
required: true | ||
type: choice | ||
options: | ||
- patch | ||
- minor | ||
- major | ||
release_title: | ||
description: "Enter the title of the release" | ||
required: true | ||
type: string | ||
acknowledge_draft: | ||
description: "I understand that I must re-edit and finalize the draft release (Y/N)" | ||
required: true | ||
type: choice | ||
options: | ||
- "No" | ||
- "Yes" | ||
|
||
jobs: | ||
validate-input: | ||
runs-on: ubuntu-latest | ||
steps: | ||
- name: Validate Acknowledgement | ||
if: ${{ github.event.inputs.acknowledge_draft != 'Yes' }} | ||
run: | | ||
echo "You must select 'Yes' to acknowledge your responsibility for finalizing the draft release." | ||
exit 1 | ||
- name: Validate title (no empty) | ||
if: ${{ github.event.inputs.release_title == '' }} | ||
run: | | ||
echo "You must enter a title for the release." | ||
exit 1 | ||
create-draft-release: | ||
runs-on: ubuntu-latest | ||
needs: validate-input | ||
|
||
steps: | ||
- uses: actions/checkout@v4 | ||
- name: Fetch Latest Release | ||
id: get-latest-release | ||
uses: actions/github-script@v6 | ||
with: | ||
script: | | ||
const latestRelease = await github.rest.repos.getLatestRelease({ | ||
owner: context.repo.owner, | ||
repo: context.repo.repo, | ||
}).catch(() => null); | ||
if (latestRelease) { | ||
core.setOutput('latest_tag', latestRelease.data.tag_name); | ||
} else { | ||
core.setOutput('latest_tag', 'v0.0.0'); // Default for first release | ||
} | ||
- name: Calculate New Version | ||
id: calculate-version | ||
uses: actions/github-script@v6 | ||
with: | ||
script: | | ||
const latestTag = '${{ steps.get-latest-release.outputs.latest_tag }}'; | ||
const versionType = '${{ github.event.inputs.version_type }}'; | ||
const [major, minor, patch] = latestTag.replace('v', '').split('.').map(Number); | ||
let newVersion; | ||
if (versionType === 'major') { | ||
newVersion = `v${major + 1}.0.0`; | ||
} else if (versionType === 'minor') { | ||
newVersion = `v${major}.${minor + 1}.0`; | ||
} else { | ||
newVersion = `v${major}.${minor}.${patch + 1}`; | ||
} | ||
core.setOutput('new_version', newVersion); | ||
- name: Generate Release Notes | ||
id: generate-release-notes | ||
uses: actions/github-script@v6 | ||
with: | ||
script: | | ||
const { data: releaseNotes } = await github.rest.repos.generateReleaseNotes({ | ||
owner: context.repo.owner, | ||
repo: context.repo.repo, | ||
tag_name: "${{ steps.calculate-version.outputs.new_version }}" | ||
}); | ||
const actor = context.actor; | ||
const noteToAdd = `**@${actor} 👈 TODO: Write detailed release note for this version before release**\n`; | ||
const footer = `---\nThis release is prepared by @${actor}`; | ||
const modifiedBody = releaseNotes.body.replace( | ||
'## What\'s Changed', | ||
`## What's Changed\n\n${noteToAdd}` | ||
) | ||
.concat(`\n\n${footer}`); | ||
console.log(`releaseNotes (modified): ${JSON.stringify(modifiedBody, null, 2)}`); | ||
core.setOutput("release_body", modifiedBody); | ||
- name: Create Draft Release | ||
run: | | ||
gh release create "${{ steps.calculate-version.outputs.new_version }}" \ | ||
--title "${{ steps.calculate-version.outputs.new_version }} ${{ github.event.inputs.release_title }}" \ | ||
--notes "${{ steps.generate-release-notes.outputs.release_body }}" \ | ||
--draft \ | ||
--repo "${{ github.repository }}" | ||
env: | ||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} |