Skip to content

Release guide

Enrico Olivelli edited this page Jan 10, 2019 · 3 revisions

Release guide

Assume that your git 'origin' remote is http://github.com/diennea/majordodo

git remote -v

Set up and cache Github credentials (you need to have committer privileges on this repository):

git checkout master
git push --dry-run

Ensure you have at least JDK11 and Maven 3.6.X

$JAVA_HOME/bin/java -version
mvn -version

In case you are performing new major release, for instance you are releasing 0.14.0, so current master should be 0.14.0-SNAPSHOT, new master will be 0.15.0-SNAPSHOT, you will be creating a release/0.14 branch and a v0.14.0 tag

In case you are performing a minor release, for instance you are releasing 0.14.1, you will be starting from release/0.14 branch, with version 0.7.1-SNAPSHOT, new version on that branch will be 0.14.2-SNAPSHOT and at the end you will have a v0.14.1 tag

Cut release branch (for major releases)

BRANCH_NAME=release/0.14
RELEASE_DEVELOPMENT_VERSION=0.14.1-SNAPSHOT
RELEASE_VERSION=0.14.0
MASTER_DEVELOPMENT_VERSION=0.15.0-SNAPSHOT
TAG=v$RELEASE_VERSION
JAVA_HOME=~/dev/jdk-11


git checkout master
git pull --rebase
mvn release:clean
mvn release:branch -DbranchName=$BRANCH_NAME -DdevelopmentVersion=$MASTER_DEVELOPMENT_VERSION

From now you can expect:

  • on master pom.xml version is MASTER_DEVELOPMENT_VERSION
  • you have a release branch named BRANCH_NAME
  • in BRANCH_NAME pom.xml version is RELEASE_DEVELOPMENT_VERSION

Prepare release branch (for minor/point releases)

BRANCH_NAME=release/0.14
RELEASE_DEVELOPMENT_VERSION=0.14.2-SNAPSHOT
RELEASE_VERSION=0.14.1
TAG=v$RELEASE_VERSION
JAVA_HOME=~/dev/jdk-11

git checkout $BRANCH_NAME
git pull
git push --dry-run

Perform release on the branch

git checkout $BRANCH_NAME
mvn release:prepare -DautoVersionSubmodules=true  -DreleaseVersion=$RELEASE_VERSION -Dtag=$TAG  -DdevelopmentVersion=$RELEASE_DEVELOPMENT_VERSION -Darguments='-DskipTests=true' 

From now you can expect:

  • in BRANCH_NAME pom.xml version is RELEASE_DEVELOPMENT_VERSION
  • you have a new tag named TAG
  • in TAG version.xml is RELEASE_VERSION

Deploy artifacts to Maven Central

Checklist:

  • You need to have your OSSRH credentials written in settings.xml
  • You need to have a valid GPG Private Key
git checkout $TAG
mvn release:perform -DreleaseProfiles=ossrh -Darguments='-DskipTests=true'