2023-10-12 14:18:25 +00:00
# git-sv
A command line tool (CLI) to validate commit messages, bump version, create tags and generate changelogs.
2019-11-17 16:37:41 +00:00
## Getting Started
2021-04-07 23:53:04 +00:00
### Pre Requirements
- Git 2.17+
2019-11-17 16:37:41 +00:00
### Installing
2021-04-07 23:53:04 +00:00
- Download the latest release and add the binary to your path.
2023-10-12 14:18:25 +00:00
- Optional: Set `GITSV_HOME` to define user configs. Check the [Config ](#config ) topic for more information.
2019-11-17 16:37:41 +00:00
2021-08-28 17:53:14 +00:00
If you want to install from source using `go install` , just run:
```bash
2022-03-01 02:43:39 +00:00
# keep in mind that with this, it will compile from source and won't show the version on cli -h.
2023-10-12 14:18:25 +00:00
go install github.com/thegeeklab/git-sv/v2/cmd/git-sv@latest
2022-03-01 02:43:39 +00:00
# if you want to add the version on the binary, run this command instead.
2023-10-12 14:18:25 +00:00
GITSV_VERSION=$(go list -f '{{ .Version }}' -m github.com/thegeeklab/git-sv/v2@latest | sed 's/v//') & & go install --ldflags "-X main.Version=$SGITSV_VERSION" github.com/thegeeklab/git-sv/v2/cmd/git-sv@v$GITSV_VERSION
2021-08-28 17:53:14 +00:00
```
2019-12-05 00:10:16 +00:00
### Config
2022-03-01 02:43:39 +00:00
#### YAML
2023-10-12 14:18:25 +00:00
There are 3 config levels when using git-sv: [default ](#default ), [user ](#user ), [repository ](#repository ). All of them are merged considering the follow priority: **repository > user > default** .
2021-02-15 06:28:34 +00:00
2021-04-07 23:53:04 +00:00
To see the current config, run:
2021-02-15 06:28:34 +00:00
```bash
git sv cfg show
```
2022-03-01 02:43:39 +00:00
##### Configuration Types
2021-02-15 06:28:34 +00:00
2022-03-01 02:43:39 +00:00
###### Default
2021-02-15 06:28:34 +00:00
2021-04-07 23:53:04 +00:00
To check the default configuration, run:
2021-02-15 06:28:34 +00:00
```bash
git sv cfg default
```
2022-03-01 02:43:39 +00:00
###### User
2021-02-15 06:28:34 +00:00
2023-10-12 14:18:25 +00:00
For user config, it is necessary to define the `GITSV_HOME` environment variable, eg.:
2021-02-15 06:28:34 +00:00
```bash
2023-10-12 14:18:25 +00:00
GITSV_HOME=/home/myuser/.gitsv # myuser is just an example.
2021-02-15 06:28:34 +00:00
```
2021-04-07 23:53:04 +00:00
And create a `config.yml` file inside it, eg.:
2021-02-15 06:28:34 +00:00
```bash
2023-10-12 14:18:25 +00:00
.gitsv
2021-02-15 06:28:34 +00:00
└── config.yml
```
2022-03-01 02:43:39 +00:00
###### Repository
2021-02-15 06:28:34 +00:00
2023-10-12 14:18:25 +00:00
Create a `.gitsv/config.yml` file on the root of your repository, eg. [.gitsv/config.yml ](.gitsv/config.yml ).
2021-02-15 06:28:34 +00:00
2022-03-01 02:43:39 +00:00
##### Configuration format
2021-02-15 06:28:34 +00:00
```yml
2022-03-01 02:43:39 +00:00
version: "1.1" #config version
2021-02-15 06:28:34 +00:00
versioning: # versioning bump
2023-10-12 14:18:25 +00:00
update-major: [] # Commit types used to bump major.
update-minor: [feat] # Commit types used to bump minor.
update-patch: [build, ci, chore, fix, perf, refactor, test] # Commit types used to bump patch.
# When type is not present on update rules and is unknown (not mapped on commit message types);
# if ignore-unknown=false bump patch, if ignore-unknown=true do not bump version
ignore-unknown: false
2021-02-15 06:28:34 +00:00
tag:
2023-10-12 14:18:25 +00:00
pattern: "%d.%d.%d" # Pattern used to create git tag.
filter: "" # Enables you to filter for considerable tags using git pattern syntax
2021-02-15 06:28:34 +00:00
release-notes:
2023-10-12 14:18:25 +00:00
# Deprecated!!! please use 'sections' instead!
# Headers names for release notes markdown. To disable a section just remove the header
# line. It's possible to add other commit types, the release note will be created
# respecting the following order: feat, fix, refactor, perf, test, build, ci, chore, docs, style, breaking-change.
headers:
breaking-change: Breaking Changes
feat: Features
fix: Bug Fixes
sections: # Array with each section of release note. Check template section for more information.
- name: Features # Name used on section.
section-type: commits # Type of the section, supported types: commits, breaking-changes.
commit-types: [feat] # Commit types for commit section-type, one commit type cannot be in more than one section.
- name: Bug Fixes
section-type: commits
commit-types: [fix]
- name: Breaking Changes
section-type: breaking-changes
2021-02-15 06:28:34 +00:00
2021-04-07 23:53:04 +00:00
branches: # Git branches config.
2023-10-12 14:18:25 +00:00
prefix: ([a-z]+\/)? # Prefix used on branch name, it should be a regex group.
suffix: (-.*)? # Suffix used on branch name, it should be a regex group.
disable-issue: false # Set true if there is no need to recover issue id from branch name.
skip: [master, main, developer] # List of branch names ignored on commit message validation.
skip-detached: false # Set true if a detached branch should be ignored on commit message validation.
2021-02-15 06:28:34 +00:00
commit-message:
2023-10-12 14:18:25 +00:00
types: [
build,
ci,
chore,
docs,
feat,
fix,
perf,
refactor,
revert,
style,
test,
] # Supported commit types.
header-selector: "" # You can put in a regex here to select only a certain part of the commit message. Please define a regex group 'header'.
scope:
# Define supported scopes, if blank, scope will not be validated, if not, only scope listed will be valid.
# Don't forget to add "" on your list if you need to define scopes and keep it optional.
values: []
footer:
issue: # Use "issue: {}" if you wish to disable issue footer.
key: jira # Name used to define an issue on footer metadata.
key-synonyms: [Jira, JIRA] # Supported variations for footer metadata.
use-hash: false # If false, use :< space > separator. If true, use < space > # separator.
add-value-prefix: "" # Add a prefix to issue value.
issue:
regex: "[A-Z]+-[0-9]+" # Regex for issue id.
2021-02-15 06:28:34 +00:00
```
2019-12-05 00:10:16 +00:00
2022-03-01 02:43:39 +00:00
#### Templates
2023-10-12 14:18:25 +00:00
**git-sv** uses _go templates_ to format the output for `release-notes` and `changelog` , to see how the default template is configured check [template directory ](cmd/git-sv/resources/templates ). It's possible to overwrite the default configuration by adding `.gitsv/templates` on your repository. The cli expects that at least 2 files exists on your directory: `changelog-md.tpl` and `releasenotes-md.tpl` .
2022-03-01 02:43:39 +00:00
```bash
2023-10-12 14:18:25 +00:00
.gitsv
2022-03-01 02:43:39 +00:00
└── templates
├── changelog-md.tpl
└── releasenotes-md.tpl
```
2023-10-12 14:18:25 +00:00
Everything inside `.gitsv/templates` will be loaded, so it's possible to add more files to be used as needed.
2022-03-01 02:43:39 +00:00
##### Variables
2022-03-01 02:52:46 +00:00
To execute the template the `releasenotes-md.tpl` will receive a single **ReleaseNote** and `changelog-md.tpl` will receive a list of **ReleaseNote** as variables.
2022-03-01 02:43:39 +00:00
2022-03-01 02:52:46 +00:00
Each **ReleaseNoteSection** will be configured according with `release-notes.section` from config file. The order for each section will be maintained and the **SectionType** is defined according with `section-type` attribute as described on the table below.
2022-03-01 02:43:39 +00:00
2023-10-12 14:18:25 +00:00
| section-type | ReleaseNoteSection |
| ---------------- | -------------------------------- |
| commits | ReleaseNoteCommitsSection |
2022-03-01 02:43:39 +00:00
| breaking-changes | ReleaseNoteBreakingChangeSection |
2022-03-01 02:52:46 +00:00
> :warning: currently only `commits` and `breaking-changes` are supported as `section-types`, using a different value for this field will make the section to be removed from the template variables.
2022-03-01 02:43:39 +00:00
Check below the variables available:
```go
ReleaseNote
2022-03-01 02:52:46 +00:00
Release string // 'v' followed by version if present, if not tag will be used instead.
2022-03-01 02:43:39 +00:00
Tag string // Current tag, if available.
Version *Version // Version from tag or next version according with semver.
Date time.Time
Sections []ReleaseNoteSection // ReleaseNoteCommitsSection or ReleaseNoteBreakingChangeSection
AuthorNames []string // Author names recovered from commit message (user.name from git)
Version
Major int
Minor int
Patch int
Prerelease string
Metadata string
Original string
2022-03-01 02:53:56 +00:00
ReleaseNoteCommitsSection // SectionType == commits
2022-03-01 02:43:39 +00:00
SectionType string
SectionName string
Types []string
Items []GitCommitLog
HasMultipleTypes bool
2022-03-01 02:53:56 +00:00
ReleaseNoteBreakingChangeSection // SectionType == breaking-changes
2022-03-01 02:43:39 +00:00
SectionType string
SectionName string
Messages []string
GitCommitLog
Date string
Timestamp int
AuthorName string
Hash string
Message CommitMessage
CommitMessage
Type string
Scope string
Description string
Body string
IsBreakingChange bool
Metadata map[string]string
```
##### Functions
2022-03-01 02:53:56 +00:00
Beside the [go template functions ](https://pkg.go.dev/text/template#hdr-Functions ), the folowing functions are availiable to use in the templates. Check [formatter_functions.go ](sv/formatter_functions.go ) to see the functions implementation.
2022-03-01 02:43:39 +00:00
###### timefmt
**Usage:** timefmt time "2006-01-02"
Receive a time.Time and a layout string and returns a textual representation of the time according with the layout provided. Check < https: / / pkg . go . dev / time # Time . Format > for more information.
###### getsection
**Usage:** getsection sections "Features"
Receive a list of ReleaseNoteSection and a Section name and returns a section with the provided name. If no section is found, it will return `nil` .
2019-12-05 00:10:16 +00:00
### Running
2019-11-17 16:37:41 +00:00
2021-04-07 23:53:04 +00:00
Run `git-sv` to get the list of available parameters:
2019-11-17 16:37:41 +00:00
```bash
git-sv
```
2019-12-05 00:10:16 +00:00
#### Run as git command
2019-11-17 16:37:41 +00:00
2021-04-07 23:53:04 +00:00
If `git-sv` is configured on your path, you can use it like a git command:
2019-11-17 16:37:41 +00:00
```bash
git sv
git sv current-version
git sv next-version
```
2019-12-05 00:10:16 +00:00
#### Usage
2019-12-04 23:57:05 +00:00
2021-04-07 23:53:04 +00:00
Use `--help` or `-h` to get usage information, don't forget that some commands have unique options too:
2019-12-04 23:57:05 +00:00
2020-02-01 22:02:03 +00:00
```bash
# sv help
git-sv -h
2019-12-04 23:57:05 +00:00
2020-02-01 22:02:03 +00:00
# sv release-notes command help
git-sv rn -h
```
2019-12-04 23:57:05 +00:00
2020-02-01 22:02:03 +00:00
##### Available commands
2019-12-04 23:57:05 +00:00
2021-07-31 03:47:58 +00:00
| Variable | description | has options or subcommands |
| ---------------------------- | -------------------------------------------------------------- | :------------------------: |
| config, cfg | Show config information. | :heavy_check_mark: |
| current-version, cv | Get last released version from git. | :x: |
| next-version, nv | Generate the next version based on git commit messages. | :x: |
| commit-log, cl | List all commit logs according to range as jsons. | :heavy_check_mark: |
| commit-notes, cn | Generate a commit notes according to range. | :heavy_check_mark: |
| release-notes, rn | Generate release notes. | :heavy_check_mark: |
| changelog, cgl | Generate changelog. | :heavy_check_mark: |
| tag, tg | Generate tag with version based on git commit messages. | :x: |
| commit, cmt | Execute git commit with convetional commit message helper. | :heavy_check_mark: |
| validate-commit-message, vcm | Use as prepare-commit-message hook to validate commit message. | :heavy_check_mark: |
| help, h | Shows a list of commands or help for one command. | :x: |
2019-12-04 23:57:05 +00:00
2021-01-25 21:24:25 +00:00
##### Use range
Commands like `commit-log` and `commit-notes` has a range option. Supported range types are: `tag` , `date` and `hash` .
By default, it's used [--date=short ](https://git-scm.com/docs/git-log#Documentation/git-log.txt---dateltformatgt ) at `git log` , all dates returned from it will be in `YYYY-MM-DD` format.
2021-04-11 01:59:30 +00:00
Range `tag` will use `git for-each-ref refs/tags` to get the last tag available if `start` is empty, the others types won't use the existing tags. It's recommended to always use a start limit in a old repository with a lot of commits. This behavior was maintained to not break the retrocompatibility.
2021-01-25 21:24:25 +00:00
2021-04-07 23:53:04 +00:00
Range `date` use git log `--since` and `--until` . It's possible to use all supported formats from [git log ](https://git-scm.com/docs/git-log#Documentation/git-log.txt---sinceltdategt ). If `end` is in `YYYY-MM-DD` format, `sv` will add a day on git log command to make the end date inclusive.
2021-01-25 21:24:25 +00:00
Range `tag` and `hash` are used on git log [revision range ](https://git-scm.com/docs/git-log#Documentation/git-log.txt-ltrevisionrangegt ). If `end` is empty, `HEAD` will be used instead.
```bash
# get commit log as json using a inclusive range
git-sv commit-log --range hash --start 7ea9306~1 --end c444318
# return all commits after last tag
git-sv commit-log --range tag
```
2020-09-01 01:28:54 +00:00
##### Use validate-commit-message as prepare-commit-msg hook
2021-04-07 23:53:04 +00:00
Configure your `.git/hooks/prepare-commit-msg` :
2020-09-01 01:28:54 +00:00
```bash
#!/bin/sh
COMMIT_MSG_FILE=$1
COMMIT_SOURCE=$2
SHA1=$3
2021-02-26 00:12:43 +00:00
git sv vcm --path "$(pwd)" --file "$COMMIT_MSG_FILE" --source "$COMMIT_SOURCE"
2020-09-01 01:28:54 +00:00
```
2021-07-22 23:07:18 +00:00
**Tip**: you can configure a directory as your global git templates using the command below:
2020-09-01 01:28:54 +00:00
```bash
git config --global init.templatedir '< YOUR TEMPLATE DIR > '
```
2021-04-07 23:53:04 +00:00
Check [git config docs ](https://git-scm.com/docs/git-config#Documentation/git-config.txt-inittemplateDir ) for more information!
2019-11-17 16:37:41 +00:00
## Development
### Makefile
2021-04-07 23:53:04 +00:00
Run `make` to get the list of available actions:
2019-11-17 16:37:41 +00:00
```bash
make
```
#### Make configs
2021-07-31 03:47:58 +00:00
| Variable | description |
| ---------- | ----------------------- |
| BUILDOS | Build OS. |
| BUILDARCH | Build arch. |
| ECHOFLAGS | Flags used on echo. |
| BUILDENVS | Var envs used on build. |
| BUILDFLAGS | Flags used on build. |
| Parameters | description |
| ---------- | ------------------------------------ |
| args | Parameters that will be used on run. |
2019-11-17 16:37:41 +00:00
```bash
#variables
BUILDOS="linux" BUILDARCH="amd64" make build
#parameters
make run args="-h"
```
### Build
```bash
make build
```
2021-04-07 23:53:04 +00:00
The binary will be created on `bin/$BUILDOS_$BUILDARCH/git-sv` .
2019-11-17 16:37:41 +00:00
### Tests
```bash
make test
```
### Run
```bash
#without args
make run
#with args
make run args="-h"
```