OpenMRS Platform Release Process
Summary
Here's a quick summary of being Platform release manager (from Darius Jazayeri):
Pick some tickets and kick others out of the release
Keep an eye on those tickets, looking for unassigned & those assigned with no movement, occasionally pinging folks to see what's needed to move things along.
For tickets awaiting to be reviewed and whose reviews are small, you can go ahead and review them yourself.
Pull together the release (an hour or two of time)
Preliminary testing
Releasing an alpha release
Oversee subsequent releases as described on the Release Process page.
Prerequisites
OpenMRS ID
GitHub account with write privileges to openmrs-core and openmrs-distro-platform (all /dev/4 and /dev/5, but can be granted temporarily on request)
JIRA privileges for administering the OpenMRS Core project
Make sure that the release manager is added to bamboo-release-manager group
If you need GitHub/JIRA privileges, Bamboo account, open a ticket to request it.
Prior to Release
Prior to any release make an initial decision and post to Talk on what will be included in the release.
In most cases, this should be fairly clear from the Road Map; however, some projects may be a little behind schedule and a decision made whether they can be properly resourced/sped up to meet the release timeline or need to be bumped to a later release. You do not need to do all of the work of making these decision (the community should do that), but you should help ensure that the discussion occurs and you are the final arbiter for these decisions.
Features that have been committed, but are not going to be in the release need to be removed from the code.
If necessary, hold a Release Prioritization Meeting to prioritize tickets and finalize, which will be included in the release.
As release manager, try as much as possible to have the release scheduled for any working day except Friday. This will effectively publicize the the release to the community in time.
Release Types
Alpha Release
Before an alpha release, all New Feature tickets should either be Closed or at least in a Post Commit state. The same goes for Blocker tickets.
An alpha is a feature-complete release, but is not yet verified to be bug free.
An alpha version is indicated by appending "-alpha" to the version e.g. "2.2.0-alpha".
A release is ready to go from alpha to beta when preliminary testing has been completed and any bugs squashed (a minimum of rudimentary testing, ideally as many steps in the complete testing list as possible). If large bugs are found and squashed, "alpha.2", "alpha.3", etc. may be released to aid testers as needed.
Releasing additional alpha releases is up to the release manager. Going from alpha to beta does not require community discussion and is up to the release manager, but should be done only after the release manager has confirmed with testers that all known bugs have been squashed.
Beta Releases
A beta is a release that is ready to be tested by a larger group of people. Obvious bugs found in the alpha have been found and fixed.
A beta version is indicated by appending "-beta" to the version e.g. "2.2.0-beta".
Be sure to examine all outstanding tickets for the release milestone. By the time a beta release is being considered, all of the tickets assigned to the release milestone should have a clear trajectory (either be moved to a later release or have plans in place to address the issue by the full release).
Testing a Beta Release
Rudimentary testing should have already been done when creating the beta version.
Recruit volunteers to help test the beta version, including at least one implementation. Ideally, testers would run through all items in the list of application-level tests "More Complete Testing Process" on the Testing Releases page. It may help to copy this list to a shared document (e.g., Google doc or Wave) and have testers strike out tests that have been completed.
Consider adding to the More Complete Testing Process list to cover any bugs discovered at the application level (that may not be completely covered by unit testing) which are not currently included in that list.
Going from beta to a release candidate or full release requires that testing have been completed and the system formally exercised by at least one (ideally two or more) implementation.
The decision to go from beta to release candidate or final release should be led by the release manager but agreed by the developer community (via mailing list or dev call).
Release Candidates
A release candidate is only needed when non-trivial changes were required during the beta phase. If the beta release was tested and no significant changes were needed, then you can proceed directly to a full release.
A release candidate version is indicated by appending "-rc" to the version e.g. "2.2.0-rc".
Going from release candidate to full release requires that testing have been completed and the system formally exercised by at least two or more implementations. The decision to go from release candidate to final release should be led by the release manager but agreed by the developer community (via Talk).
Final Release
A true "Release" is deemed tested and worthy of production environments.
Review all existing tickets. Be certain that all tickets assigned to this release milestone have been addressed and that there aren't any straggling tickets for this milestone or previous milestones.
Maintenance Release
A maintenance release contains bug fixes and security patches for use between major releases, e.g., from 1.8.0 to 1.8.1. There is no branch to create. You just pick up where you left off in the current minor version series release branch.
Release steps
There's a number of steps to follow when doing an alpha/beta/rc/final/maintenance release. Please also refer to instructions for different types of releases (alpha/beta/rc/final/maintenance), which you can find in the next paragraphs.
If it is not a maintenance release, the release process should start from creating a maintenance branch.
Create a new maintenance branch for openmrs-core and openmrs-distro-platform.
Click the "branch" dropdown.
Type the new maintenance branch name e.g. "2.2.x".
Click "Create branch '2.2.x' from master".
Repeat the steps from b to d.
Create a new CI plan for openmrs-core
Access Bamboo:
Go to OpenMRS Bamboo.
Add a Linked Repository:
Navigate to
Administration → Linked repositories
.Click “Add repository” and select “GitHub Repository”.
Name the repository using the format:
openmrs-core-{branch_name}
, e.g.,openmrs-core-2.7.x
,openmrs-core-2.8.x
.Enter your GitHub username and access token (refer to GitHub documentation for guidance on creating a token).
Click “Load Repositories”.
From the loaded list, select
openmrs/openmrs-core
.Choose the branch you want to create a plan for (e.g.,
2.7.x
,2.8.x
).Click “Save Repository”.
Modify Bamboo Specs Configuration:
In the GitHub branch, update the
bamboo-specs/bamboo.yml
file as follows:Update
plan.key
to a version-specific key, e.g.,OC27
,OC28
.Under
repositories
, renameopenmrs-core
to match the new linked repository name, e.g.,openmrs-core-2.7.x
,openmrs-core-2.8.x
.Under
triggers
, update references toopenmrs-core
to use the new linked repository name, e.g.,openmrs-core-2.7.x
,openmrs-core-2.8.x
.
Enable and Scan the Bamboo Specs:
Go back to Bamboo's "Linked repositories" view.
Locate the newly added repository.
Under "Bamboo Specs", enable the “Scan for Bamboo Specs” option.
Under "Specs status", click “Scan” to add the new project.
Create a new CI plan for openmrs-distro-platform.
Go to https://ci.openmrs.org.
Click the "Create" dropdown at the top of the page and choose "Clone plan".
Select "OpenMRS Platform Master" as the plan to clone and give it e.g. "OpenMRS Platform 2.2.x" name, also select the plan key eg OP2.2
Edit the newly created plan by going to the "Repository" tab and change the branch of openmrs-platform repo to the newly created one e.g. "2.2.x".
Announce the upcoming Unsupported Releases (EOL) on Talk under the Software category for the line of two releases back. (e.g. if you're releasing 1.7.0, announce EOL for 1.4.x)
Steps to follow for all releases:
Write a post that announces the release date and modules to be included on Talk under the Software category. Ask, if there is a need to release modules in order to include latest changes before the platform release.
Verify that there are no unreviewed open tickets against the version to be released. You can use this query https://goo.gl/WXqrI3 (adjust the fixVersion).
Review/close tickets that are in Post Commit Review.
Look carefully at In Progress tickets to see, if some of them have not been committed to a branch (back ported) already. You need to review/close such tickets as well. You can easily check, if any code was committed by searching for an issue id on a GitHub comparison page at https://github.com/openmrs/openmrs-core/compare/2.0.4...2.0.x (adjust the versions).
Move tickets to the next version that are In Progress or in Pre-Commit Review stage (use Manage Versions admin page for bulk moving of tickets, see the 4.a. step below).
Create a new version for the next release. Using the Manage Versions in https://tickets.openmrs.org/plugins/servlet/project-config/TRUNK.
Release the current version using the above admin page.
When you release a version it will allow you to move non-closed tickets to the next version.
Download the latest CIEL for OpenMRS 1.9.x (use 1.9.x regardless of the release version) as described here. Upload the version to our maven repository to be used in standalone by running (adjust the version and the file parameters to match the downloaded version of CIEL):
mvn deploy:deploy-file -DgroupId=org.openmrs.contrib -DartifactId=ciel-dictionary -Dversion=1.9.9-20170409 -Dpackaging=zip -Dfile=openmrs_concepts_1.9.9_20170409.sql.zip -DrepositoryId=openmrs-repo-contrib -Durl=https://mavenrepo.openmrs.org/nexus/content/repositories/contrib
Update the CIEL version in standalone's pom.
Check if the branch to be released is green at https://ci.openmrs.org/browse/TRUNK and https://ci.openmrs.org/browse/OP-OPM/branches
Do some last minute rudimentary testing as described in Testing Releases on snapshot artifacts published by CI.
Release process for OpenMRS Core
Build the release plan
Start by running the release plan for OpenMRS Core (e.g., "OpenMRS Core 2.7.0 Release Plan") in Bamboo.Verify build completion
Once the build is finished, confirm that the build icon has turned green, indicating a successful build.Initiate the release
Click "Release" to proceed.Set release variables
In the "Run stage (Release)" pop-up window, selectOverride a variable
and specify the following variables:build.release.type: Choose the type of release. If this is a full release, set this to
release
; if it's an alpha or beta release, useprerelease
.maven.release.version: Enter the version you are releasing (e.g.,
2.6.2
or2.7.0-alpha
).
Execute the release
After setting the variables, click "Run" to initiate the release process.Setting the next Maven development version
After a release, Bamboo automatically updates the next Maven development version on the release branch. However, if you want to set a custom version, follow these steps:Checkout to the release branch locally
Switch to the release branch you want to modify, for example,2.7.x
or2.6.x
:Run the following Maven command to set your desired development version, replacing
NEXT_DEV_VERSION
with the version you want:mvn versions:set -DnewVersion=${OMRS_DEV_VERSION} -DgenerateBackupPoms=false
Create and merge a pull request
Create a pull request with this version update and merge it into the release branch.
Release process for OpenMRS Platform
Prepare the release branch
Checkout the release branch for openmrs-distro-platform locally.
Update module versions in the
pom.xml
file to the latest released versions. (Note: You may need to release these modules individually beforehand.)
Run the platform release plan on Bamboo
In Bamboo, select the release plan created for the platform.
Initiate the release
Click "Release" to start the release process.
Set release variables
In the “Run stage (Release)” pop-up, select Override a variable and specify the following:
build.release.type: Set to
release
for a full release orprerelease
for alpha/beta.maven.release.version: Enter the version being released (e.g.,
2.6.2
,2.7.0-alpha
).maven.development.version: Set the next development version for the release (e.g.,
2.7.0-SNAPSHOT
,2.6.3-SNAPSHOT
).
Execute the release
After configuring the variables, click "Run" to initiate and complete the release process.
Update the openmrs qa-ref2app server by ensuring it is pointing to the openMRS Platform version you have just released.
create a pull request on the 2.x branch on the https://github.com/openmrs/openmrs-distro-referenceapplication repository. For example take a look at this pull request https://github.com/openmrs/openmrs-distro-referenceapplication/pull/692
Update the UAT Platform Environment: Remember to update UAT Platform server. This can be achieved by doing the following.
Go to your build plan, for example https://ci.openmrs.org/browse/OP-OP26
click the create button (with dropdown icon) in the navigation bar and select create deployment project
Fill in the details like Name e.g OpenMRS platform 2.6.0, description and check the checkbox allowing all users to see the deployment project.
Ensure the link to the build plan matches the build plan containing the release you just made and then click the create deployment button to create the project.
On the page that opens up, add an environment by clicking the Add Environment button.
Provide the environment details like environment name e.g UAT PLATFORM, description e.g Deploys uat tag for platform in docker hub.
On the page that opens up, click the setup tasks button in order to provide the script to be used to make the deployment.
Remove the existing tasks i.e clean working directory task and artifact download task, and then add a new task called script
Provide a task description i.e Deploy UAT tag for platform in docker hub and in the script body, paste the scripts below and save;-
script
docker login -u ${bamboo.dockerhub.username} -p ${bamboo.dockerhub.password} set -x docker buildx imagetools create --tag ${bamboo.docker.image.id} ${bamboo.docker.image.id}:uat ssh -o StrictHostKeyChecking=no \ -o UserKnownHostsFile=/dev/null \ bamboo@uat-platform.openmrs.org \ sudo deploy-compose uat-platform
Then click the deploy button at the top but ensure the build result to be used in this deployment is the latest build result. Then click the start deployment deployment.
Then, Login to the UAT Platform Environment and confirm you can see a page like this: https://uat-platform.openmrs.org/openmrs/owa/addonmanager/index.html#/
What you SHOULD see after logging in:
Example of what you should NOT see:
In the file listing page on Sourceforge, open the recently released version, click the info "i" button next to the standalone to expand the details of the uploaded ZIP file. For "Download Button", type "OpenMRS Platform 2.0.5 Standalone". Under "Default Download For:" check all the option boxes. Click "Save" to save the settings.
Create the release notes page as a child of Platform Release Notes and include JIRA filters showing all closed tickets (e.g. Platform Release Notes 1.11.1)
Use Finding Database Changes Between Releases to put the db changes into the release notes page.
Edit the Platform Release Notes page to include as content the new release notes page you just created, and updated it to give the new version number.
Update the Releases page to include the new platform release, (replacing the prior version in the release line with this release)
Update and modify the Downloads wiki page with the latest release notes page.
Create a help desk case with https://openmrs.atlassian.net/servicedesk/customer/portals at a minimum of one working day prior to the scheduled release providing download links. DO NOT mark Impact as anything other than "Routine."
Use the following template for description (replace 2.0.5 with the correct version, the release date & time and the JIRA url, which you can determine from https://issues.openmrs.org/browse/TRUNK/?selectedTab=com.atlassian.jira.jira-projects-plugin:versions-panel):Create a new case at OpenMRS helpdesk requesting to update the OpenMRS.org home page and downloads page to the latest release. Please provide links to the downloads.
Create a blog post about the full release(Note: this should be done only after releasing the Full Release not during the alpha or beta release) you have just made by creating a help desk case in the infrastructure requests portal with https://openmrs.atlassian.net/servicedesk/customer/portals requesting for access to the website so that you can be able update the blogs page with your blog.
Write a post that announces the released on Talk under Software category similar to the blog post .
With the exception of pre-releases, you need to release the version in jira, you will probably need admin privileges to do this, you can ask for them through the help desk or ask somebody with the privileges to help you release it in JIRA.
Go to JIRA
Click the Projects menu item and select OpenMRS Core (TRUNK) from the dropdown.
You should see a menu on the left panel on the page that gets loaded, select Releases.
In the Actions column click the row matching the version you're releasing and select Release from the little pop up menu.
Set the release date and click the Release button, note that you might have to move any unresolved issues to the next release.
Troubleshooting (when not using CI for releasing)
Tips
When doing release testing, creating standalone distributions can be a very quick and easy way.