diff --git a/.circleci/config.yml b/.circleci/config.yml index e2fa808e6..7485d0566 100644 --- a/.circleci/config.yml +++ b/.circleci/config.yml @@ -8,7 +8,6 @@ executors: go: docker: - image: cimg/go:1.20 - resource_class: large environment: CGO_ENABLED: 0 mac: @@ -26,7 +25,7 @@ commands: # https://app.circleci.com/jobs/github/CircleCI-Public/circleci-cli/6480 # curl: (92) HTTP/2 stream 0 was not closed cleanly: PROTOCOL_ERROR (err 1) # The issue seems to be on the server-side, so force HTTP 1.1 - name: "cURL: Force HTTP 1.1" + name: 'cURL: Force HTTP 1.1' command: echo '--http1.1' >> ~/.curlrc build-docker-image: steps: @@ -42,31 +41,36 @@ commands: command: | docker build -t circleci/circleci-cli:0.1.$CIRCLE_BUILD_NUM-alpine --file Dockerfile.alpine . docker run --rm circleci/circleci-cli:0.1.$CIRCLE_BUILD_NUM-alpine update check - deploy-save-workspace-and-artifacts: + deploy-save-cache-workspace-and-artifacts: steps: + - save_cache: + key: v4-goreleaser-{{ checksum "~/goreleaser_amd64.deb" }} + paths: [~/goreleaser_amd64.deb] - persist_to_workspace: root: . paths: - - "dist" + - 'dist' - store_artifacts: path: ./dist destination: dist install-goreleaser: parameters: - version: + GORELEASER_URL: type: string - default: "1.19.1" + default: https://github.com/goreleaser/goreleaser/releases/download/v0.184.0/goreleaser_amd64.deb steps: + - restore_cache: + keys: [v5-goreleaser-] - run: name: Install GoReleaser command: | - echo 'deb [trusted=yes] https://repo.goreleaser.com/apt/ /' | sudo tee /etc/apt/sources.list.d/goreleaser.list - sudo apt -q update -y - sudo apt -q install -y --no-install-recommends goreleaser=<< parameters.version >> + [ -f ~/goreleaser_amd64.deb ] || curl --silent --location --fail --retry 3 << parameters.GORELEASER_URL >> > ~/goreleaser_amd64.deb + sudo apt-get update -y + sudo apt install ~/goreleaser_amd64.deb gomod: steps: - restore_cache: - keys: ["v3-gomod-{{ arch }}-"] + keys: ['v3-gomod-{{ arch }}-'] - run: name: Download go module dependencies command: go mod download @@ -117,7 +121,7 @@ jobs: - persist_to_workspace: root: . paths: - - "build" + - 'build' cucumber: docker: - image: cimg/ruby:2.7 @@ -126,7 +130,7 @@ jobs: - attach_workspace: at: . - run: - name: "Install CLI tool from workspace" + name: 'Install CLI tool from workspace' command: sudo cp ~/project/build/linux/amd64/circleci /usr/local/bin/ - run: command: bundle install @@ -205,7 +209,7 @@ jobs: docker_layer_caching: true - build-docker-image - build-alpine-image - - deploy-save-workspace-and-artifacts + - deploy-save-cache-workspace-and-artifacts deploy: executor: go @@ -242,7 +246,7 @@ jobs: docker push circleci/circleci-cli:0.1.$CIRCLE_BUILD_NUM-alpine docker tag circleci/circleci-cli:0.1.$CIRCLE_BUILD_NUM-alpine circleci/circleci-cli:alpine docker push circleci/circleci-cli:alpine - - deploy-save-workspace-and-artifacts + - deploy-save-cache-workspace-and-artifacts snap: docker: diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS index e8f4d8c1b..ec9fce118 100644 --- a/.github/CODEOWNERS +++ b/.github/CODEOWNERS @@ -1,5 +1,5 @@ * @CircleCI-Public/developer-experience *orb*.go @CircleCI-Public/orb-publishers @CircleCI-Public/developer-experience -/api/runner @CircleCI-Public/on-prem -/cmd/runner @CircleCI-Public/on-prem \ No newline at end of file +/api/runner @CircleCI-Public/runner +/cmd/runner @CircleCI-Public/runner diff --git a/Dockerfile b/Dockerfile index 88e84018c..7cdf842f2 100644 --- a/Dockerfile +++ b/Dockerfile @@ -4,4 +4,4 @@ LABEL maintainer="Developer Experience Team " ENV CIRCLECI_CLI_SKIP_UPDATE_CHECK true -COPY ./dist/circleci-cli_linux_amd64_v1/circleci /usr/local/bin +COPY ./dist/circleci-cli_linux_amd64/circleci /usr/local/bin diff --git a/Dockerfile.alpine b/Dockerfile.alpine index 0983ed58d..71240212d 100644 --- a/Dockerfile.alpine +++ b/Dockerfile.alpine @@ -2,7 +2,7 @@ FROM alpine:3.8 ENV CIRCLECI_CLI_SKIP_UPDATE_CHECK true -COPY ./dist/circleci-cli_linux_amd64_v1/circleci /usr/local/bin +COPY ./dist/circleci-cli_linux_amd64/circleci /usr/local/bin RUN apk add --no-cache --upgrade git openssh ca-certificates diff --git a/Makefile b/Makefile index a51a58c4a..604d50148 100644 --- a/Makefile +++ b/Makefile @@ -4,7 +4,7 @@ GOOS=$(shell go env GOOS) GOARCH=$(shell go env GOARCH) build: always - go build -o build/$(GOOS)/$(GOARCH)/circleci -ldflags='-X github.com/CircleCI-Public/circleci-cli/telemetry.SegmentEndpoint=https://api.segment.io' + go build -o build/$(GOOS)/$(GOARCH)/circleci build-all: build/linux/amd64/circleci build/darwin/amd64/circleci diff --git a/README.md b/README.md index b57b73873..a955cff70 100644 --- a/README.md +++ b/README.md @@ -180,20 +180,6 @@ Please see the [documentation](https://circleci-public.github.io/circleci-cli) o ## Server compatibility -| Functionality | Impacted commands | Change description | Compatibility with Server | -| --- | --- | --- | --- | -| Config compilation and validation |