blob: 5210f22c0f4b2834820395dc854f9b26f670c06f [file] [log] [blame]
# Copyright 2022 The Go Authors. All rights reserved.
# Use of this source code is governed by a BSD-style
# license that can be found in the LICENSE file.
# This is a Cloud Build config file for the go-ecosystem worker.
# Invoke locally from the command line using devtools/deploy.sh.
# It can also be configured to run from a trigger, by supplying the _ENV
# substitution.
substitutions:
_ENV: ''
_BQ_DATASET: ''
steps:
- id: Lock
name: golang:1.20.7
entrypoint: bash
args:
- -ec
- |
if [[ "$COMMIT_SHA" = '' ]]; then
echo "no COMMIT_SHA, not locking"
exit 0
fi
go run golang.org/x/website/cmd/locktrigger@latest \
-project $PROJECT_ID -build $BUILD_ID -repo https://go.googlesource.com/pkgsite-metrics
- id: Test
# Run tests. Do this early, to avoid wasting time if they fail.
name: golang:1.20.7
entrypoint: bash
args:
- -ec
- go test ./...
- id: Prepare
name: gcr.io/cloud-builders/gcloud
entrypoint: bash
args:
- -ec
- |
# Determine the image name and save for later steps.
if [[ "$SHORT_SHA" = '' ]]; then
echo >&2 "missing SHORT_SHA; use --substitutions on command line"
exit 1
fi
if [[ "$_ENV" = '' ]]; then
echo >&2 "missing _ENV; use --substitutions on command line"
exit 1
fi
if [[ "$_BQ_DATASET" = '' ]]; then
echo >&2 "missing _BQ_DATASET; use --substitutions on command line"
exit 1
fi
tag=$(date +%Y%m%dt%H%M%S)-$SHORT_SHA
image=gcr.io/$PROJECT_ID/${_ENV}-ecosystem-worker:$tag
echo "image is $image"
echo $image > /workspace/image.txt
# Convert the commented config.json file to valid json.
sed '/^[ \t]*#/d' config.json.commented > /workspace/config.json
# Download the vuln DB from its bucket to a local directory, and remember
# its last-modified time in a file.
gsutil -m -q cp -r gs://go-vulndb /workspace
gsutil stat gs://go-vulndb/index.json | \
awk '$$1 == "Update" { for (i = 4; i <= NF; i++) printf("%s ", $$i); printf("\n"); }' \
> /workspace/go-vulndb/LAST_MODIFIED
# Download a tarball of a docker Go image.
gsutil cp gs://go-ecosystem/go-image.tar.gz /workspace
- id: Build
# Build the docker image.
#
# The files we put in /workspace in the previous step need to be
# in the repo root so they get uploaded to the Docker daemon.
# However it turns out that /workspace is in fact the same directory,
# so no copying is necessary.
name: gcr.io/cloud-builders/docker
entrypoint: bash
args:
- -ec
- |
image=$(cat /workspace/image.txt)
docker build -t $image -f cmd/worker/Dockerfile . \
--build-arg DOCKER_IMAGE=$image \
--build-arg BQ_DATASET=${_BQ_DATASET} \
--build-arg SERVICE_ID=${_ENV}-ecosystem-worker
docker push $image
- id: Deploy
name: gcr.io/cloud-builders/gcloud
entrypoint: bash
args:
- -ec
- |
image=$(cat /workspace/image.txt)
service=${_ENV}-ecosystem-worker
args="--project $PROJECT_ID --region us-central1"
gcloud beta run deploy $args $service --image $image --execution-environment=gen2
# If there was a rollback, `gcloud run deploy` will create a revision but
# not point traffic to it. The following command ensures that the new revision
# will get traffic.
latestTraffic=$(gcloud run services $args describe $service \
--format='value(status.traffic.latestRevision)')
if [[ $latestTraffic != True ]]; then
gcloud run services $args update-traffic $service --to-latest
fi