Skip to content

Commit

Permalink
Replaced deprecated fields in Kustomization
Browse files Browse the repository at this point in the history
When running `kustomize build`, we currently see some warnings. Get rid
of these by using the more modern replacements. See [docs][0].

```
Warning: 'commonLabels' is deprecated. Please use 'labels' instead.
Warning: 'vars' is deprecated. Please use 'replacements' instead.
```

[0]: https://kubectl.docs.kubernetes.io/references/kustomize/kustomization/
  • Loading branch information
benwh committed Nov 27, 2024
1 parent aec5d53 commit dc1684f
Show file tree
Hide file tree
Showing 4 changed files with 46 additions and 13 deletions.
23 changes: 23 additions & 0 deletions config/acceptance/kustomization.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -12,3 +12,26 @@ patchesStrategicMerge:
- overlays/rbac-manager.yaml
- overlays/vault-manager.yaml
- overlays/workloads-manager.yaml

# Sadly we must repeat the replacement as in our root Kustomization, because we've
# overriden the image field, and there's no way to get Kustomize to run the (merged) replacements
# after (merged) patches.
replacements:
- source:
fieldPath: spec.template.spec.containers.[name=manager].image
group: apps
version: v1
kind: StatefulSet
name: theatre-vault-manager
namespace: theatre-system
targets:
- select:
group: apps
kind: StatefulSet
name: vault-manager
version: v1
fieldPaths:
- spec.template.spec.containers.0.args.0
options:
delimiter: =
index: 1
3 changes: 0 additions & 3 deletions config/acceptance/overlays/vault-manager.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -11,9 +11,6 @@ spec:
- name: manager
image: theatre:latest
imagePullPolicy: Never
args:
- --theatre-image=$(THEATRE_IMAGE)
- --metrics-address=0.0.0.0
resources:
requests:
cpu: "100m"
31 changes: 22 additions & 9 deletions config/base/kustomization.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -5,8 +5,10 @@ kind: Kustomization
namespace: theatre-system
namePrefix: theatre-

commonLabels:
app: theatre
labels:
- includeSelectors: true
pairs:
app: theatre

resources:
- crds/rbac.crd.gocardless.com_directoryrolebindings.yaml
Expand All @@ -22,16 +24,27 @@ resources:
- rbac/leader-election.yaml
- cert-manager/certificate.yaml

vars:
replacements:
# We want our mutating webhook to ensure it only ever configures pods to use
# the same image as it is running itself. If we ensure this, we don't need to
# worry about maintaining compatibility between versions of the webhook and
# theatre-secrets, as both will use the same version and be deployed
# atomically.
- name: THEATRE_IMAGE
objref:
apiVersion: apps/v1
- source:
fieldPath: spec.template.spec.containers.[name=manager].image
group: apps
version: v1
kind: StatefulSet
name: vault-manager
fieldref:
fieldpath: spec.template.spec.containers[0].image
name: theatre-vault-manager
namespace: theatre-system
targets:
- select:
group: apps
kind: StatefulSet
name: vault-manager
version: v1
fieldPaths:
- spec.template.spec.containers.0.args.0
options:
delimiter: =
index: 1
2 changes: 1 addition & 1 deletion config/base/managers/vault.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -113,7 +113,7 @@ spec:
- command:
- /usr/local/bin/vault-manager
args:
- --theatre-image=$(THEATRE_IMAGE)
- --theatre-image=THEATRE_IMAGE_PLACEHOLDER
- --metrics-address=0.0.0.0
image: eu.gcr.io/gc-containers/gocardless/theatre:latest
imagePullPolicy: Always
Expand Down

0 comments on commit dc1684f

Please sign in to comment.