From 33966450d93e0101ea1d9a5609ca79425ac7adda Mon Sep 17 00:00:00 2001 From: Simon Beck Date: Wed, 28 Aug 2024 15:44:24 +0200 Subject: [PATCH] Add CI Improvements --- .cruft.json | 20 ++ .github/changelog-configuration.json | 12 +- .github/workflows/cruft-update.yml | 79 +++++++ .github/workflows/pr.yml | 217 ++++++++++++++++++ .github/workflows/release.yml | 62 +++-- .gitignore | 1 - Makefile | 12 +- Makefile.vars.mk | 10 +- ci.mk | 53 +++++ kind/kind.mk | 4 +- ...ossplane.yaml.template => crossplane.yaml} | 2 - package/package.mk | 53 ----- test/local.mk | 8 +- 13 files changed, 424 insertions(+), 109 deletions(-) create mode 100644 .cruft.json create mode 100644 .github/workflows/cruft-update.yml create mode 100644 .github/workflows/pr.yml create mode 100644 ci.mk rename package/{crossplane.yaml.template => crossplane.yaml} (92%) delete mode 100644 package/package.mk diff --git a/.cruft.json b/.cruft.json new file mode 100644 index 0000000..d90c1a3 --- /dev/null +++ b/.cruft.json @@ -0,0 +1,20 @@ +{ + "template": "https://github.com/vshn/appcat-cookiecutter", + "commit": "6a18e430833adf8e515c6050b3ff20268fc47d25", + "checkout": null, + "context": { + "cookiecutter": { + "app_name": "provider-cloudscale", + "component_repo": "vshn/component-appcat", + "push_upbound": true, + "push_package": true, + "push_image": false, + "_copy_without_render": [ + ".github/workflows/cruft-update.yml", + ".github/changelog-configuration.json" + ], + "_template": "https://github.com/vshn/appcat-cookiecutter" + } + }, + "directory": null +} diff --git a/.github/changelog-configuration.json b/.github/changelog-configuration.json index 8c93e7b..02c9648 100644 --- a/.github/changelog-configuration.json +++ b/.github/changelog-configuration.json @@ -4,25 +4,19 @@ { "title": "## 🚀 Features", "labels": [ - "enhancement" - ] - }, - { - "title": "## 🛠️ Minor Changes", - "labels": [ - "change" + "minor" ] }, { "title": "## 🔎 Breaking Changes", "labels": [ - "breaking" + "major" ] }, { "title": "## 🐛 Fixes", "labels": [ - "bug" + "patch" ] }, { diff --git a/.github/workflows/cruft-update.yml b/.github/workflows/cruft-update.yml new file mode 100644 index 0000000..41e51b4 --- /dev/null +++ b/.github/workflows/cruft-update.yml @@ -0,0 +1,79 @@ +# /.github/workflows/cruft-update.yml +name: Update repository with Cruft +permissions: + contents: write + pull-requests: write + actions: write +on: + schedule: + - cron: "0 * * * *" # Once per hour + workflow_dispatch: {} + +jobs: + update: + runs-on: ubuntu-latest + strategy: + fail-fast: true + matrix: + include: + - add-paths: . + body: Use this to merge the changes to this repository. + branch: cruft/update + commit-message: "chore: accept new Cruft update" + title: New updates detected with Cruft + - add-paths: .cruft.json + body: Use this to reject the changes in this repository. + branch: cruft/reject + commit-message: "chore: reject new Cruft update" + title: Reject new updates detected with Cruft + steps: + - uses: actions/checkout@v4 + with: + token: ${{ secrets.COMPONENT_ACCESS_TOKEN }} + + - uses: actions/setup-python@v5 + with: + python-version: "3.10" + + - name: Install Cruft + run: pip3 install cruft + + - name: Check if update is available + continue-on-error: false + id: check + run: | + CHANGES=0 + if [ -f .cruft.json ]; then + if ! cruft check; then + CHANGES=1 + fi + else + echo "No .cruft.json file" + fi + + echo "has_changes=$CHANGES" >> "$GITHUB_OUTPUT" + + - name: Run update if available + if: steps.check.outputs.has_changes == '1' + run: | + git config --global user.email "githubbot@vshn.ch" + git config --global user.name "GitHubBot" + + cruft update --skip-apply-ask --refresh-private-variables + git restore --staged . + + - name: Create pull request + if: steps.check.outputs.has_changes == '1' + uses: peter-evans/create-pull-request@v6 + with: + token: ${{ secrets.COMPONENT_ACCESS_TOKEN }} + add-paths: ${{ matrix.add-paths }} + commit-message: ${{ matrix.commit-message }} + branch: ${{ matrix.branch }} + delete-branch: true + title: ${{ matrix.title }} + labels: dependencies + body: | + This is an autogenerated PR. ${{ matrix.body }} + + [Cruft](https://cruft.github.io/cruft/) has detected updates from the Cookiecutter repository. diff --git a/.github/workflows/pr.yml b/.github/workflows/pr.yml new file mode 100644 index 0000000..8b69e83 --- /dev/null +++ b/.github/workflows/pr.yml @@ -0,0 +1,217 @@ +name: PR Automation + +on: + pull_request: {} + pull_request_target: + types: + - closed + branches: + - master + +env: + APP_NAME: provider-cloudscale + COMPONENT_REPO: vshn/component-appcat + PUSH_UPBOUND: "True" + PUSH_PACKAGE: "True" + PUSH_IMAGE: "False" + +jobs: + check-labels: + # Act doesn't set a pull request number by default, so we skip if it's 0 + if: github.event.pull_request.number != 0 + name: Check labels + runs-on: ubuntu-latest + steps: + - uses: docker://agilepathway/pull-request-label-checker:v1.6.51 + with: + one_of: major,minor,patch,documentation,dependency + repo_token: ${{ secrets.GITHUB_TOKEN }} + publish-branch-images: + if: github.event.action != 'closed' + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + + - name: Determine Go version from go.mod + run: echo "GO_VERSION=$(grep "go 1." go.mod | cut -d " " -f 2)" >> $GITHUB_ENV + + - uses: actions/setup-go@v5 + with: + go-version: ${{ env.GO_VERSION }} + + - uses: actions/cache@v4 + with: + path: ~/go/pkg/mod + key: ${{ runner.os }}-go-${{ hashFiles('**/go.sum') }} + restore-keys: | + ${{ runner.os }}-go- + + - name: Extract escaped branch name + shell: bash + run: echo "branch=$(echo ${GITHUB_HEAD_REF:-${GITHUB_REF#refs/heads/}} | sed 's/\//_/g' )" >> $GITHUB_OUTPUT + id: extract_branch + + - name: Login to GHCR + uses: docker/login-action@v3 + with: + registry: ghcr.io + username: ${{ github.repository_owner }} + password: ${{ secrets.GITHUB_TOKEN }} + + - name: Build branch and push image + if: env.PUSH_IMAGE == 'true' + run: make docker-push-branchtag -e IMG_TAG="${{ steps.extract_branch.outputs.branch }}" + + - name: Build branch and push package + if: env.PUSH_PACKAGE == 'True' + run: make package-push-branchtag -e IMG_TAG="${{ steps.extract_branch.outputs.branch }}" + + - name: Login to Upbound + if: env.PUSH_UPBOUND == 'true' + uses: docker/login-action@v3 + with: + registry: xpkg.upbound.io + username: ${{ secrets.UPBOUND_MARKETPLACE_PUSH_ROBOT_USR }} + password: ${{ secrets.UPBOUND_MARKETPLACE_PUSH_ROBOT_PSW }} + + - name: Build branch and push package to upbound + if: env.PUSH_UPBOUND == 'true' && env.PUSH_PACKAGE == 'true' + run: make package-push-branchtag -e IMG_TAG="${{ steps.extract_branch.outputs.branch }}" -e IMG_REPO=xpkg.upbound.io + + open-pr-component: + if: github.event.action == 'opened' + runs-on: ubuntu-latest + steps: + - name: Checkout code + uses: actions/checkout@v4 + with: + repository: ${{ env.COMPONENT_REPO }} + token: ${{ secrets.GITHUB_TOKEN }} + + - name: Extract branch name + shell: bash + run: echo "branch=${GITHUB_HEAD_REF:-${GITHUB_REF#refs/heads/}}" >> $GITHUB_OUTPUT + id: extract_branch + + - name: Update defaults.yml and create branch + run: | + yq e '.parameters.appcat.images.${{ env.APP_NAME }}.tag="${{ steps.extract_branch.outputs.branch }}"' class/defaults.yml | diff -B class/defaults.yml - | patch class/defaults.yml - || true + + git --no-pager diff + + - name: Generate new golden + # Act uses the host's docker to run containers, but then + # they can't access the files that were previously cloned. + if: github.event.pull_request.number != 0 + run: | + make gen-golden-all + + - name: Create Pull Request + uses: peter-evans/create-pull-request@v6 + with: + token: ${{ secrets.COMPONENT_ACCESS_TOKEN }} + title: 'PR for ${{ env.APP_NAME }} on ${{ steps.extract_branch.outputs.branch }}' + body: "${{ github.event.pull_request.body}}\nLink: ${{ github.event.pull_request.url }}" + branch: "${{ env.APP_NAME }}/${{ github.event.pull_request.number }}/${{ steps.extract_branch.outputs.branch }}" + base: master + draft: false + create-release: + if: github.event.pull_request.merged + runs-on: ubuntu-latest + steps: + - name: Check for patch label + if: contains(github.event.pull_request.labels.*.name, 'patch') || contains(github.event.pull_request.labels.*.name, 'dependencies') || contains(github.event.pull_request.labels.*.name, 'documentation') + id: patch + run: | + echo "set=true" >> $GITHUB_OUTPUT + - name: Check for minor label + if: contains(github.event.pull_request.labels.*.name, 'minor') + id: minor + run: | + echo "set=true" >> $GITHUB_OUTPUT + - name: Check for major label + if: contains(github.event.pull_request.labels.*.name, 'major') + id: major + run: | + echo "set=true" >> $GITHUB_OUTPUT + + - uses: actions/checkout@v4 + with: + # Make sure we use the right commit to tag + ref: ${{ github.event.pull_request.merge_commit_sha }} + # We also need to use the personal access token here. As subsequent + # actions will not trigger by tags/pushes that use `GITHUB_TOKEN` + # https://github.com/orgs/community/discussions/25702#discussioncomment-3248819 + token: ${{ secrets.COMPONENT_ACCESS_TOKEN }} + # This is broken in checkout@v4... + # https://github.com/actions/checkout/issues/1781 + fetch-tags: true + + - name: fetch tags + run: | + git fetch --tags + echo "latest tag: $(git describe --tags "$(git rev-list --tags --max-count=1)")" + echo "TAG_VERSION=$(git describe --tags "$(git rev-list --tags --max-count=1)")" >> $GITHUB_ENV + + - name: Extract branch name + shell: bash + run: echo "branch=${GITHUB_HEAD_REF:-${GITHUB_REF#refs/heads/}}" >> $GITHUB_OUTPUT + id: extract_branch + + # We only run this if any of the release tags is set. + # For docs and deps we don't do automagic releases + - name: Increase Tag + id: tag + run: | + patch=${{ steps.patch.outputs.set }} + minor=${{ steps.minor.outputs.set }} + major=${{ steps.major.outputs.set }} + + major_ver=$(echo '${{ env.TAG_VERSION }}' | cut -d "." -f1) + minor_ver=$(echo '${{ env.TAG_VERSION }}' | cut -d "." -f2) + patch_ver=$(echo '${{ env.TAG_VERSION }}' | cut -d "." -f3) + + major_ver="${major_ver:1}" + + # Check for patch label + [ ! -z "$bug" ] && [ -z "$minor" ] && [ -z "$major" ] && ((patch_ver++)) || true + + # check for minor label + if [ ! -z "$minor" ] && [ -z "$major" ]; then + ((minor_ver++)) + patch_ver=0 + fi + + # Check for major label + if [ ! -z "$major" ]; then + ((major_ver++)) + minor_ver=0 + patch_ver=0 + fi + + tag="v$major_ver.$minor_ver.$patch_ver" + echo "new tag $tag" + git tag $tag + git push --tags + echo tag=$tag >> $GITHUB_OUTPUT + + - name: Checkout component + uses: actions/checkout@v4 + with: + repository: ${{ env.COMPONENT_REPO }} + token: ${{ secrets.COMPONENT_ACCESS_TOKEN }} + ref: "${{ env.APP_NAME }}/${{ github.event.pull_request.number }}/${{ steps.extract_branch.outputs.branch }}" + + - name: Update tag and run golden + run: | + yq e '.parameters.appcat.images.${{ env.APP_NAME }}.tag="${{ steps.tag.outputs.tag }}"' class/defaults.yml | diff -B class/defaults.yml - | patch class/defaults.yml - || true + make gen-golden-all + + - name: Commit & Push changes + uses: actions-js/push@master + with: + github_token: ${{ secrets.COMPONENT_ACCESS_TOKEN }} + branch: "${{ env.APP_NAME }}/${{ github.event.pull_request.number }}/${{ steps.extract_branch.outputs.branch }}" + message: "Update tag" + repository: ${{ env.COMPONENT_REPO }} + diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index 2c7a284..d3a56ec 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -3,71 +3,87 @@ name: Release on: push: tags: - - "v*" + - "*" + +env: + APP_NAME: provider-cloudscale + PUSH_UPBOUND: "True" + PUSH_PACKAGE: "True" + PUSH_IMAGE: "False" jobs: - goreleaser: + dist: runs-on: ubuntu-latest steps: - - uses: actions/checkout@v3 + + - uses: actions/checkout@v4 with: fetch-depth: 0 - name: Determine Go version from go.mod - run: echo "GO_VERSION=$(go mod edit -json | jq -r .Go)" >> $GITHUB_ENV + run: echo "GO_VERSION=$(grep "go 1." go.mod | cut -d " " -f 2)" >> $GITHUB_ENV - - uses: actions/setup-go@v3 + - uses: actions/setup-go@v5 with: go-version: ${{ env.GO_VERSION }} - name: Set up QEMU - uses: docker/setup-qemu-action@v2 + uses: docker/setup-qemu-action@v3 - name: Set up Docker Buildx - uses: docker/setup-buildx-action@v2 + uses: docker/setup-buildx-action@v3 - - uses: actions/cache@v3 + - uses: actions/cache@v4 with: path: ~/go/pkg/mod key: ${{ runner.os }}-go-${{ hashFiles('**/go.sum') }} restore-keys: | ${{ runner.os }}-go- + - name: Login to GHCR + uses: docker/login-action@v3 + with: + registry: ghcr.io + username: ${{ github.repository_owner }} + password: ${{ secrets.GITHUB_TOKEN }} + + - name: Push docker image + if: env.PUSH_IMAGE == 'true' + run: make docker-push -e IMG_TAG=${GITHUB_REF##*/} -e APP_NAME=${{ env.APP_NAME }} + + - name: Build and push function package + if: env.PUSH_PACKAGE == 'true' + run: make package-push -e IMG_TAG=${GITHUB_REF##*/} -e APP_NAME=${{ env.APP_NAME }} + - name: Login to Upbound + if: env.PUSH_UPBOUND == 'true' uses: docker/login-action@v1 with: registry: xpkg.upbound.io username: ${{ secrets.UPBOUND_MARKETPLACE_PUSH_ROBOT_USR }} password: ${{ secrets.UPBOUND_MARKETPLACE_PUSH_ROBOT_PSW }} - - name: Login to ghcr.io - uses: docker/login-action@v2 - with: - registry: ghcr.io - username: ${{ github.repository_owner }} - password: ${{ secrets.GITHUB_TOKEN }} - - - name: Push package image - run: make package-push -e IMG_TAG=${GITHUB_REF##*/} + - name: Build branch and push package to upbound + if: env.PUSH_UPBOUND == 'true' && env.PUSH_PACKAGE == 'true' + run: make package-push -e IMG_TAG=${GITHUB_REF##*/} -e APP_NAME=${{ env.APP_NAME }} -e IMG_REPO=xpkg.upbound.io - name: Build changelog from PRs with labels id: build_changelog - uses: mikepenz/release-changelog-builder-action@v3 + uses: mikepenz/release-changelog-builder-action@v5 with: configuration: ".github/changelog-configuration.json" # PreReleases still get a changelog, but the next full release gets a diff since the last full release, - # combining possible changelogs of all previous PreReleases in between. - # PreReleases show a partial changelog since last PreRelease. + # combining possible changelogs of all previous PreReleases in between. PreReleases show a partial changelog + # since last PreRelease. ignorePreReleases: "${{ !contains(github.ref, '-rc') }}" outputFile: .github/release-notes.md env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - name: Publish releases - uses: goreleaser/goreleaser-action@v3 + uses: goreleaser/goreleaser-action@v6 with: args: release --release-notes .github/release-notes.md env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - CONTAINER_REGISTRY: ghcr.io - IMAGE_NAME: ${{ github.repository }}/controller + diff --git a/.gitignore b/.gitignore index 0d09940..4000549 100644 --- a/.gitignore +++ b/.gitignore @@ -21,5 +21,4 @@ node_modules/ .cr-index/ # Crossplane package -/package/crossplane.yaml /package/*.xpkg diff --git a/Makefile b/Makefile index 59bfcb9..6d3a38a 100644 --- a/Makefile +++ b/Makefile @@ -20,6 +20,8 @@ include Makefile.vars.mk -include test/local.mk # Crossplane packaging -include package/package.mk +# CI automation +-include ci.mk golangci_bin = $(go_bin)/golangci-lint @@ -28,7 +30,7 @@ help: ## Show this help @grep -E -h '\s##\s' $(MAKEFILE_LIST) | sort | awk 'BEGIN {FS = ":.*?## "}; {printf "\033[36m%-20s\033[0m %s\n", $$1, $$2}' .PHONY: build -build: build-bin build-docker ## All-in-one build +build: build-bin docker-build ## All-in-one build .PHONY: build-bin build-bin: export CGO_ENABLED = 0 @@ -36,10 +38,6 @@ build-bin: fmt vet ## Build binary env CGO_ENABLED=0 GOOS=linux GOARCH=amd64 \ go build -o $(BIN_FILENAME) . -.PHONY: build-docker -build-docker: build-bin ## Build docker image - $(DOCKER_CMD) build --platform linux/amd64 -t $(CONTAINER_IMG) . - .PHONY: test test: test-go ## All-in-one test @@ -98,9 +96,9 @@ run-operator: ## Run in Operator mode against your current kube context go run . -v 1 operator .PHONY: clean -clean: .package-clean .envtest-clean .e2e-test-clean kind-clean ## Cleans local build artifacts +clean: .envtest-clean .e2e-test-clean kind-clean ## Cleans local build artifacts rm -rf docs/node_modules $(docs_out_dir) dist .cache .work - $(DOCKER_CMD) rmi $(CONTAINER_IMG) || true + $(DOCKER_CMD) rmi $(IMG) || true $(golangci_bin): | $(go_bin) curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s -- -b "$(go_bin)" diff --git a/Makefile.vars.mk b/Makefile.vars.mk index 89b9e76..42b5a12 100644 --- a/Makefile.vars.mk +++ b/Makefile.vars.mk @@ -1,9 +1,6 @@ ## These are some common variables for Make PROJECT_ROOT_DIR = . -# TODO: Adjust project meta -PROJECT_NAME ?= provider-cloudscale -PROJECT_OWNER ?= vshn ## BUILD:go BIN_FILENAME ?= provider-cloudscale @@ -19,10 +16,7 @@ CONTAINER_REGISTRY ?= ghcr.io UPBOUND_CONTAINER_REGISTRY ?= xpkg.upbound.io # Image URL to use all building/pushing image targets -CONTAINER_IMG ?= $(CONTAINER_REGISTRY)/$(PROJECT_OWNER)/$(PROJECT_NAME)/controller:$(IMG_TAG) -LOCAL_PACKAGE_IMG = localhost:5000/$(PROJECT_OWNER)/$(PROJECT_NAME)/package:$(IMG_TAG) -GHCR_PACKAGE_IMG ?= $(CONTAINER_REGISTRY)/$(PROJECT_OWNER)/$(PROJECT_NAME)/provider:$(IMG_TAG) -UPBOUND_PACKAGE_IMG ?= $(UPBOUND_CONTAINER_REGISTRY)/$(PROJECT_OWNER)/$(PROJECT_NAME):$(IMG_TAG) +LOCAL_PACKAGE_IMG = localhost:5000/$(ORG)/$(APP_NAME)/package:$(IMG_TAG) ## KIND:setup @@ -30,7 +24,7 @@ UPBOUND_PACKAGE_IMG ?= $(UPBOUND_CONTAINER_REGISTRY)/$(PROJECT_OWNER)/$(PROJECT_ KIND_NODE_VERSION ?= v1.24.0 KIND_IMAGE ?= docker.io/kindest/node:$(KIND_NODE_VERSION) KIND_KUBECONFIG ?= $(kind_dir)/kind-kubeconfig-$(KIND_NODE_VERSION) -KIND_CLUSTER ?= $(PROJECT_NAME)-$(KIND_NODE_VERSION) +KIND_CLUSTER ?= $(APP_NAME)-$(KIND_NODE_VERSION) # TEST:integration ENVTEST_ADDITIONAL_FLAGS ?= --bin-dir "$(kind_dir)" diff --git a/ci.mk b/ci.mk new file mode 100644 index 0000000..a63d1bc --- /dev/null +++ b/ci.mk @@ -0,0 +1,53 @@ +# Image URL to use all building/pushing image targets +IMG_TAG ?= latest +APP_NAME ?= provider-cloudscale +ORG ?= vshn +IMG_REPO ?= ghcr.io +IMG ?= $(IMG_REPO)/$(ORG)/$(APP_NAME):$(IMG_TAG) +DOCKER_CMD ?= docker + +# Upbound push config +UPBOUND_CONTAINER_REGISTRY ?= xpkg.upbound.io +UPBOUND_PACKAGE_IMG ?= $(UPBOUND_CONTAINER_REGISTRY)/$(ORG)/$(APP_NAME):$(IMG_TAG) + +# For alpine image it is required the following env before building the application +DOCKER_IMAGE_GOOS = linux +DOCKER_IMAGE_GOARCH = amd64 + +.PHONY: docker-build +docker-build: + env CGO_ENABLED=0 GOOS=$(DOCKER_IMAGE_GOOS) GOARCH=$(DOCKER_IMAGE_GOARCH) \ + go build -o ${BIN_FILENAME} + docker build --platform $(DOCKER_IMAGE_GOOS)/$(DOCKER_IMAGE_GOARCH) -t ${IMG} . + +.PHONY: docker-build-branchtag +IMG_TAG ?= $(shell git rev-parse --abbrev-ref HEAD | sed 's/\//_/g') +docker-build-branchtag: docker-build ## Build docker image with current branch name + +.PHONY: docker-push +docker-push: docker-build ## Push docker image with the manager. + docker push ${IMG} + +.PHONY: docker-push-branchtag +IMG_TAG ?= $(shell git rev-parse --abbrev-ref HEAD | sed 's/\//_/g') +docker-push-branchtag: docker-build-branchtag docker-push ## Push docker image with current branch name + +.PHONY: package-build +package-build: docker-build + rm -f package/*.xpkg + go run github.com/crossplane/crossplane/cmd/crank@v1.16.0 xpkg build -f package --verbose --embed-runtime-image=${IMG} -o package/package.xpkg + +.PHONY: package-push +package-push: package-build + go run github.com/crossplane/crossplane/cmd/crank@v1.16.0 xpkg push -f package/package.xpkg ${IMG} --verbose + +.PHONY: package-build-branchtag +IMG_TAG ?= $(shell git rev-parse --abbrev-ref HEAD | sed 's/\//_/g') +package-build-branchtag: docker-build-branchtag + rm -f package/*.xpkg + go run github.com/crossplane/crossplane/cmd/crank@v1.16.0 xpkg build -f package --verbose --embed-runtime-image=${IMG} -o package/package.xpkg + +.PHONY: package-push-package-branchtag +IMG_TAG ?= $(shell git rev-parse --abbrev-ref HEAD | sed 's/\//_/g') +package-push-branchtag: package-build-branchtag + go run github.com/crossplane/crossplane/cmd/crank@v1.16.0 xpkg push -f package/package.xpkg ${IMG} --verbose diff --git a/kind/kind.mk b/kind/kind.mk index ba92dfd..5ee0f77 100644 --- a/kind/kind.mk +++ b/kind/kind.mk @@ -25,8 +25,8 @@ kind-setup-ingress: kind-setup ## Install NGINX as ingress controller onto kind # We fix the arch to linux/amd64 since kind runs in amd64 even on Mac/arm. kind-load-image: export GOOS = linux kind-load-image: export GOARCH = amd64 -kind-load-image: kind-setup build-docker ## Load the container image onto kind cluster - @$(kind_bin) load docker-image --name $(KIND_CLUSTER) $(CONTAINER_IMG) +kind-load-image: kind-setup docker-build ## Load the container image onto kind cluster + @$(kind_bin) load docker-image --name $(KIND_CLUSTER) $(IMG) .PHONY: kind-clean kind-clean: export KUBECONFIG = $(KIND_KUBECONFIG) diff --git a/package/crossplane.yaml.template b/package/crossplane.yaml similarity index 92% rename from package/crossplane.yaml.template rename to package/crossplane.yaml index 8838cce..90d03e9 100644 --- a/package/crossplane.yaml.template +++ b/package/crossplane.yaml @@ -16,7 +16,5 @@ metadata: If you encounter an issue please create an issue in the [vshn/provider-cloudscale](https://github.com/vshn/provider-cloudscale/issues) repo. spec: - controller: - image: ghcr.io/vshn/provider-cloudscale/controller:latest crossplane: version: ">=v1.9.0" diff --git a/package/package.mk b/package/package.mk deleted file mode 100644 index 6375fd9..0000000 --- a/package/package.mk +++ /dev/null @@ -1,53 +0,0 @@ - -mkfile_path := $(abspath $(lastword $(MAKEFILE_LIST))) -package_dir := $(notdir $(patsubst %/,%,$(dir $(mkfile_path)))) - -crossplane_bin = $(go_bin)/kubectl-crossplane - -# Build kubectl-crossplane plugin -$(crossplane_bin):export GOBIN = $(go_bin) -$(crossplane_bin): | $(go_bin) - go install github.com/crossplane/crossplane/cmd/crank@latest - @mv $(go_bin)/crank $@ - -.PHONY: package -package: ## All-in-one packaging and releasing -package: package-push - -.PHONY: package-provider-local -package-provider-local: export CONTROLLER_IMG = $(CONTAINER_IMG) -package-provider-local: $(crossplane_bin) generate-go ## Build Crossplane package for local installation in kind-cluster - @rm -rf package/*.xpkg - @yq e '.spec.controller.image=strenv(CONTROLLER_IMG)' $(package_dir)/crossplane.yaml.template > $(package_dir)/crossplane.yaml - @$(crossplane_bin) xpkg build -f $(package_dir) - @echo Package file: $$(ls $(package_dir)/*.xpkg) - -.PHONY: package-provider -package-provider: export CONTROLLER_IMG = $(CONTAINER_IMG) -package-provider: $(crossplane_bin) generate-go build-docker ## Build Crossplane package for Upbound Marketplace - @rm -rf package/*.xpkg - @yq e 'del(.spec)' $(package_dir)/crossplane.yaml.template > $(package_dir)/crossplane.yaml - $(crossplane_bin) xpkg build -f $(package_dir) -o $(package_dir)/provider-cloudscale.xpkg --embed-runtime-image=$(CONTROLLER_IMG) - -.PHONY: .local-package-push -.local-package-push: pkg_file = $(shell ls $(package_dir)/*.xpkg) -.local-package-push: $(crossplane_bin) package-provider-local - $(crossplane_bin) xpkg push -f $(pkg_file) $(LOCAL_PACKAGE_IMG) - -.PHONY: .ghcr-package-push -.ghcr-package-push: pkg_file = $(package_dir)/provider-cloudscale.xpkg -.ghcr-package-push: $(crossplane_bin) package-provider - $(crossplane_bin) xpkg push -f $(pkg_file) $(GHCR_PACKAGE_IMG) - -.PHONY: .upbound-package-push -.upbound-package-push: pkg_file = $(package_dir)/provider-cloudscale.xpkg -.upbound-package-push: $(crossplane_bin) package-provider - $(crossplane_bin) xpkg push -f $(pkg_file) $(UPBOUND_PACKAGE_IMG) - -.PHONY: package-push -package-push: pkg_file = $(package_dir)/provider-cloudscale.xpkg -package-push: .ghcr-package-push .upbound-package-push ## Push Crossplane package to container registry - -.PHONY: .package-clean -.package-clean: - rm -f $(crossplane_bin) package/*.xpkg $(package_dir)/crossplane.yaml diff --git a/test/local.mk b/test/local.mk index 23152ce..89cde1f 100644 --- a/test/local.mk +++ b/test/local.mk @@ -4,8 +4,8 @@ registry_sentinel = $(kind_dir)/registry_sentinel .PHONY: local-install local-install: export KUBECONFIG = $(KIND_KUBECONFIG) # for ControllerConfig: -local-install: export INTERNAL_PACKAGE_IMG = registry.registry-system.svc.cluster.local:5000/$(PROJECT_OWNER)/$(PROJECT_NAME)/package:$(IMG_TAG) -local-install: kind-load-image crossplane-setup registry-setup .local-package-push ## Install Operator in local cluster +local-install: export INTERNAL_PACKAGE_IMG = registry.registry-system.svc.cluster.local:5000/$(ORG)/$(APP_NAME)/package:$(IMG_TAG) +local-install: kind-load-image crossplane-setup registry-setup package-push-local ## Install Operator in local cluster yq e '.spec.metadata.annotations."local.dev/installed"="$(shell date)"' test/controllerconfig-cloudscale.yaml | kubectl apply -f - yq e '.spec.package=strenv(INTERNAL_PACKAGE_IMG)' test/provider-cloudscale.yaml | kubectl apply -f - kubectl wait --for condition=Healthy provider.pkg.crossplane.io/provider-cloudscale --timeout 60s @@ -130,6 +130,6 @@ test-e2e: $(kuttl_bin) $(mc_bin) local-install provider-config ## E2E tests .PHONY: .e2e-test-clean .e2e-test-clean: export KUBECONFIG = $(KIND_KUBECONFIG) .e2e-test-clean: - if [ -f $(KIND_KUBECONFIG) ]; then kubectl delete buckets --all; else echo "no kubeconfig found"; fi - if [ -f $(KIND_KUBECONFIG) ]; then kubectl delete objectsuser --all; else echo "no kubeconfig found"; fi + if [ -f $(KIND_KUBECONFIG) ]; then kubectl delete buckets --all; else echo "no kubeconfig found"; fi || true + if [ -f $(KIND_KUBECONFIG) ]; then kubectl delete objectsuser --all; else echo "no kubeconfig found"; fi || true rm -f $(kuttl_bin) $(mc_bin)