4.3 KiB
go-semantic-release
Release Types
| Type | Implemendet | Git tag | Changelog | Release | Write access git | Api token |
|---|---|---|---|---|---|---|
github |
✅ | ✅ | ✅ | ✅ | ✅ | |
gitlab |
✅ | ✅ | ✅ | ✅ | ✅ | |
git |
Comming soon | ✅ | ✅ | |||
bitbuckt |
Comming soon | ✅ | ✅ |
Supported CI Pipelines
- Github Actions
- Gitlab CI
- Travis CI
- Custom CI, set enviroment
CI=true
How to use
go-semantic-release config file
Create a file with the name .release.yml or anything else, but you need to set to every command -c <your config file>
Example config
commitFormat: angular
branch:
master: release
release: 'github'
github:
repo: "go-semantic-release"
user: "nightapes"
assets:
- name: ./build/go-semantic-release
compress: false
- name: ./build/go-semantic-release.exe
compress: false
CommitFormat
Set the commit format, at the moment we support ony angular, more coming soon.
commitFormat: angular
Branch
You can define which kind of release should be created for different branches.
Supported release kinds:
release->v1.0.0rc->v1.0.0-rc.0beta->v1.0.0-beta.0alpha->v1.0.0-alpha.0
Add a branch config to your config
branch:
<branch-name>: <kind>
Relase
At the moment we support releases to gitlab and github.
Github
You need to set the env GITHUB_TOKEN with an access token.
release: 'github'
github:
user: "<user/group"
repo: "<repositroyname>"
## Optional, if your not using github.com
customUrl: <https://your.github>
Gitlab
You need to set the env GITLAB_ACCESS_TOKEN with an personal access token.
release: 'gitlab'
gitlab:
repo: "<repositroyname>" ## Example group/project
## Optional, if your not using gitlab.com
customUrl: <https://your.gitlab>
Assets
You can upload assets to a release
Support for gitlab and github. If you want, you can let the file be compressed before uploading
assets:
- name: ./build/go-semantic-release
compress: false
Changelog
Following variables can be used for templates:
CommitsstringVersionstringNowtime.TimeBacktickstringHasDockerboolHasDockerLatestboolDockerRepositorystring
changelog:
printAll: false ## Print all valid commits to changelog
title: "v{{.Version}} ({{.Now.Format "2006-01-02"}})" ## Used for releases (go template)
templatePath: "./examples/changelog.tmpl" ## Path to a template file (go template)
Docker
You can print a help text for a docker image
changelog:
docker:
latest: false ## If you uploaded a latest image
repository: ## Your docker repository, which is used for docker run
Version
go-semantic-release has two modes for calcualting the version: automatic or manual.
Automatic
Version will be calculated on the next or release command
Manual
If you don't want that go-semantic-release is calculating the version from the commits, you can set the version by hand with
following command:
./go-semantic-release set 1.1.1
Print version
Print the next version, can be used to add version to your program
./go-semantic-release next
Example with go-lang
go build -ldflags "--X main.version=`./go-semantic-release next`"
Create release
./go-semantic-release release
Build from source
go build ./cmd/go-semantic-release/
Testing
go test ./...
Linting
curl -sfL https://install.goreleaser.com/github.com/golangci/golangci-lint.sh | sh -s -- -b $(go env GOPATH)/bin v1.16.0
golangci-lint run ./...