Skip to content

Latest commit

 

History

History
203 lines (141 loc) · 7.46 KB

RELEASING.md

File metadata and controls

203 lines (141 loc) · 7.46 KB

Releasing

The releasing guide for the SOCI maintainers.

  1. Update CHANGES file
  2. Update version numbers
  3. Add build status to README
  4. Update website content
  5. Upload website content
  6. Create release branch
  7. Create source archive
  8. Publish release packages on SourceForge
  9. Create annotated tag for final release and push to GitHub
  10. Announce new release

NOTICE: The 4.0 and 4.0.0 version numbers are used below (e.g. as in release/4.0) to keep the instructions more concrete, but it is a placeholder similar to X.Y or X.Y.Z. It should be replaced with the version number of the new release.

Update CHANGES file

Update the list of important changes in the CHANGES file.

First, start new section with new line like this:

Version X.Y.Z differs from A.B.C in the following ways:

optionally, you may also want to start with X.Y.Z-rc1, changing through X.Y.Z-rc2, X.Y.Z-rc3, etc. to X.Y.Z on the course of updates towards the final release. For example, like so

Version 4.0.0 differs from 3.2.3 in the following ways:

Next, it is helpful to generate complete log of changes in Markdown format:

git log 3.2.3..master --pretty=format:"1. [%h](http://github.com/soci/soci/commit/%H) - %s"

Then, filter it out from trivial changes keeping only the important ones. Next, group changes in sections for core and backends, sort within sections, edit and update if necessary. Finally, copy to the CHANGES file.

Commit the updates to the master branch first. See Create release branch.

Update version numbers

Update the version number of the new release in the following places:

Search through the source tree looking for other places that use current version number and may require an update. Depending on type of release, update major, minor and micro version numbers.

The version number also has to be updated in number of places on the website, see update website section.

Add build status to README

Add row for release/X.Y to the CI build status table in README.md.

Update website content

Update version of the new release on the www/index.html page.

Add date and version of the new release on the www/events.html page.

Add link to the folder with documentation for the new release on the www/doc/index.html page.

Upload website content

Continuous deployment

There is CircleCI workflow configured in .circleci/config.yml with dedicated jobs to deploy content website and documentation.

For master and release/X.Y branches, the jobs do:

  • lint all Markdown files
  • run MkDocs to generate HTML pages from source in doc/
  • upload generated HTML files to branch-specific documentation folder (e.g. doc/release/4.0)
  • upload static HTML files with website pages

See manual update for details about SFTP connection.

Manual update

The website is hosted on SourceForge.net at soci.sourceforge.net and in order to upload updated files there, you will need:

For example, you can use lftp to upload website and documentation files similarly to our CircleCI workflow configured to generate and deploy documentation (see .circleci/config.yml):

lftp sftp://${DEPLOY_DOCS_USER}:${DEPLOY_DOCS_PASS}@web.sourceforge.net -e "set ftp:ssl-force true; set ftp:ssl-protect-data true; set ssl:verify-certificate no; set sftp:auto-confirm yes; mirror -v -R <source> <target directory>; quit"

where <source> denotes a file or folder to be copied and <target directory> is a directory under Web content folder of SOCI on web.sourceforge.net i.e. /home/project-web/soci/htdocs.

Create release branch

git checkout master
git branch release/4.0

NOTICE:: All changes preparing the release or hotfixes should be committed to master branch first, then merged to release/X.Y branch that is being released. If it is a newly created release/X.Y branch, then prefer fast-forward merges from master. In other cases, e.g. if release/X.Y is an existing release branch and you are releasing a bugfix release, you may have to perform true merge.

Create source archive

NOTICE: Run this step in Linux environment only.

Run scripts/release.sh script to build release archives with content from release/X.Y branch.

cd soci
./scripts/release.sh --help

First, you will want to build number of release candidates (typically 1-3, rarely 5-6):

./scripts/release.sh --rc 1 release/4.0
./scripts/release.sh --rc 2 release/4.0
...

Eventually, once release candidates have been reviewed and verified, you will build packages ready for the final release:

./scripts/release.sh release/4.0

This will output the release candidate packages:

  • soci-4.0.0-rc1.zip
  • soci-4.0.0-rc1.tar.gz

or the final release packages:

  • soci-4.0.0.zip
  • soci-4.0.0.tar.gz

where 4.0.0 is placeholder for the major, minor and micro version determined from the current value of the SOCI_LIB_VERSION macro in include/soci/version.h.

Publish release packages on SourceForge

  1. Sign in to SourceForge.net using your own credentials (you need SOCI Admin privileges).
  2. Go to https://sourceforge.net/projects/soci/files/soci/ page.
  3. Hit "Add Folder" and create soci-X.Y.Z if it does not exist yet (e.g. soci-4.0.0)
  4. Go to https://sourceforge.net/projects/soci/files/soci/soci-4.0.0/
  5. Hit "Add File" and upload source packages prepared for release, including release candidates.

Announce release candidates

Post brief announcement about the issued release candidate to the project mailing lists: soci-devel and soci-users.

Create annotated tag for final release and push to GitHub

Since we use SourceForge.net to publish release packages, we do not use GitHub releases, so there is no need to publish a new release via GitHub. Creating and pushing Git annotated tag is sufficient.

git checkout release/4.0
git tag -a 4.0.0 -m "Releasing SOCI 4.0.0"
git push origin 4.0.0

Announce final release

Post the final release announcement to the project mailing lists: soci-devel and soci-users.

The End.