]> granicus.if.org Git - icinga2/blobdiff - RELEASE.md
Docs: Add SELinux chapter
[icinga2] / RELEASE.md
index 898154ba4f2e58cf5f00d860d0241b7448aae020..8d7859ac3d76b952c639c7a3906ff9e6acb0519a 100644 (file)
@@ -1,14 +1,38 @@
-# Quality Assurance
+# Release Workflow
 
-Review and test the changes and issues for this version.
-https://dev.icinga.org/projects/i2/roadmap
+Print this document.
 
-# Release Workflow
+## Issues
+
+Check the following issue filters:
+
+* [Pending backports](https://dev.icinga.org/projects/i2/issues?query_id=41)
+* [Invalid target version](https://dev.icinga.org/projects/i2/issues?query_id=55)
+
+## Backport Commits
+
+    $ git checkout master
+    $ ./pick.py -V 2.4.9
+
+The script creates a new branch 'auto-merged-2.4.9' which is based on the
+current support branch. It then merges all commits from the 'master' branch which
+reference a ticket for the version that was specified.
+
+If there are any merge commits you will need to manually fix them and continue the
+rebase until no commits are left:
+
+    $ git rebase --continue
+
+After finishing the rebase the branch needs to be merged into the support branch:
+
+    $ git checkout support/2.4
+    $ git merge --ff-only auto-merged-2.4.9
 
 ## Authors
 
 Update the [.mailmap](.mailmap) and [AUTHORS](AUTHORS) files:
 
+    $ git checkout master
     $ git log --use-mailmap | grep ^Author: | cut -f2- -d' ' | sort | uniq > AUTHORS
 
 ## Version
@@ -17,7 +41,7 @@ Update the version number in the following files:
 
 * [icinga2.spec]: Version: (.*)
 * [icinga2.nuspec]: <version>(.*)</version>
-* [tools/chocolateyInstall.ps1]: Icinga2-v(.*).exe
+* [tools/chocolateyInstall.ps1]: Icinga2-v(.*)-{x86,x86_64}.msi
 
 ## Changelog
 
@@ -26,15 +50,15 @@ the changelog.py script. Also generate HTML for the wordpress release announceme
 
 Changelog:
 
-    $ ./changelog.py --version 2.3.11 --project i2
+    $ ./changelog.py -V 2.4.9
 
 Docs:
 
-    $ ./changelog.py --version 2.3.11 --project i2 --links
+    $ ./changelog.py -V 2.4.9 -l
 
 Wordpress:
 
-    $ ./changelog.py --version 2.3.11 --project i2 --html --links
+    $ ./changelog.py -V 2.4.9 -H -l
 
 ## Git Tag
 
@@ -62,29 +86,37 @@ Push the tag.
 For major releases: Create a new "support" branch:
 
     $ git checkout master
-    $ git checkout -b support/2.3
-    $ git push -u origin support/2.3
+    $ git checkout -b support/2.4
+    $ git push -u origin support/2.4
 
-For minor releases: Push the support branch and cherry-pick the release commit into master:
+For minor releases: Push the support branch, cherry-pick the release commit
+into master and merge the support branch:
 
-    $ git push -u origin support/2.3
+    $ git push -u origin support/2.4
     $ git checkout master
-    $ git cherry-pick support/2.3
+    $ git cherry-pick support/2.4
+    $ git merge --strategy=ours support/2.4
     $ git push origin master
 
 # External Dependencies
 
 ## Build Server
 
-### Linux
+* Update Git tags for the release jobs.
+* Build the newly created Git tag for Debian/RHEL/SuSE.
+* Build the newly created Git tag for Windows.
 
-* Build the newly created git tag for Debian/RHEL/SuSE.
+## Release Tests
+
+* Test DB IDO with MySQL and PostgreSQL.
 * Provision the vagrant boxes and test the release packages.
-* Start a new docker container and install/run icinga2
+* Test the [setup wizard](http://packages.icinga.org/windows/) inside a Windows VM.
+
+* Start a new docker container and install/run icinga2.
 
 Example for CentOS7:
 
-    $ sudo docker run -ti centos:latest bash
+    $ docker run -ti centos:latest bash
 
     # yum -y install http://packages.icinga.org/epel/7/release/noarch/icinga-rpm-release-7-1.el7.centos.noarch.rpm
     # yum -y install icinga2
@@ -93,23 +125,40 @@ Example for CentOS7:
     # systemctl start icinga2
     # tail -f /var/log/icinga2/icinga2.log
 
-### Windows
+## GitHub Release
 
-* Build the newly created git tag for Windows.
-* Test the [setup wizard](http://packages.icinga.org/windows/) inside a Windows VM.
+Create a new release for the newly created Git tag.
+https://github.com/Icinga/icinga2/releases
 
-## Github Release
+## Chocolatey
 
-Create a new release from the newly created git tag.
-https://github.com/Icinga/icinga2/releases
+Navigate to the git repository on your Windows box which
+already has chocolatey installed. Pull/checkout the release.
+
+Create the nupkg package:
+
+    cpack
+
+Install the created icinga2 package locally:
+
+    choco install icinga2 -version 2.4.9 -fdv "%cd%" -source "'%cd%;https://chocolatey.org/api/v2/'"
+
+Upload the package to [chocolatey](https://chocolatey.org/packages/upload).
 
 ## Online Documentation
 
-Ssh into the web box, navigate into `icinga2-latest/module/icinga2`
-and pull the current icinga2 revision to update what's new".
+SSH into the web box, navigate into `icinga2-latest/module/icinga2`
+and pull the current support branch.
 
 ## Announcement
 
 * Create a new blog post on www.icinga.org/blog
 * Send announcement mail to icinga-announce@lists.icinga.org
 * Social media: [Twitter](https://twitter.com/icinga), [Facebook](https://www.facebook.com/icinga), [G+](http://plus.google.com/+icinga), [Xing](https://www.xing.com/communities/groups/icinga-da4b-1060043), [LinkedIn](https://www.linkedin.com/groups/Icinga-1921830/about)
+* Update IRC channel topic
+
+# After the release
+
+* Add new minor version
+* Close the released version
+* Update Redmine filters for the next major/minor version