GitHub Action
Changelog Parser
v1.0.2
Latest version
A GitHub action that parses
CHANGELOG.md
written in Keep a Changelog format.
path
(optional) - Path to the changelog file.- By default action will look for a changelog is standard locations (
changelog.md
,CHANGELOG.md
, ...).
- By default action will look for a changelog is standard locations (
version
(optional) - Version of the changelog entry to parse.- By default the last released version is used. If changelog has no released versions, action will return an empty entry (no error raised).
- When version is defined but not available in the changelog then an error is raised.
version
- Version from the changelog entry. Example:2.1.0
.versionMajor
- Major version part. Example:2
for version2.1.0
.versionMinor
- Minor version part. Example:1
for version2.1.0
.versionPatch
- Patch version part. Example:0
for version2.1.0
.date
- Release date from the changelog entry. Example:2020-08-22
.status
- Status from the changelog entry. One of: (prerelease
,release
,unreleased
).description
- Content from the changelog entry found.
Typical README.md
file:
# Changelog
Some description
## [Unreleased]
### Added
- Another important feature
## [0.2.0] - 2020-11-10
### Added
- Important feature
## [0.1.1] - 2020-10-10
### Changed
- Fixed small bug
## [0.1.0] - 2020-09-10
### Added
- Initialized project
[Unreleased]: https://github.com/coditory/changelog-parser-action/compare/v0.2.0...HEAD
[0.2.0]: https://github.com/coditory/changelog-parser-action/compare/v0.1.1...v0.2.0
[0.1.1]: https://github.com/coditory/changelog-parser-action/compare/v0.1.0...v0.1.1
[0.1.0]: https://github.com/coditory/changelog-parser-action/releases/tag/v0.1.0
Action executed with no inputs
version: "0.2.0"
versionMajor: "0"
versionMinor: "2"
versionPatch: "0"
date: "2020-11-10"
status: "release"
description: "### Added\n- Important feature"
Action executed with input version: 0.1.1
version: "0.1.1"
versionMajor: "0"
versionMinor: "1"
versionPatch: "1"
date: "2020-10-10"
status: "release"
description: "### Changed\n- Fixed small bug"
Release steps are triggered when:
- it's a master branch
- changelog has different latest version then last published tag matching
v*
This is just a sample action that uses java with gradle.
name: Build
on: [ push ]
jobs:
build:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v2
- name: Set up JDK 11
uses: actions/setup-java@v1
with:
java-version: 11
- name: Build with Gradle
run: ./gradlew build
- name: Get last version from tag
id: lasttag
shell: bash
run: echo ::set-output name=version::$(git describe --abbrev=0 --tags --match 'v[0-9]*' | cut -c2-)
- name: Parse Changelog Entry
id: changelog
uses: coditory/changelog-parser@v1
- name: Release
if: "github.ref == 'refs/heads/master' && steps.changelog.outputs.version != steps.lasttag.outputs.version"
env:
RELEASE_VERSION: ${{ steps.changelog.outputs.version }}
run: ./gradlew release
- name: GitHub Release
if: "github.ref == 'refs/heads/master' && steps.changelog.outputs.version != steps.lasttag.outputs.version"
uses: actions/create-release@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
body: ${{ steps.changelog.outputs.description }}
tag_name: ${{ steps.changelog.outputs.version }}
release_name: Release ${{ steps.changelog.outputs.version }}
This action simply creates a GitHub Release on a newly pushed tag matching v*
.
name: Create Release
on:
push:
tags:
- v*
jobs:
build:
name: Create Release
runs-on: ubuntu-latest
steps:
- name: Get version from tag
id: lasttag
run: echo ::set-output name=version::${GITHUB_REF#refs/tags/v}
shell: bash
- name: Checkout code
uses: actions/checkout@v2
- name: Parse Changelog Entry
id: changelog
uses: coditory/changelog-parser@v1
with:
version: version: ${{ steps.lasttag.outputs.version }}
- name: Create GitHub Release
id: create_release
uses: actions/create-release@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
tag_name: ${{ steps.changelog.outputs.version }}
release_name: Release ${{ steps.changelog.outputs.version }}
body: ${{ steps.changelog.outputs.description }}