From 65d1f577af43325e275df59920168e9fd61e0950 Mon Sep 17 00:00:00 2001 From: Josh Deprez Date: Thu, 28 Nov 2024 14:26:31 +1100 Subject: [PATCH] Pipeline cleanups --- .buildkite/Dockerfile | 5 --- .buildkite/Dockerfile.build | 3 ++ .buildkite/Dockerfile.test | 1 + .buildkite/docker-compose.yaml | 19 ------------ .buildkite/docker-compose.yml | 48 +++++++++++++++++++++++++++++ .buildkite/pipeline.release.yml | 8 +++-- .buildkite/pipeline.yml | 52 ++++++++++++++++++++------------ .buildkite/steps/build-binary.sh | 4 +-- .buildkite/steps/build-lambda.sh | 14 ++------- .github/dependabot.yml | 6 ++-- 10 files changed, 98 insertions(+), 62 deletions(-) delete mode 100644 .buildkite/Dockerfile create mode 100644 .buildkite/Dockerfile.build create mode 100644 .buildkite/Dockerfile.test delete mode 100644 .buildkite/docker-compose.yaml create mode 100644 .buildkite/docker-compose.yml diff --git a/.buildkite/Dockerfile b/.buildkite/Dockerfile deleted file mode 100644 index b758d902..00000000 --- a/.buildkite/Dockerfile +++ /dev/null @@ -1,5 +0,0 @@ -FROM buildkite/agent:3.45.0 AS agent - -FROM public.ecr.aws/docker/library/golang:1.20.2-alpine3.17 -COPY --from=agent /usr/local/bin/buildkite-agent /usr/local/bin/buildkite-agent -RUN apk --no-cache add bash zip curl aws-cli github-cli diff --git a/.buildkite/Dockerfile.build b/.buildkite/Dockerfile.build new file mode 100644 index 00000000..63804bf6 --- /dev/null +++ b/.buildkite/Dockerfile.build @@ -0,0 +1,3 @@ +FROM public.ecr.aws/docker/library/golang:1.23.3-alpine@sha256:c694a4d291a13a9f9d94933395673494fc2cc9d4777b85df3a7e70b3492d3574 + +RUN apk add --no-cache aws-cli bash curl github-cli zip diff --git a/.buildkite/Dockerfile.test b/.buildkite/Dockerfile.test new file mode 100644 index 00000000..c3f0e88f --- /dev/null +++ b/.buildkite/Dockerfile.test @@ -0,0 +1 @@ +FROM public.ecr.aws/docker/library/golang:1.23.3@sha256:73f06be4578c9987ce560087e2e2ea6485fb605e3910542cadd8fa09fc5f3e31 AS builder diff --git a/.buildkite/docker-compose.yaml b/.buildkite/docker-compose.yaml deleted file mode 100644 index 78e438a2..00000000 --- a/.buildkite/docker-compose.yaml +++ /dev/null @@ -1,19 +0,0 @@ -version: "3.9" - -services: - agent: - build: - context: . - dockerfile: Dockerfile - volumes: - - ../:/workspace:cached - working_dir: /workspace - environment: - - BUILDKITE_BUILD_NUMBER - - BUILDKITE_BUILD_ID - - BUILDKITE_JOB_ID - - BUILDKITE_BRANCH - - BUILDKITE_TAG - - BUILDKITE_AGENT_ACCESS_TOKEN - - GITHUB_RELEASE_ACCESS_TOKEN - - RELEASE_DRY_RUN diff --git a/.buildkite/docker-compose.yml b/.buildkite/docker-compose.yml new file mode 100644 index 00000000..9b3e6a06 --- /dev/null +++ b/.buildkite/docker-compose.yml @@ -0,0 +1,48 @@ +services: + build: + build: + context: . + dockerfile: Dockerfile.build + volumes: + - ../:/work:cached + - ~/gocache:/gocache + - ~/gomodcache:/gomodcache + working_dir: /work + environment: + - BUILDKITE_AGENT_ACCESS_TOKEN + - BUILDKITE_AGENT_TAGS=queue=default + - BUILDKITE_BRANCH + - BUILDKITE_BUILD_ID + - BUILDKITE_BUILD_NUMBER + - BUILDKITE_BUILD_PATH=/buildkite + - BUILDKITE_JOB_ID + - BUILDKITE_TAG + - GITHUB_RELEASE_ACCESS_TOKEN + - GOCACHE=/gocache + - GOMODCACHE=/gomodcache + - RELEASE_DRY_RUN + + test: + build: + context: . + dockerfile: Dockerfile.test + volumes: + - ../:/work:cached + - ~/gocache:/gocache + - ~/gomodcache:/gomodcache + working_dir: /work + environment: + - BUILDKITE_AGENT_TAGS=queue=default + - BUILDKITE_BRANCH + - BUILDKITE_BUILD_ID + - BUILDKITE_BUILD_NUMBER + - BUILDKITE_BUILD_PATH=/buildkite + - BUILDKITE_JOB_ID + - BUILDKITE_TAG + - GOCACHE=/gocache + - GOMODCACHE=/gomodcache + + release: + build: + context: . + dockerfile: Dockerfile.release diff --git a/.buildkite/pipeline.release.yml b/.buildkite/pipeline.release.yml index 63cea827..fce090ad 100644 --- a/.buildkite/pipeline.release.yml +++ b/.buildkite/pipeline.release.yml @@ -9,7 +9,7 @@ steps: agents: queue: "elastic-runners" concurrency: 1 - concurrency_group: 'release_buildkite_metrics_github' + concurrency_group: "release_buildkite_metrics_github" plugins: - aws-assume-role-with-web-identity: role-arn: arn:aws:iam::032379705303:role/pipeline-buildkite-buildkite-agent-metrics @@ -26,6 +26,8 @@ steps: - aws-ssm#v1.0.0: parameters: GITHUB_RELEASE_ACCESS_TOKEN: /pipelines/buildkite/buildkite-agent-metrics/GITHUB_RELEASE_ACCESS_TOKEN - - docker-compose#v4.14.0: + - docker-compose#v5.5.0: config: .buildkite/docker-compose.yaml - run: agent + run: build + cli-version: 2 + mount-buildkite-agent: true diff --git a/.buildkite/pipeline.yml b/.buildkite/pipeline.yml index 240c7e52..b0e601e3 100644 --- a/.buildkite/pipeline.yml +++ b/.buildkite/pipeline.yml @@ -3,35 +3,47 @@ steps: key: test command: go test -v -race ./... plugins: - - docker#v5.9.0: - image: golang:1.21 + - docker-compose#v5.5.0: + config: .buildkite/docker-compose.yml + cli-version: 2 + run: test - group: ":hammer_and_wrench: Binary builds" steps: - - name: ":{{matrix.os}}: Build {{matrix.os}} {{matrix.arch}} binary" - command: .buildkite/steps/build-binary.sh {{matrix.os}} {{matrix.arch}} - key: build-binary - depends_on: - - test - plugins: - - docker#v5.9.0: - image: golang:1.21 - mount-buildkite-agent: true - matrix: - setup: - os: - - darwin - - linux - - windows - arch: - - amd64 - - arm64 + - name: ":{{matrix.os}}: Build {{matrix.os}} {{matrix.arch}} binary" + command: .buildkite/steps/build-binary.sh {{matrix.os}} {{matrix.arch}} + key: build-binary + depends_on: + - test + plugins: + - docker-compose#v5.5.0: + config: .buildkite/docker-compose.yml + cli-version: 2 + run: build + matrix: + setup: + os: + - darwin + - linux + - windows + arch: + - amd64 + - arm64 + artifact_paths: + - ./dist/* - name: ":lambda: Build Lambda" key: build-lambda depends_on: - test command: .buildkite/steps/build-lambda.sh + plugins: + - docker-compose#v5.5.0: + config: .buildkite/docker-compose.yml + cli-version: 2 + run: build + artifact_paths: + - ./dist/* - name: ":s3: Upload to S3" key: upload-to-s3 diff --git a/.buildkite/steps/build-binary.sh b/.buildkite/steps/build-binary.sh index 2b3c6e38..fc912bc5 100755 --- a/.buildkite/steps/build-binary.sh +++ b/.buildkite/steps/build-binary.sh @@ -9,5 +9,5 @@ export GOOS export GOARCH export CGO_ENABLED=0 -go build -o "buildkite-agent-metrics-${GOOS}-${GOARCH}" . -buildkite-agent artifact upload "buildkite-agent-metrics-${GOOS}-${GOARCH}" +mkdir -p dist +go build -o "dist/buildkite-agent-metrics-${GOOS}-${GOARCH}" . diff --git a/.buildkite/steps/build-lambda.sh b/.buildkite/steps/build-lambda.sh index 6c843396..18b3670e 100755 --- a/.buildkite/steps/build-lambda.sh +++ b/.buildkite/steps/build-lambda.sh @@ -1,17 +1,9 @@ #!/usr/bin/env sh - set -eu -docker run --rm --volume "$PWD:/code" \ - --workdir /code \ - --rm \ - --env CGO_ENABLED=0 \ - golang:1.21 \ - go build -tags lambda.norpc -o lambda/bootstrap ./lambda +CGO_ENABLED=0 go build -tags lambda.norpc -o lambda/bootstrap ./lambda chmod +x lambda/bootstrap -mkdir -p dist/ -zip -j handler.zip lambda/bootstrap - -buildkite-agent artifact upload handler.zip +mkdir -p dist +zip -j dist/handler.zip lambda/bootstrap diff --git a/.github/dependabot.yml b/.github/dependabot.yml index 6a8bfe55..857dcf86 100644 --- a/.github/dependabot.yml +++ b/.github/dependabot.yml @@ -8,9 +8,11 @@ updates: reviewers: - "buildkite/pipelines-dispatch" - package-ecosystem: "docker" - directory: "/" + directories: + - "/" + - ".buildkite" schedule: interval: "weekly" open-pull-requests-limit: 2 reviewers: - - "buildkite/pipelines-dispatch" \ No newline at end of file + - "buildkite/pipelines-dispatch"