The releasing guide for the SOCI maintainers.
- Update CHANGES file
- Update version numbers
- Add build status to README
- Update website content
- Upload website content
- Create release branch
- Create source archive
- Publish release packages on SourceForge
- Create annotated tag for final release and push to GitHub
- 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 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 the version number of the new release in the following places:
- README.md - version in badges, links to Git tag on GitHub and release
- include/soci/version.h
- mkdocs.yml - in
release/X.Y
branch (see create release branch) setsite_name
with X.Y and keep master in themaster
branch. - docs/index.md
- appveyor.yml
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 row for release/X.Y
to the CI build status table in README.md.
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.
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.
The website is hosted on SourceForge.net at soci.sourceforge.net and in order to upload updated files there, you will need:
- Your SourceForge account credentials with administration rights for SOCI project (used for SFTP authentication)
- SFTP client to connect to SourceForge host.
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
.
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.
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.
- Sign in to SourceForge.net using your own credentials (you need SOCI Admin privileges).
- Go to https://sourceforge.net/projects/soci/files/soci/ page.
- Hit "Add Folder" and create
soci-X.Y.Z
if it does not exist yet (e.g.soci-4.0.0
) - Go to https://sourceforge.net/projects/soci/files/soci/soci-4.0.0/
- Hit "Add File" and upload source packages prepared for release, including release candidates.
Post brief announcement about the issued release candidate to the project mailing lists: soci-devel and soci-users.
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
Post the final release announcement to the project mailing lists: soci-devel and soci-users.
The End.