Skip to content

Commit

Permalink
Merge pull request #551 from doitintl/feature/git-cliff
Browse files Browse the repository at this point in the history
feat(git-cliff): Add git-cliff
  • Loading branch information
dark0dave committed Dec 19, 2023
2 parents bc4ca3a + e15bb40 commit 177a11e
Show file tree
Hide file tree
Showing 7 changed files with 87 additions and 102 deletions.
4 changes: 2 additions & 2 deletions .github/workflows/main.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ jobs:
test:
name: test
runs-on: ubuntu-latest
container: golang:1.21-alpine3.17
container: golang:1.21-alpine3.19
steps:
- name: Install git
run: apk add --update --no-cache git
Expand All @@ -37,7 +37,7 @@ jobs:
build:
name: build
runs-on: ubuntu-latest
container: golang:1.21-alpine3.17
container: golang:1.21-alpine3.19
strategy:
matrix:
os: [linux, darwin, windows]
Expand Down
2 changes: 1 addition & 1 deletion Dockerfile
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
FROM --platform=$BUILDPLATFORM golang:1.21-alpine3.17 AS builder
FROM --platform=$BUILDPLATFORM golang:1.21-alpine3.19 AS builder
ARG GITHUB_REF GITHUB_SHA
WORKDIR /src
COPY go.mod go.sum ./
Expand Down
2 changes: 1 addition & 1 deletion Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -98,5 +98,5 @@ clean:

## Generate Changelog based on PRs
changelog:
OUTPUT_FILE=$(RELEASE_DIR)/$(CHANGELOG) ./scripts/github-changelog.sh
git cliff --latest -o $(RELEASE_DIR)/$(CHANGELOG)
.PHONY: changelog
82 changes: 82 additions & 0 deletions cliff.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,82 @@
# git-cliff ~ default configuration file
# https://git-cliff.org/docs/configuration
#
# Lines starting with "#" are comments.
# Configuration options are organized into tables and keys.
# See documentation for more information on available options.

[changelog]
# changelog header
header = """
# Changelog\n
All notable changes to this project will be documented in this file.\n
"""
# template for the changelog body
# https://tera.netlify.app/docs
body = """
{% if version %}\
## [{{ version | trim_start_matches(pat="v") }}] - {{ timestamp | date(format="%Y-%m-%d") }}
{% else %}\
## [unreleased]
{% endif %}\
{% for group, commits in commits | group_by(attribute="group") %}
### {{ group | upper_first }}
{% for commit in commits %}
- {% if commit.breaking %}[**breaking**] {% endif %}{{ commit.message | upper_first }}\
{% endfor %}
{% endfor %}\n
"""
# remove the leading and trailing whitespace from the template
trim = true
# changelog footer
footer = """
<!-- generated by git-cliff -->
"""
# postprocessors
postprocessors = [
# { pattern = '<REPO>', replace = "https://github.com/orhun/git-cliff" }, # replace repository URL
]
[git]
# parse the commits based on https://www.conventionalcommits.org
conventional_commits = true
# filter out the commits that are not conventional
filter_unconventional = true
# process each line of a commit as an individual commit
split_commits = false
# regex for preprocessing the commit messages
commit_preprocessors = [
# { pattern = '\((\w+\s)?#([0-9]+)\)', replace = "([#${2}](<REPO>/issues/${2}))"}, # replace issue numbers
]
# regex for parsing and grouping commits
commit_parsers = [
{ message = "^feat", group = "Features" },
{ message = "^fix", group = "Bug Fixes" },
{ message = "^doc", group = "Documentation" },
{ message = "^perf", group = "Performance" },
{ message = "^refactor", group = "Refactor" },
{ message = "^style", group = "Styling" },
{ message = "^test", group = "Testing" },
{ message = "^chore\\(release\\): prepare for", skip = true },
{ message = "^chore\\(deps\\)", skip = true },
{ message = "^chore\\(pr\\)", skip = true },
{ message = "^chore\\(pull\\)", skip = true },
{ message = "^chore|ci", group = "Miscellaneous Tasks" },
{ body = ".*security", group = "Security" },
{ message = "^revert", group = "Revert" },
]
# protect breaking changes from being skipped due to matching a skipping commit_parser
protect_breaking_commits = false
# filter out the commits that are not matched by commit parsers
filter_commits = false
# glob pattern for matching git tags
tag_pattern = "v[0-9]*"
# regex for skipping tags
skip_tags = "v0.1.0-beta.1"
# regex for ignoring tags
ignore_tags = ""
# sort the tags topologically
topo_order = false
# sort the commits inside sections by oldest/newest order
sort_commits = "oldest"
# limit the number of commits included in the changelog.
# limit_commits = 42
6 changes: 1 addition & 5 deletions scripts/alpine-setup.sh
Original file line number Diff line number Diff line change
Expand Up @@ -5,20 +5,16 @@ set -eou pipefail
LC_CTYPE=C

OPA_VERSION="0.22.0"
CHANGELOG_VERSION="1.1.0"

apk add --update --no-cache \
bash \
curl \
git \
git-cliff \
jq \
make \
tar \
xz

wget -q -O "/usr/local/bin/opa" "https://github.com/open-policy-agent/opa/releases/download/v${OPA_VERSION}/opa_linux_amd64"
chmod +x "/usr/local/bin/opa"

wget -q "https://github.com/paultyng/changelog-gen/releases/download/v${CHANGELOG_VERSION}/changelog-gen_Linux_x86_64.tar.gz" -O - | tar -xz
chmod +x changelog-gen
mv changelog-gen /usr/local/bin/changelog-gen
72 changes: 0 additions & 72 deletions scripts/changelog.tmpl

This file was deleted.

21 changes: 0 additions & 21 deletions scripts/github-changelog.sh

This file was deleted.

0 comments on commit 177a11e

Please sign in to comment.