Release instructions (back-end module)
Main release
Make sure that all pull requests required for the release are merged.
Pull all changes and create a new branch from the master with the name `tmp-release-vX.Y.Z`, where X.Y.Z - a new version of the module
Use versions-maven-plugin to update module dependencies in pom.xml (only stable versions, without snapshot, betta, alfa, etc.).
Run mvn clean verify to check that new dependencies versions do not affect functionality.
Commit changes with the commit message 'Update dependencies'.
Update NEWS with changes that are included in the release (use the template below).
## vX.Y.Z YYYY-mm-DD ### Breaking changes * Description ([ISSUE](https://folio-org.atlassian.net/browse/ISSUE)) ### New APIs versions * Provides `API_NAME vX.Y` * Requires `API_NAME vX.Y` ### Features * Description ([ISSUE](https://folio-org.atlassian.net/browse/ISSUE)) ### Bug fixes * Description ([ISSUE](https://folio-org.atlassian.net/browse/ISSUE)) ### Tech Dept * Description ([ISSUE](https://folio-org.atlassian.net/browse/ISSUE)) ### Dependencies * Bump `LIB_NAME` from `OLD_VERSION` to `NEW_VERSION` * Add `LIB_NAME VERSION` * Remove `LIB_NAME`Commit changes with the commit message 'Update NEWS'.
Run
mvn release:branchor use the built-in IDE Maven plugin to create a release branch.The branch name should be in the format
release/vX.YThe new development version should be
X.Y+1.0-SNAPSHOT.
Update folio dependencies to snapshot versions and update NEWS with template for upcoming version. Commit changes.
Push created commits to the repository and create a pull request. Wait for the review of your PR and merge it.
Checkout the
release/vX.Yrelease branch. Then runmvn clean release:prepareor use the built-in Maven plugin to prepare the release.Release version - X.Y.0
Release tag - vX.Y.0
New version - vX.Y.1-SNAPSHOT
Push the release branch and the tag to the repository.
Go to Jenkins https://jenkins-aws.indexdata.com/job/folio-org/job/<module-name>/view/tags/ and run the pipeline for the new tag.
After the pipeline job is successfully finished you can create a release on GitHub.
Notify the community in the release channel about the release.
Close the release ticket:
Set Fix Version = X.Y.0 (if it does not exist ask SM or TL to create it)
Set Release
Set Fix Version to all tickets that were included in the release.
Release version in Jira and preapre new versions (request it from TL or SM).
Bugfix/Hotfix Release
Checkout to release/vX.Y branch.
Cherry-Pick required commits from master branch.
Create a new branch with the name `tmp-release-vX.Y.Z`, where X.Y.Z - a new version of the module
Run mvn clean verify to check that all tests are passed.
Update NEWS with changes that are included in the release (use the template below).
## vX.Y.Z YYYY-mm-DD ### Bug fixes * Description ([ISSUE](https://folio-org.atlassian.net/browse/ISSUE)) ### Tech Dept * Description ([ISSUE](https://folio-org.atlassian.net/browse/ISSUE)) ### Dependencies * Bump `LIB_NAME` from `OLD_VERSION` to `NEW_VERSION` * Add `LIB_NAME` `VERSION` * Remove `LIB_NAME`Commit changes with the commit message 'Update NEWS'.
Run
mvn release:clean release:prepareor use the built-in Maven plugin to prepare the release. (Usemvn release:clean -DskipTests -Darguments=-DskipTests release:preparein case of some problems with local maven tests run)Release version - X.Y.Z
Release tag - vX.Y.Z
New version - vX.Y.Z+1-SNAPSHOT
Push the branch and the tag to the repository and create a pull request. Wait for the review of your PR and merge it.
Go to Jenkins https://jenkins-aws.indexdata.com/job/folio-org/job/<module-name>/view/tags/ and run the pipeline for the new tag.
After the pipeline job is successfully finished you can create a release on GitHub.
Notify the community in the release channel about the release.
Close the release ticket:
Set Fix Version = X.Y.Z (if it does not exist ask SM or TL to create it)
Set Release to all tickets that were included in the release (don't set to release ticket).
Set Fix Version to all tickets that were included in the release.
Release version in Jira and preapre new versions (request it from TL or SM).