Skip to content

Commit

Permalink
Add image substitutions in kustomization instead of doing a patch (#617)
Browse files Browse the repository at this point in the history
## Description
This PR refactors the `release-manifests` target to use `kustomize` to substitute the tink-controller and tink-servers images instead of using patches.

## Why is this needed
There was a bug in the previous `release-manifests` target where the tink-server image wasn't being updated because its dependencies were all being met already causing it to not be re-build. This PR refactors it to not use the image patches removing the need to update these patch files.

## How Has This Been Tested?
ran `make release-manifests` and verified that the kustomization.yaml and tink.yaml have the expected outputs

## How are existing users impacted? What migration steps/scripts do we need?
No user impact


## Checklist:

I have:

- [ ] updated the documentation and/or roadmap (if required)
- [ ] added unit or e2e tests
- [ ] provided instructions on how to upgrade
  • Loading branch information
mergify[bot] authored May 4, 2022
2 parents a0f65e9 + 54dffbb commit c9ebfa8
Show file tree
Hide file tree
Showing 4 changed files with 7 additions and 42 deletions.
4 changes: 0 additions & 4 deletions config/default/kustomization.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,3 @@ bases:
- ../manager
- ../server
- ../server-rbac

patchesStrategicMerge:
- manager_image.yaml
- server_image.yaml
12 changes: 0 additions & 12 deletions config/default/manager_image.yaml

This file was deleted.

12 changes: 0 additions & 12 deletions config/default/server_image.yaml

This file was deleted.

21 changes: 7 additions & 14 deletions kube.mk
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
## Generate
## --------------------------------------

PHONY: generate
.PHONY: generate
generate: generate-go generate-manifests # Generate code, manifests etc.

.PHONY: generate-go
Expand Down Expand Up @@ -40,25 +40,18 @@ generate-server-rbacs: bin/controller-gen
rbac:roleName=server-role
prettier --write ./config/server-rbac/

REGISTRY ?= quay.io/tinkerbell
TINK_SERVER_IMAGE_NAME ?= tink-server
TINK_CONTROLLER_IMAGE_NAME ?= tink-controller
TINK_SERVER_IMAGE_TAG ?= latest
TINK_CONTROLLER_IMAGE_TAG ?= latest

out/release/default/manager_image.yaml: config/default/manager_image.yaml out/release/default/kustomization.yaml
out/release/default/manager_image.yaml: TAG=$(REGISTRY)/$(TINK_CONTROLLER_IMAGE_NAME):$(TINK_CONTROLLER_IMAGE_TAG)
out/release/default/server_image.yaml: config/default/server_image.yaml out/release/default/kustomization.yaml
out/release/default/server_image.yaml: TAG=$(REGISTRY)/$(TINK_SERVER_IMAGE_NAME):$(TINK_SERVER_IMAGE_TAG)
out/release/default/manager_image.yaml out/release/default/server_image.yaml:
sed -e 's|image: .*|image: "$(TAG)"|' $^ >$@
TINK_SERVER_IMAGE ?= quay.io/tinkerbell/tink-server
TINK_CONTROLLER_IMAGE ?= quay.io/tinkerbell/tink-controller
TINK_SERVER_TAG ?= latest
TINK_CONTROLLER_TAG ?= latest

out/release/default/kustomization.yaml: config/default/kustomization.yaml
rm -rf out/
mkdir -p out/
cp -a config/ out/release/

out/release/tink.yaml: bin/kustomize generate-manifests out/release/default/manager_image.yaml out/release/default/manager_image.yaml
out/release/tink.yaml: bin/kustomize generate-manifests out/release/default/kustomization.yaml
(cd out/release/default && kustomize edit set image server=$(TINK_SERVER_IMAGE):$(TINK_CONTROLLER_TAG) controller=$(TINK_CONTROLLER_IMAGE):$(TINK_CONTROLLER_TAG))
kustomize build out/release/default -o $@
prettier --write $@

Expand Down

0 comments on commit c9ebfa8

Please sign in to comment.