]> granicus.if.org Git - icinga2/blobdiff - RELEASE.md
Update documentation for Windows Wizard and On-Demand signing support
[icinga2] / RELEASE.md
index 898154ba4f2e58cf5f00d860d0241b7448aae020..0657dbb32c40f18dce3f4f360945f9fdde5a8775 100644 (file)
@@ -1,46 +1,65 @@
-# Quality Assurance
+# Release Workflow
 
-Review and test the changes and issues for this version.
-https://dev.icinga.org/projects/i2/roadmap
+Specify the release version.
 
-# Release Workflow
+```
+VERSION=2.7.1
+```
+
+## Issues
+
+Check issues at https://github.com/Icinga/icinga2
+
+## Backport Commits
+
+For minor versions you need to manually backports any and all commits from the
+master branch which should be part of this release.
 
 ## Authors
 
 Update the [.mailmap](.mailmap) and [AUTHORS](AUTHORS) files:
 
-    $ git log --use-mailmap | grep ^Author: | cut -f2- -d' ' | sort | uniq > AUTHORS
+```
+git checkout master
+git log --use-mailmap | grep ^Author: | cut -f2- -d' ' | sort | uniq > AUTHORS
+```
 
 ## Version
 
-Update the version number in the following files:
+Fetch the latest spec file from the [icinga-packaging](https://github.com/icinga/icinga-packaging)
+repository and verify that the latest version is set.
 
-* [icinga2.spec]: Version: (.*)
-* [icinga2.nuspec]: <version>(.*)</version>
-* [tools/chocolateyInstall.ps1]: Icinga2-v(.*).exe
+```
+wget -O icinga2.spec https://raw.githubusercontent.com/Icinga/icinga-packaging/rpm/snapshot/icinga2/icinga2.spec
+gsed -i "s/Version: .*/Version: $VERSION/g" icinga2.spec
+```
 
 ## Changelog
 
-Update the [ChangeLog](ChangeLog), [doc/1-about.md](doc/1-about.md) files using
-the changelog.py script. Also generate HTML for the wordpress release announcement.
+Update the [CHANGELOG.md](CHANGELOG.md) file.
 
-Changelog:
+Export these environment variables:
 
-    $ ./changelog.py --version 2.3.11 --project i2
+```
+export ICINGA_GITHUB_AUTH_USERNAME='user'
+export ICINGA_GITHUB_AUTH_TOKEN='token'
+export ICINGA_GITHUB_PROJECT='icinga/icinga2'
+```
 
-Docs:
+Run the script which updates the [CHANGELOG.md](CHANGELOG.md) file.
 
-    $ ./changelog.py --version 2.3.11 --project i2 --links
-
-Wordpress:
-
-    $ ./changelog.py --version 2.3.11 --project i2 --html --links
+```
+./changelog.py
+git diff
+```
 
 ## Git Tag
 
 Commit these changes to the "master" branch:
 
-    $ git commit -v -a -m "Release version <VERSION>"
+```
+git commit -v -a -m "Release version $VERSION"
+```
 
 For minor releases: Cherry-pick this commit into the "support" branch.
 
@@ -49,67 +68,119 @@ releases) or the "support" branch (for minor releases).
 
 GB:
 
-    $ git tag -u EE8E0720 -m "Version <VERSION>" v<VERSION>
+```
+git tag -u EE8E0720 -m "Version $VERSION" v$VERSION
+```
 
 MF:
 
-    $ git tag -u D14A1F16 -m "Version <VERSION>" v<VERSION>
+```
+git tag -u D14A1F16 -m "Version $VERSION" v$VERSION
+```
 
 Push the tag.
 
-    $ git push --tags
+```
+git push --tags
+```
 
 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 master
+git checkout -b support/2.7
+git push -u origin support/2.7
+```
 
-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 checkout master
-    $ git cherry-pick support/2.3
-    $ git push origin master
+```
+git push -u origin support/2.7
+git checkout master
+git cherry-pick support/2.7
+git merge --strategy=ours support/2.7
+git push origin master
+```
 
 # External Dependencies
 
 ## Build Server
 
-### Linux
+* Verify package build changes for this version.
+* Test the snapshot packages for all distributions beforehand.
+* Build the newly created Git tag for Debian/RHEL/SuSE.
+* Build the newly created Git tag for Windows.
+
+## Release Tests
 
-* Build the newly created git tag for Debian/RHEL/SuSE.
+* 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](https://packages.icinga.com/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 https://packages.icinga.com/epel/icinga-rpm-release-7-latest.noarch.rpm
+yum -y install icinga2
+icinga2 daemon -C
+```
 
-    # yum -y install http://packages.icinga.org/epel/7/release/noarch/icinga-rpm-release-7-1.el7.centos.noarch.rpm
-    # yum -y install icinga2
-    # icinga2 daemon -C
+## GitHub Release
 
-    # systemctl start icinga2
-    # tail -f /var/log/icinga2/icinga2.log
+Create a new release for the newly created Git tag.
+https://github.com/Icinga/icinga2/releases
 
-### Windows
+## Chocolatey
 
-* Build the newly created git tag for Windows.
-* Test the [setup wizard](http://packages.icinga.org/windows/) inside a Windows VM.
+Navigate to the git repository on your Windows box which
+already has chocolatey installed. Pull/checkout the release.
 
-## Github Release
+Create the nupkg package:
 
-Create a new release from the newly created git tag.
-https://github.com/Icinga/icinga2/releases
+```
+cpack
+```
+
+Install the created icinga2 package locally:
+
+```
+choco install icinga2 -version 2.7.0 -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".
+Edit `config.yml` in the [icinga-docs-tools](https://github.com/Icinga/icinga-docs-tools) repository:
+
+```
+git clone git@github.com:Icinga/icinga-docs-tools.git
+cd icinga-docs-tools/
+vim config.yml
+
+git commit -av -m "Update to Icinga 2 v$VERSION"
+git push
+```
+
+SSH into the web VM and build the docs:
+
+```
+cd /var/www/docs/icinga-docs/latest/
+/usr/bin/bundle exec ./build-docs.rb
+```
 
 ## 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)
+* Create a new blog post on www.icinga.com/blog
+* Social media: [Twitter](https://twitter.com/icinga), [Facebook](https://www.facebook.com/icinga), [G+](https://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 on [GitHub](https://github.com/Icinga/icinga2/milestones).
+* Close the released version on [GitHub](https://github.com/Icinga/icinga2/milestones).