2016-05-10 18:44:41 +02:00
|
|
|
Release process
|
|
|
|
===============
|
|
|
|
|
|
|
|
Corda is under heavy development. The current release process is therefore geared towards rapid iteration.
|
|
|
|
|
|
|
|
Each Corda development release is called a *milestone* and has its own branch in the git repository. Milestones are
|
|
|
|
temporarily stabilised snapshots of the Corda code which are suitable for developers to experiment with. They may
|
|
|
|
receive backported bugfixes but once announced a milestone will not have any API or backwards compatibility breaks.
|
|
|
|
|
|
|
|
Between milestones backwards compatibility is expected to break. Every new milestone comes with a short announcement
|
|
|
|
detailing:
|
|
|
|
|
|
|
|
* What major improvements have been made.
|
|
|
|
* How to forward port your code to the new milestone.
|
|
|
|
* What new documentation has become available.
|
|
|
|
* Important known issues.
|
|
|
|
|
|
|
|
Eventually, Corda will stabilise and release version 1. At that point backwards compatibility will be guaranteed
|
|
|
|
forever and the software will be considered production ready. Until then, expect it to be a building site and wear your
|
|
|
|
hard hat.
|
|
|
|
|
|
|
|
Our goal is to cut a new milestone roughly once a month. There are no fixed dates. If need be, a milestone may slip by
|
2016-05-25 11:52:16 +02:00
|
|
|
a few days to ensure the code is sufficiently usable. Usually the release will happen around the end of the month.
|
|
|
|
|
|
|
|
Steps to cut a release
|
2017-01-06 11:05:37 +00:00
|
|
|
----------------------
|
2016-05-25 11:52:16 +02:00
|
|
|
|
|
|
|
1. Pick a commit that is stable and do basic QA: run all the tests, run the demos.
|
|
|
|
2. Review the commits between this release and the last looking for new features, API changes, etc. Make sure the
|
|
|
|
summary in the current section of the :doc:`release-notes` is correct and update if not. Then move it into the right
|
|
|
|
section for this release. This is the right place to put any advice on how to port app code from the last release.
|
|
|
|
3. Additionally, if there are any new features or APIs that deserve a new section in the docsite and the author didn't
|
|
|
|
create one, bug them to do so a day or two before the release.
|
|
|
|
4. Regenerate the docsite if necessary and commit.
|
|
|
|
5. Create a branch with a name like `release-M0` where 0 is replaced by the number of the milestone.
|
2016-07-06 17:54:46 +01:00
|
|
|
6. Adjust the version in the root build.gradle file to take out the -SNAPSHOT and commit it on the branch.
|
2016-08-30 12:53:34 +02:00
|
|
|
7. Remove the "is master" warning from the docsite index page on this branch only.
|
|
|
|
8. Tag the branch with a tag like `release-M0.0`
|
|
|
|
9. Push the branch and the tag to git.
|
|
|
|
10. Write up a short announcement containing the summary of new features, changes, and API breaks. Send it to the r3dlg-awg mailing list.
|
|
|
|
11. On master, adjust the version number in the root build.gradle file upwards.
|
2016-05-25 11:52:16 +02:00
|
|
|
|
|
|
|
If there are serious bugs found in the release, backport the fix to the branch and then tag it with e.g. `release-M0.1`
|
2017-01-18 13:42:22 +01:00
|
|
|
Minor changes to the branch don't have to be announced unless it'd be critical to get all developers updated.
|