tree: b175e94715610749565fefea6bd7819cf68a5f52 [path history] [tgz]
  1. tests/
  2. cloudbuild.yaml
  3. README.md
  4. release-versions.yaml
  5. release.py
  6. requirements.txt
release/README.md

Release process

Container images for container source code present in cos/tools are built utilizing the Google cloud build service. An automated build system which utilizes cloud build triggers builds the container images whenever changes are pushed on the cos/tools git repo. Any change to the container images source code automatically triggers new builds for all the containers in this repo.

In addition to builds triggered after a change on cos/tools, we have nightly builds for all the containers in this repo.

The recipes for building the containers are specified as dockerfiles (for eg. toolbox Dockerfile). Further buildx is used to create images for multiple target architectures(x86 64, ARM64).

For each new build executed by the automated triggers and nightly builds, the built container images are pushed to an internal google container image registry with unique tag labels with pattern of -. Short-sha is the short version of GIT commit-sha of the change being updated. Build-id is a unique id assigned by cloud build. To pick a release candidate, find the latest image that has the matching short-sha to the commit-sha of the change.

The release process is a multi-party code reviewed automated process(see source here). This is also achieved by using the cloud build triggers on the cos/tools repository. The release candidates (state of the releases) live in a config file(source). When changes are made to the release candidates, an automated cloud build process copies the specified container images from the internal google container image registry to the public cos-cloud container registry.

Validating release config - TODO (rnv) - convert to presubmit cloud build

task

After making changes to the release state the validity of the changes can be checked by running the following command from the root of the repo:

gcloud builds submit --config=presubmit.yaml

where presubmit.yaml could look like the following:

steps:
- name: 'gcr.io/google.com/cloudsdktool/cloud-sdk:latest'
  entrypoint: 'bash'
  args: ['-c',
  'pip3 install -r release/requirements.txt && python3 release/release.py --verify'
  ]