mirror of
https://github.com/kubernetes-sigs/kustomize.git
synced 2026-06-11 00:52:55 +00:00
Merge pull request #4751 from aibarbetta/fix-4717
[address #4717] create template/metadata when using includeTemplates if not present
This commit is contained in:
@@ -288,7 +288,7 @@ var transformerConfigurators = map[builtinhelpers.BuiltinPluginType]func(
|
|||||||
} else {
|
} else {
|
||||||
// merge spec/template/metadata fieldSpec if includeTemplate flag is true
|
// merge spec/template/metadata fieldSpec if includeTemplate flag is true
|
||||||
if label.IncludeTemplates {
|
if label.IncludeTemplates {
|
||||||
fss, err = fss.MergeOne(types.FieldSpec{Path: "spec/template/metadata/labels", CreateIfNotPresent: false})
|
fss, err = fss.MergeOne(types.FieldSpec{Path: "spec/template/metadata/labels", CreateIfNotPresent: true})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, errors.Wrap(err, "failed to merge template fieldSpec")
|
return nil, errors.Wrap(err, "failed to merge template fieldSpec")
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -160,3 +160,66 @@ spec:
|
|||||||
foo: bar
|
foo: bar
|
||||||
`)
|
`)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestKustomizationLabelsInTemplateWhenLabelsIsNil(t *testing.T) {
|
||||||
|
th := kusttest_test.MakeHarness(t)
|
||||||
|
th.WriteF("app/deployment.yaml", `
|
||||||
|
apiVersion: apps/v1
|
||||||
|
kind: Deployment
|
||||||
|
metadata:
|
||||||
|
name: deployment
|
||||||
|
spec:
|
||||||
|
replicas: 1
|
||||||
|
template:
|
||||||
|
spec:
|
||||||
|
containers:
|
||||||
|
- name: test-server
|
||||||
|
image: test-server
|
||||||
|
`)
|
||||||
|
th.WriteK("/app", `
|
||||||
|
resources:
|
||||||
|
- deployment.yaml
|
||||||
|
|
||||||
|
commonLabels:
|
||||||
|
app: test-server
|
||||||
|
|
||||||
|
labels:
|
||||||
|
- pairs:
|
||||||
|
app.kubernetes.io/component: a
|
||||||
|
app.kubernetes.io/instance: b
|
||||||
|
app.kubernetes.io/name: c
|
||||||
|
app.kubernetes.io/part-of: d
|
||||||
|
includeSelectors: false
|
||||||
|
includeTemplates: true
|
||||||
|
`)
|
||||||
|
m := th.Run("/app", th.MakeDefaultOptions())
|
||||||
|
th.AssertActualEqualsExpected(m, `
|
||||||
|
apiVersion: apps/v1
|
||||||
|
kind: Deployment
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: test-server
|
||||||
|
app.kubernetes.io/component: a
|
||||||
|
app.kubernetes.io/instance: b
|
||||||
|
app.kubernetes.io/name: c
|
||||||
|
app.kubernetes.io/part-of: d
|
||||||
|
name: deployment
|
||||||
|
spec:
|
||||||
|
replicas: 1
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: test-server
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: test-server
|
||||||
|
app.kubernetes.io/component: a
|
||||||
|
app.kubernetes.io/instance: b
|
||||||
|
app.kubernetes.io/name: c
|
||||||
|
app.kubernetes.io/part-of: d
|
||||||
|
spec:
|
||||||
|
containers:
|
||||||
|
- image: test-server
|
||||||
|
name: test-server
|
||||||
|
`)
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user