mirror of https://github.com/getdnsapi/getdns.git
106 lines
3.9 KiB
Plaintext
106 lines
3.9 KiB
Plaintext
High level release procedure that we follow to make a formal release for the
|
|
getdns API project. This is a recipe - if you have a better way to do it then
|
|
update this document and share it with us.
|
|
|
|
- code freeze
|
|
confirm with core team that all commits are in, from this point forward
|
|
only bug fixes will be included in the release branch
|
|
|
|
- create a release branch
|
|
in git repository named for the release, e.g. "v0.1.2"
|
|
we do this because folks may want to continue to work in the master branch
|
|
and be free to commit changes without injuring the release process. Since
|
|
building and testing binaries for a release takes a few days we don't want to
|
|
force changes to queue up.
|
|
|
|
One might argue that a release can be cut more quickly, however there are
|
|
inevitably little tweaks that need to be made that get uncovered as a result
|
|
of the binary builds - these tweaks need to be included in the souces for
|
|
this release so building the source tarball can't be done until all of the
|
|
binaries have been built and tested.
|
|
|
|
- clone repo release branch to a clean local repo
|
|
this should be a brand spanking new directory - don't try to shortcut it and
|
|
use a working directory with lots of cruft - crap will find its way into the
|
|
release and embarass you:
|
|
|
|
# git clone -b v0.1.2 https://github.com/getdnsapi/getdns.git getdns-0.1.2
|
|
|
|
- update files to reflect release number/date
|
|
./README.md
|
|
./ChangeLog
|
|
./configure.ac (AC_INIT)
|
|
|
|
# autoreconf
|
|
|
|
commit these changes to the release branch
|
|
|
|
# git commit -a -m "release number and date updates"
|
|
# git push
|
|
|
|
- build binaries for each target platform
|
|
- create clean local repo
|
|
- build code (no additional libraries, note that regression tests will not build)
|
|
if you are building a simple binary tar then something like this works
|
|
# ./configure --prefix=/Users/gwiley/getdnsox/export
|
|
# make
|
|
# make install
|
|
# tar -C /Users/gwiley/getdnsosx/export -cvf getdns-0.1.2.tar *
|
|
|
|
- build code (with libevent)
|
|
# ./configure --with-libevent2
|
|
|
|
- run regression tests and verify that alls well
|
|
|
|
if you have do do anything even mildly interesting to get the build or install to
|
|
work then we either have to add it to the README.md or, preferably, fix it
|
|
and update the branch
|
|
|
|
Be careful about tool sets loaded on your build hosts. You may have 'solved'
|
|
problems while you are working that mask issues with the build for more typical
|
|
users - this is why we want to build on hosts that are representative of
|
|
our users.
|
|
|
|
- install on each target platform
|
|
- make sure and use a user that was NOT used for the build, this will uncover
|
|
any silliness related to absolute paths in the build
|
|
|
|
- if a build breaks or an install fails then commit fixes to the relase branch
|
|
- rebuild EVERY binary using the changed release branch
|
|
|
|
- once all binaries are built and tested clean, create source tar ball
|
|
and the actual package for each platform
|
|
|
|
you may need to run this as root to permit the chown
|
|
# make clean
|
|
# make dist
|
|
generates getdns-0.1.2.tar.gz
|
|
|
|
- generate checksums for each binary/source tar
|
|
|
|
- upload source and binaries to the getdnsapi.net site
|
|
|
|
- update getdnsapi.net web site
|
|
news entry for the release
|
|
main page download links
|
|
main page checksums
|
|
|
|
- announce message to
|
|
getdns mailing list
|
|
stub-resolvers mailing list
|
|
Verisign internal via the matrix
|
|
|
|
- merge branch changes back into master
|
|
|
|
List of Build Targets
|
|
---------------------
|
|
The naming conventions for each of these build products are specific to the
|
|
platform they target. The result is that the naming seems a little inconsistent,
|
|
however I felt that it is best to follow naming standards for the platform rather
|
|
than try to impose a project specific standard across platforms.
|
|
|
|
- source tar: getdns-0.1.2.tar.gz
|
|
- OSX binary package: getdns-0.1.2-OSX_10_8.dmg
|
|
- RHEL/CentOS: getdns-0.1.0-1.CentOS_6_5.x86_64.rpm
|
|
- Debian/Ubuntu:
|