Things to do when creating new monthly minor or major release
NOTE: This is a guide for GitLab developers. If you are trying to install GitLab see the latest stable installation guide and if you are trying to upgrade, see the upgrade guides.
Install guide up to date?
- References correct GitLab branch x-x-stableand correct GitLab shell tag?
Make upgrade guide
From x.x to x.x
0. Any major changes? Database updates? Web server change? File structure changes?
1. Make backup
2. Stop server
3. Do users need to update dependencies like git?
4. Get latest code
5. Does GitLab shell need to be updated?
6. Install libs, migrations, etc.
7. Any config files updated since last release?
Check if any of these changed since last release (~22nd of last month depending on when last release branch was created):
- https://gitlab.com/gitlab-org/gitlab-ce/commits/master/lib/support/nginx/gitlab
- https://gitlab.com/gitlab-org/gitlab-shell/commits/master/config.yml.example
- https://gitlab.com/gitlab-org/gitlab-ce/commits/master/config/gitlab.yml.example
- https://gitlab.com/gitlab-org/gitlab-ce/commits/master/config/unicorn.rb.example
- https://gitlab.com/gitlab-org/gitlab-ce/commits/master/config/database.yml.mysql
- https://gitlab.com/gitlab-org/gitlab-ce/commits/master/config/database.yml.postgresql
8. Need to update init script?
Check if changed since last release (~22nd of last month depending on when last release branch was created): https://gitlab.com/gitlab-org/gitlab-ce/commits/master/lib/support/init.d/gitlab
9. Start application
10. Check application status
Make sure the code quality indicatiors are good
 this button can be yellow (small updates are available) but must not be red (a security fix or an important update is available) this button can be yellow (small updates are available) but must not be red (a security fix or an important update is available)
Make a release branch
After making the release branch new commits are cherry-picked from master. When the release gets closer we get more selective what is cherry-picked. The days of the month are approximately as follows:
- 17th: feature freeze (stop merging new features in master)
- 18th: UI freeze (stop merging changes to the user interface)
- 19th: code freeze (stop merging non-essential code improvements)
- 20th: release candidate 1 (VERSION x.x.0.pre, tag and tweet about x.x.0.rc1)
- 21st: optional release candidate 2 (x.x.0.rc2, only if rc1 had problems)
- 22nd: release (VERSION x.x.0, create x-x-stable branch, tag, blog and tweet)
- 23nd: optional patch releases (x.x.1, x.x.2, etc., only if there are serious problems)
- 24-end of month: release Enterprise Edition and upgrade GitLab Cloud
- 1-7th: official merge window (see contributing guide)
- 8-16th: bugfixes and sponsored features
Write a blog post
- Mention what GitLab is on the second line: GitLab is open source software to collaborate on code.
- Select and thank the the Most Valuable Person (MVP) of this release.
- Add a note if there are security fixes: This release fixes an important security issue and we advise everyone to upgrade as soon as possible.



