Release instructions.
(a) - denotes something that is a candidate for automation
In-progress release notes during the cycle of development should have been written in release-notes.md
.
Review these notes and edit as needed. You can use Markdown.
The only truly mandatory requirement is to mention all contributors.
When you've got the release announcement set, copy it to the description of the GitHub milestone, but don't close the milestone yet.
- Ensure there is a next (version after what is being released) milestone on GitHub
- Check that there are no outstanding reviews for commits for the current versions, or at least that any issues don't block the release
- Check that there are no outstanding issues/pull requests for the development version (either implement or move them to next milestone)
- (a) Ensure that there are no -SNAPSHOT dependencies (or if there are, that there is good reason for them)
- Ensure the the build is passing (i.e. run
./gradlew clean build
)
- (a) Update the
version
property inratpack.gradle
(i.e. drop the -SNAPSHOT) - Ensure the the build is still passing (i.e. run
./gradlew clean build
) - really isn't needed, but doesn't hurt - Commit with message “Version «number»”
- Tag commit with name “v«number»” (don't push yet)
- Build and upload the binaries:
./gradlew publishToSonatypeOss closeAndReleaseSonatypeOssStagingRepository
- See below for credential requirements - Publish to Gradle Plugin Portal:
./gradlew publishPlugins
- See below for credential requirements.
- (a) Update
version
property inratpack.gradle
(i.e. increment the patch number and add -SNAPSHOT) - Update the
manualVersions
list inratpack-site.gradle
so the new manual is included in the site - (a) Update
release-notes.md
to remove the content specific to the freshly-completed release (i.e. set it back to a fresh template) - Commit with message 'Begin version «version»', and push (make sure you push the tag)
- Run
./gradlew clean publishToSonatypeOss
- Add the
Due Date
to the Milestone in GitHub and close it - Copy the release announcement to the GitHub tag description on the GitHub releases page and publish the release
- Get a tweet out about the release
- For all example projects (example-ratpack-gradle-java-app, example-ratpack-gradle-groovy-app, example-books):
- Update
master
branch to use the latest released version - Merge
latest
branch intomaster
to pick up any fixes for breaking changes in the released version
- Update
- Ability to edit milestones for the
ratpack/ratpack
GitHub project (it might be that only admins can do this, not sure) - GPG credentials/config
- We use the Gradle Signing Plugin to sign the artifacts - See the Gradle docs for how to set this up
- One gotcha is forgetting to distribute your public key. See here for more info. If you don't do this you will get problems when syncing to Maven central.
- oss.sonatype.org credentials
- Create an account for oss.sonatype.org
- Add a comment to this JIRA ticket with your new account, asking for permission to publish to
io.ratpack
. - Add to ~/.gradle/gradle.properties as
ratpackOssrhUsername
andratpackOssrhPassword
- Gradle Plugin Portal config
- Access to the
ratpack_team
publish key and secret. (Ask John or Jeff)
- Access to the