Gradle plugin for Updates the project version.
A plugin that can updating the semantic versions like yarn version
command.
Prerequisites:
- Java 8 or higher
- Gradle 6.x or higher
You need to add the following lines to your build.gradle
file:
plugins {
id 'com.github.shailesh17.semver' version '<latest version from the Gradle plugin portal>'
}
- Add supported for dry-run. More...
- Add supported for an automating generate a changelog with the ConventionalCommits. More...
- Add supported for an automating versioning with the ConventionalCommits. More...
- Add supported for a get current version from the latest tag. More...
Using the semver
gradle plugin you can update the version of your package via the gradle task.
For example,starting with this gradle.properties
file:
version=1.0.1
When we run the semver
task:
gradle semver
question New version.
info Current version: 1.0.1
question New version: 1.0.2
> Task :semver
...
info New version: 1.0.2
We will get this updated gradle.properties
file:
version=1.0.2
Note: The new version you enter must be a valid SemVer version.
A plugin consists of the following tasks.
gradle semverLatest
Resolve a current version from the latest FILE, or TAG.
DependsOn: jar
gradle semver
A plugin that can updating the semantic versions like yarn version
command.
Other than that, it now supports conventional commits, so you can automate your releases.
DependsOn: check, semverLatest
gradle semver
Create a new version using an interactive session to prompt you for a new version.
gradle semver --new-version <version>
Creates a new version specified by <version>
.
gradle semver --major
gradle semver --minor
gradle semver --patch
Creates a new version by incrementing the major, minor, or patch number of the current version.
gradle semver --premajor
gradle semver --preminor
gradle semver --prepatch
Creates a new prerelease version by incrementing the major, minor, or patch number of the current version and adding a prerelease number.
gradle semver --prerelease
Increments the prerelease version number keeping the main version.
gradle semver [--premajor | --preminor | --prepatch |--prerelease ] --preid <pre-identifier>
Adds an identifier specified by to be used to prefix premajor, preminor, prepatch or prerelease version increments.
gradle semver --conventional-commits
Create a new version according to the Conventional Commits rules. It refers to the commit log since the last release and creates a new version based on the following rules.
The commit message should be structured as follows:
<type>[optional scope]: <description>
[optional body]
[optional footer(s)]
- fix: a commit the type
fix
patches a bug in your codebase (this correlates with--patch
option). - feat: a commit the type
feat
introduces a new feature to the codebase (this correlates with--minor
option). - BREAKING CHANGE: a commit that has a footer
BREAKING CHANGE:
, or appends a!
after the type/scope, introduces a breaking API change (correlating with--major
option). A BREAKING CHANGE can be part of commits of any type. - Types other than
fix
andfeat
are allowed, but an automating versioning is not supported.
For more information, please refer to ConventionalCommits
gradle semver --conventional-commits --dryrun
Dry run the options. In a dry run, the following operations will be disabled.
- local/remote Git operations (git add, git commit, git tag, git push)
- GitHub release operations
The plugin defines an extension with the namespace semver
. The following properties can be configured:
Property Name | Type | Default value | Description |
---|---|---|---|
target | String | 'FILE' | Choice 'FILE' or 'TAG'. |
versionTagPrefix | String | 'v' | Change the prefix of the git tag. |
versionGitMessage | String | 'v%s' | Change the git message. Where %s is the version string. |
changeLog | String | 'NONE' | Choice 'NONE' or FILE' or 'GITHUB' or 'BOTH'. |
changeLogZoneId | String | 'UTC' | Choice the zone id supported by the ZoneId class. |
changeLogOrder | String[] | Change type order. | |
noBackupChangelog | boolean | true | Even enable or disable the create the CHANGELOG.bak behavior entirely. |
noBackupProp | boolean | true | Even enable or disable the create the gradle.properties.bak behavior entirely. |
noBackupPackageJson | boolean | true | Even enable or disable the create the package.json.bak behavior entirely. |
noGitStatusCheck | boolean | false | Even enable or disable the git status check behavior entirely. |
filename | String | 'gradle.properties' | (FILE Only) Change the filename of version property. |
noGitCommand | boolean | false | (FILE Only) Even enable or disable the git command behavior entirely. |
noGitInit | boolean | true | (FILE Only) Even enable or disable the git init behavior entirely. |
noGitCommitVersion | boolean | false | (FILE Only) Even enable or disable the git commit behavior entirely. |
noGitTagVersion | boolean | false | (FILE Only) Even enable or disable the git tagging behavior entirely. |
noGitPush | boolean | true | (FILE Only) Even enable or disable the git push branch behavior entirely. |
noGitPushTag | boolean | true | (FILE Only) Even enable or disable the git push tag behavior entirely. |
noPackageJson | boolean | false | (FILE Only) Even enable or disable the versioning the package.json behavior entirely. |
FILE:
- Get current version from file. (gradle.properties, package.json, etc.)
- Update to new version, save to file.
- Create a git commit of save file.
- Create a git tag of new version.
TAG:
- Get latest tag for git.
- Analyze tag, convert to semantic version.(current version)
- Update to new version, save to file.
- Create a git tag of new version.
- Push tag to remote.
GIT CONTROL | FILE(DEFAULT) | TAG(DEFAULT) |
---|---|---|
CREATE(UPDATE) VERSION FILES | Y | Y |
CREATE VERSION COMMIT | Y | N |
CREATE VERSION TAG | Y | Y |
PUSH COMMIT | N | N |
PUSH TAG | N | Y |
For example, add with this build.gradle
file:
semver {
target = 'file'
versionTagPrefix = 'v'
versionGitMessage = 'v%s'
noGitInit = false
noGitCommand = false
noGitTagVersion = false
noGitPush = false
noGitPushTag = false
noPackageJson = true
}
semver-gradle-plugin requires push access to the project Git repository in order to create git branch or git tag.
The Git authentication can be set with one of the following environment variables:
Variables | Description |
---|---|
GH_ACTOR GH_TOKEN or GITHUB_ACTOR GITHUB_TOKEN |
A GitHub personal access token. |
GL_ACTOR GL_TOKEN or GITLAB_ACTOR GITLAB_TOKEN |
A GitLab personal access token. |
BB_ACTOR BB_TOKEN or BITBUCKET_ACTOR BITBUCKET_TOKEN |
A Bitbucket personal access token. |
or the following system properties:
System properties | Description |
---|---|
gh.actor gh.token or github.actor github.token |
|
gl.actor gl.token or gitlab.actor gitlab.token |
|
bb.actor bb.token or bitbucket.actor bitbucket.token |
Here is an example of what a gradle.properties
file:
~/.gradle/gradle.properties
systemProp.gh.actor=xxx
systemProp.gh.token=xxx
A new version of the changelog can be generated automatically. The changelog will be generated from the Git commit log of the previous release or later.
It also supports the following:
- Markdown format
- ConventionalCommits
- GitHub Releases
For example, add with this build.gradle
file:
semver {
changeLog = 'FILE'
}
NONE
: Do nothing (default)FILE
: Write the changelog to a file (CHANGELOG.md)GITHUB
: Upload the changelog to GitHub ReleasesBOTH
: BothFILE
andGITHUB
For example, add with this build.gradle
file:
semver {
changeLogOrder = [
'__breaking_change__',
'feat',
'fix',
]
}
For example, add with this build.gradle
file:
semver {
changeLogTitle = [
build : 'Build Improvements',
chore : 'Chores',
ci : 'CI Improvements',
docs : 'Documentation',
feat : 'New Features',
fix : 'Bug Fixes',
perf : 'Performance Improvements',
refactor : 'Code Refactoring',
style : 'Styles',
test : 'Tests',
__breaking_change__: '!!! BREAKING CHANGES !!!',
__undefined__ : 'Other Changes',
]
}
if you run semver
task within a Git repository an annotated Git tag will be created by default following the format v0.0.0
.
You can customize the git tag that is created or disable this behavior by using semver extension
.
For example, add with this build.gradle
file:
semver {
// To change the prefix of the git tag you can use versionTagPrefix:
versionTagPrefix = 'v'
// Or you can change the git message using versionGitMessage where %s is the version string:
versionGitMessage = 'v%s'
// You can even enable or disable the git tagging behavior entirely by using noGitTagVersion:
noGitTagVersion = false
// You can even enable or disable the git command behavior entirely by using noGitCommand:
noGitCommand = false
}
CASE | gradle.properties | package.json |
---|---|---|
Not exists | CREATE | - |
gradle.properties exists | UPDATE | - |
package.json exists | - | UPDATE |
gradle.properties, package.json exists |
UPDATE | UPDATE |
The semver
task runs based on Gradle build lifecycle.
You can use the following mechanism of Gradle to execute another task before and after executing the semver
task.
- dependsOn
- reconfigure
Executing the semver
task overrides project.version
, e.g. project.version
will in the doFirst() hold the version before the version change, and in the doLast() it will hold the version after the version change.
Here is an example of what a build.gradle
file:
tasks.semver.dependsOn test
tasks.semver.configure {
doFirst {
println "doFirst preversion: $project.version"
}
doLast {
println "doLast postversion: $project.version"
}
}
Executed semver
task would look something like this:
info Current version: 0.1.1
question New version: (default: 0.1.1): 0.1.2
> Task :semver
doFirst preversion: 0.1.1
info New version: 0.1.2
doLast postversion: 0.1.2
You don’t need to build from source to use semver-gradle-plugin
, but if you want to try out the latest, semver-gradle-plugin
can be built and published to your local Maven cache using the Gradle wrapper.
You also need following to:
- Java 11 or higher
- Gradle 7.x or higher
$ ./gradlew publishToMavenLocal
If you want to build everything, use the build task:
$ ./gradlew build
The semver
gradle plugin is released under version 2.0 of the Apache License.