diff --git a/actions/changelog-generate/README.md b/actions/changelog-generate/README.md index 0cba3ec67..477f04e56 100644 --- a/actions/changelog-generate/README.md +++ b/actions/changelog-generate/README.md @@ -1,13 +1,24 @@ # Generate Changelog -This action will enable the automated creation of a changelog. The changelog template needs to be configured using a `changelog-config.json`. +This action will enable the automated creation of a changelog. +The changelog template needs to be configured using a `changelog-config.json`. If there is a global changelog managed by the repository this will be updated. -The action generates a new release changelog and an updated version of the changelog file in the repository (if there is any). The default setting updates the repo changelog. If your current repository does not have any global changelog file, then pass an empty string to the variable `changelog-file`. +The action generates a new release changelog and an updated version of +the changelog file in the repository (if there is any). +The default setting updates the repo changelog. +If your current repository does not have any global changelog file, +then pass an empty string to the variable `changelog-file`. The action returns both the new tag's changelog and the global changelog. -When generating the changelog, the action evaluates two factors to decide which PRs to consider: `old-tag` (lower bound defining the 'start' from where the changelog will consider merged pull requests) and `new-tag` (upper bound defining until which tag the changelog will consider merged pull requests). +When generating the changelog, the action evaluates two factors to decide which PRs to consider: +`old-tag` +(lower bound defining the 'start' from where the changelog will consider merged pull requests) +and `new-tag` +(upper bound defining until which tag the changelog will consider merged pull requests). -The upper bound might be either existing or new. If the new tag does not yet exist, the action will nevertheless create the changelog so that it may be included in the release. +The upper bound might be either existing or new. +If the new tag does not yet exist, the action will +nevertheless create the changelog so that it may be included in the release. ## Dependencies @@ -17,7 +28,9 @@ This action is built from the following composite actions: ## Prerequisites -Create a file called `changelog-config.json` that contains the changelog configurations. The mentioned action's documentation goes into great detail about how to create and utilize config files. A simple configuration may look like this: +Create a file called `changelog-config.json` that contains the changelog configurations. +The mentioned action's documentation goes into great detail about how to create and utilize config +files. A simple configuration may look like this: ```json { @@ -26,33 +39,47 @@ Create a file called `changelog-config.json` that contains the changelog configu "title": "## ๐Ÿš€ Features", "labels": ["feature", "feat", "enhancement"] }, - { "title": "## ๐Ÿ› Fixes", "labels": ["fix", "bug"] }, - { "title": "## ๐Ÿงช Dependencies", "labels": ["dependency"] } + { + "title": "## ๐Ÿ› Fixes", + "labels": ["fix", "bug"] + }, + { + "title": "## ๐Ÿงช Dependencies", + "labels": ["dependency"] + }, + { + "title": "## ๐Ÿ“ฆ Uncategorized", + "labels": [] + } ], "ignore_labels": ["ignore"], "sort": { "order": "ASC", "on_property": "mergedAt" }, - "template": "# [${{TO_TAG}}](https://github.com///releases/tag/${{TO_TAG}}) - Release Date: ${{TO_TAG_DATE}}\n\n${{CHANGELOG}}\n
\nUncategorized\n\n${{UNCATEGORIZED}}\n
\n", - "pr_template": "- ${{TITLE}}\n - PR: ${{URL}}\n - Assignees: ${{ASSIGNEES[*]}}\n - Reviewers: ${{REVIEWERS[*]}}\n - Approvers: ${{APPROVERS[*]}}", + "template": "# [${{TO_TAG}}](https://github.com///releases/tag/${{TO_TAG}}) - Release Date: ${{TO_TAG_DATE}}\n\n${{CHANGELOG}}", + "pr_template": "- ${{TITLE}}\n - PR: ${{URL}}\n - Assignees: ${{ASSIGNEES}}\n - Reviewers: ${{REVIEWERS}}\n - Approvers: ${{APPROVERS}}", "empty_template": "- no changes!" } ``` -Make sure to update the link `https://github.com///releases/tag/${{TO_TAG}}` accordingly and make sure to include `- Release Date: ${{TO_TAG_DATE}}` because the action looks for this pattern to make the date format easily readable. +Make sure to update the link +`https://github.com///releases/tag/${{TO_TAG}}` +accordingly and make sure to include `- Release Date: ${{TO_TAG_DATE}}` +because the action looks for this pattern to make the date format easily readable. -Additional configuration options can be explored [here](https://github.com/mikepenz/release-changelog-builder-action#configuration-specification). +Additional configuration options can be explored +[here](https://github.com/mikepenz/release-changelog-builder-action#configuration-specification). ## Input Parameters | Name | Required | Default Value | Description | | ------------------------- | :------: | :-------------------------------: | ------------------------------------------------------------------------------------------------------------------------------------------------------------ | | github-token | โœ… | - | The GitHub token for committing the changes | -| new-tag | โœ… | - | New version | +| new-tag | โœ… | - | Defines until which tag the changelog will consider merged pull requests (can be a tag or a valid git ref) | | changelog-file | โŒ | "CHANGELOG.md" | Path to the Changelog.md file | | commit-mode | โŒ | "false" | Special configuration for projects which work without PRs. Uses commit messages as changelog. This mode looses access to information only available for PRs. | | config | โŒ | "./.github/changelog-config.json" | Path to the changelog config JSON file | | fetch-release-information | โŒ | "false" | Will enable fetching additional release information from tags. | | fetch-reviewers | โŒ | "false" | Will enable fetching the users/reviewers who approved the PR. | -| old-tag | โŒ | "" | Previous version | +| old-tag | โŒ | "" | Defines the 'start' from where the changelog will consider merged pull requests (can be a tag or a valid git ref) | ## Outputs @@ -63,7 +90,10 @@ Additional configuration options can be explored [here](https://github.com/mikep ## Calling the workflow -By default, just a single commit for the ref/SHA that started the process is retrieved. In the [checkout action](https://github.com/actions/checkout), enter `fetch-depth: 0` to retrieve all history for all branches and tags. Without it, the changelog action will be unable to track down previous tags. +By default, just a single commit for the ref/SHA that started the process is retrieved. +In the [checkout action](https://github.com/actions/checkout), enter `fetch-depth: 0` to retrieve +all history for all branches and tags. +Without it, the changelog action will be unable to track down previous tags. ```yaml steps: @@ -75,7 +105,7 @@ steps: id: build_changelog uses: bakdata/ci-templates/actions/changelog-generate@main with: - token: ${{ secrets.GH_TOKEN }} + github-token: ${{ secrets.GH_TOKEN }} config: "./.github/changelog-config.json" new-tag: "1.0.0" changelog-file: "CHANGELOG.md" diff --git a/actions/changelog-generate/action.yaml b/actions/changelog-generate/action.yaml index 89b9ff08a..937cace62 100644 --- a/actions/changelog-generate/action.yaml +++ b/actions/changelog-generate/action.yaml @@ -77,7 +77,7 @@ runs: - name: "Create changelog" id: build_changelog - uses: mikepenz/release-changelog-builder-action@v3.7.0 + uses: mikepenz/release-changelog-builder-action@v4 with: token: "${{ inputs.github-token }}" configuration: "${{ inputs.config }}"