gitlab-org--gitlab-foss/doc/release/patch.md

57 lines
2.2 KiB
Markdown
Raw Normal View History

2014-04-10 05:23:44 -04:00
# Things to do when doing a patch release
2014-05-27 08:12:15 -04:00
2014-04-10 05:23:44 -04:00
NOTE: This is a guide for GitLab developers. If you are trying to install GitLab see the latest stable [installation guide](install/installation.md) and if you are trying to upgrade, see the [upgrade guides](update).
## When to do a patch release
2014-04-24 18:48:22 -04:00
Do a patch release when there is a critical regression that needs to be addresses before the next monthly release.
2014-04-10 05:23:44 -04:00
Otherwise include it in the monthly release and note there was a regression fix in the release announcement.
## Release Procedure
### Preparation
2014-04-24 18:48:22 -04:00
1. Verify that the issue can be reproduced
1. Note in the 'GitLab X.X regressions' that you will create a patch
2014-04-10 05:23:44 -04:00
1. Create an issue on private GitLab development server
1. Name the issue "Release X.X.X CE and X.X.X EE", this will make searching easier
1. Fix the issue on a feature branch, do this on the private GitLab development server
1. If it is a security issue, then assign it to the release manager and apply a 'security' label
1. Consider creating and testing workarounds
2014-04-10 05:23:44 -04:00
1. After the branch is merged into master, cherry pick the commit(s) into the current stable branch
1. Make sure that the build has passed and all tests are passing
2015-02-09 13:46:38 -05:00
1. In a separate commit in the master branch update the CHANGELOG
2014-04-10 05:28:12 -04:00
1. For EE, update the CHANGELOG-EE if it is EE specific fix. Otherwise, merge the stable CE branch and add to CHANGELOG-EE "Merge community edition changes for version X.X.X"
2015-02-09 13:46:38 -05:00
1. Merge CE stable branch into EE stable branch
### Bump version
Get release tools
```
git clone git@dev.gitlab.org:gitlab/release-tools.git
cd release-tools
```
Bump version in stable branch, create release tag and push to remotes:
```
bundle exec rake release["x.x.x"]
```
Or if you need to release only EE:
```
CE=false be rake release['x.x.x']
```
### Release
2014-06-04 03:27:23 -04:00
1. [Build new packages with the latest version](https://gitlab.com/gitlab-org/omnibus-gitlab/blob/master/doc/release.md)
2015-02-09 13:46:38 -05:00
1. Apply the patch to GitLab.com and the private GitLab development server
1. Create and publish a blog post
2015-02-09 13:46:38 -05:00
1. Send tweets about the release from `@gitlab`, tweet should include the most important feature that the release is addressing and link to the blog post
1. Note in the 'GitLab X.X regressions' issue that the patch was published (CE only)