These instructions apply to every gem within the Google Cloud Ruby Client project.
Each gem must be released separately. In order for the docs for the google-cloud
package to build correctly, the only entry in docs/manifest.json
that can be updated in the version commit preceding the release tag is the entry for the gem in the tag. The docs build will fail if you attempt to release multiple gems in parallel, since the first tag build will not yet find the listed docs for the other gems in the gh-pages
branch.
The Google Cloud Ruby Client project uses semantic versioning. Replace the <prev_version>
and <version>
placeholders shown in the examples below with the appropriate numbers, e.g. 0.1.0
and 0.2.0
. Replace the <gem>
placeholder with the appropriate full name of the package, e.g. google-cloud-datastore
.
After all pull requests for a release have been merged and all Circle CI builds are green, you may create a release as follows:
-
If you haven't already, switch to the master branch, ensure that you have no changes, and pull from origin.
$ git checkout master $ git status $ git pull <remote> master --rebase
-
Build the gem locally. (Depending on your environment, you may need to
bundle exec
to rake commands; this will be shown.)$ cd <gem> $ bundle exec rake build
-
Install the gem locally. (The
rake install
task shown below may not always work as expected. Fall back to runninggem install
in an empty gemset if needed.)$ bundle exec rake install
-
Using IRB (not
rake console
!), manually test the gem that you installed in the previous step. -
Return to the root directory of the project, and review the changes since the last release.
$ cd .. $ bundle exec rake changes[<gem>]
-
Review the commits in the changes output, making notes of significant changes. (For examples of what a significant change is, browse the changes in the gem's
CHANGELOG.md
. -
Edit the gem's
CHANGELOG.md
. Using your notes from the previous step, write bullet-point lists of the major and minor changes. You can also add examples, fixes, thank yous, and anything else helpful or relevant. See google-cloud-node v0.18.0 for an example with all the bells and whistles. -
Edit the gem's
version.rb
file, if present, or theversion
setting in its.gemspec
file, changing the value to your new version number. -
Edit (or add if new) the gem's entry in
docs/manifest.json
, adding your new version number to the head of the list, and moving"master"
to be just below it. -
If the semver version change for your package requires an increase in the requirement for your package in
google-cloud/google-cloud.gemspec
and/orstackdriver/stackdriver.gemspec
, replace the old version requirement with your new requirement. Note that because of the use of the pessimistic operator (~>
), only certain version changes will require updating the requirement. Note also that the dependency requirements in thegoogle-cloud
andstackdriver
gems must remain compatible so the two can co-exist in the same bundle. -
If your package is new, ensure that it has been added to the top-level
Gemfile
. -
If your package is new, ensure that a nav link and a main entry including code example have been added to the top-level README.
-
In the root directory of the project, test that all the version dependencies are correct.
$ bundle update $ bundle exec rake ci[yes]
-
Commit your changes. Copy and paste the significant points from your
CHANGELOG.md
edit as the description in your commit message.$ git commit -am "Release <gem> <version> ..."
-
Tag the version.
$ git tag <gem>/v<version>
-
Push the tag. This will trigger a build job on Circle CI.
$ git push <remote> <gem>/v<version>
-
Wait until the Circle CI build has passed for the tag.
-
Confirm that the new version is displayed on the google-cloud-ruby gh-pages doc site, both in the packages pulldown and the version switcher.
If the gh-pages doc site has not been updated, inspect the build logs to confirm that the release task completed successfully, and that the docs build succeeded. This can still fail even on a green build because it is an "after" action in the build.
-
Confirm that the gem for the new version is available on RubyGems.org.
-
On the google-cloud-ruby releases page, click Draft a new release. Complete the form. Include the bullet-point lists of the major and minor changes from the gem's
CHANGELOG.md
. You can also add examples, fixes, thank yous, and anything else helpful or relevant. See google-cloud-node v0.18.0 for an example with all the bells and whistles. -
Click
Publish release
. -
Repeat steps 1 through 21 if you are releasing multiple gems.
-
If you updated
google-cloud/google-cloud.gemspec
for a version change to any gem, repeat steps 1 through 21 for thegoogle-cloud
gem. If any gem is new, first follow the steps in Adding a new gem to meta-packages, below. -
If you updated
stackdriver/stackdriver.gemspec
for a version change to any gem, repeat steps 1 through 21 for thestackdriver
gem. If any gem is new, first follow the steps in Adding a new gem to meta-packages, below. -
Wait until the last tag build job has successfully completed on Circle CI. Then push your commits to the master branch. This will trigger another Circle CI build on master branch.
$ git push <remote> master
-
After the Circle CI master branch build has successfully completed, confirm that Travis CI (Mac OS X) and Appveyor CI (Windows) master branch builds are also green.
High fives all around!
There are extra steps required to add a new package to the google-cloud
and/or stackdriver
meta-package gems. These instructions are for the google-cloud
gem. (The stackdriver
gem does not require the documentation steps.)
- Add the gem to
google-cloud/Gemfile
. - Add the gem to
google-cloud/google-cloud.gemspec
. - Add the gem to
gcloud/Gemfile
. - Copy the JSON fragment from the gem's
docs/toc.json
to correct alphabetical location ingoogle-cloud/docs/toc.json
. - Add the gem to the
google-cloud
whitelist in the top-levelRakefile
.