mirror of
https://github.com/kubernetes-sigs/kustomize.git
synced 2026-06-11 17:12:51 +00:00
Merge pull request #655 from monopole/makeTestHarness
Make KustTarget test harness to reduce boilerplate.
This commit is contained in:
@@ -18,8 +18,6 @@ package target
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"sigs.k8s.io/kustomize/pkg/internal/loadertest"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
// TODO(monopole): Add a feature test example covering secret generation.
|
// TODO(monopole): Add a feature test example covering secret generation.
|
||||||
@@ -37,8 +35,8 @@ import (
|
|||||||
// To eventually fix this, we could write the data to a real filesystem, and
|
// To eventually fix this, we could write the data to a real filesystem, and
|
||||||
// clean up after, or use some other trick compatible with exec.
|
// clean up after, or use some other trick compatible with exec.
|
||||||
|
|
||||||
func writeMediumBase(t *testing.T, ldr loadertest.FakeLoader) {
|
func writeMediumBase(th *KustTestHarness) {
|
||||||
writeK(t, ldr, "/app/base", `
|
th.writeK("/app/base", `
|
||||||
namePrefix: baseprefix-
|
namePrefix: baseprefix-
|
||||||
commonLabels:
|
commonLabels:
|
||||||
foo: bar
|
foo: bar
|
||||||
@@ -48,7 +46,7 @@ resources:
|
|||||||
- deployment/deployment.yaml
|
- deployment/deployment.yaml
|
||||||
- service/service.yaml
|
- service/service.yaml
|
||||||
`)
|
`)
|
||||||
writeF(t, ldr, "/app/base/service/service.yaml", `
|
th.writeF("/app/base/service/service.yaml", `
|
||||||
apiVersion: v1
|
apiVersion: v1
|
||||||
kind: Service
|
kind: Service
|
||||||
metadata:
|
metadata:
|
||||||
@@ -61,7 +59,7 @@ spec:
|
|||||||
selector:
|
selector:
|
||||||
app: mungebot
|
app: mungebot
|
||||||
`)
|
`)
|
||||||
writeF(t, ldr, "/app/base/deployment/deployment.yaml", `
|
th.writeF("/app/base/deployment/deployment.yaml", `
|
||||||
apiVersion: extensions/v1beta1
|
apiVersion: extensions/v1beta1
|
||||||
kind: Deployment
|
kind: Deployment
|
||||||
metadata:
|
metadata:
|
||||||
@@ -87,20 +85,13 @@ spec:
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestMediumBase(t *testing.T) {
|
func TestMediumBase(t *testing.T) {
|
||||||
ldr := loadertest.NewFakeLoader("/app/base")
|
th := NewKustTestHarness(t, "/app/base")
|
||||||
writeMediumBase(t, ldr)
|
writeMediumBase(th)
|
||||||
m, err := makeKustTarget(t, ldr).MakeCustomizedResMap()
|
m, err := th.makeKustTarget().MakeCustomizedResMap()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("Err: %v", err)
|
t.Fatalf("Err: %v", err)
|
||||||
}
|
}
|
||||||
if m == nil {
|
th.assertActualEqualsExpected(m, `apiVersion: v1
|
||||||
t.Fatalf("Empty map.")
|
|
||||||
}
|
|
||||||
s, err := m.EncodeAsYaml()
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("Err: %v", err)
|
|
||||||
}
|
|
||||||
assertExpectedEqualsActual(t, s, `apiVersion: v1
|
|
||||||
kind: Service
|
kind: Service
|
||||||
metadata:
|
metadata:
|
||||||
annotations:
|
annotations:
|
||||||
@@ -150,9 +141,9 @@ spec:
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestMediumOverlay(t *testing.T) {
|
func TestMediumOverlay(t *testing.T) {
|
||||||
ldr := loadertest.NewFakeLoader("/app/overlay")
|
th := NewKustTestHarness(t, "/app/overlay")
|
||||||
writeMediumBase(t, ldr)
|
writeMediumBase(th)
|
||||||
writeK(t, ldr, "/app/overlay", `
|
th.writeK("/app/overlay", `
|
||||||
namePrefix: test-infra-
|
namePrefix: test-infra-
|
||||||
commonLabels:
|
commonLabels:
|
||||||
app: mungebot
|
app: mungebot
|
||||||
@@ -174,15 +165,15 @@ imageTags:
|
|||||||
- name: nginx
|
- name: nginx
|
||||||
newTag: 1.8.0`)
|
newTag: 1.8.0`)
|
||||||
|
|
||||||
writeF(t, ldr, "/app/overlay/configmap/app.env", `
|
th.writeF("/app/overlay/configmap/app.env", `
|
||||||
DB_USERNAME=admin
|
DB_USERNAME=admin
|
||||||
DB_PASSWORD=somepw
|
DB_PASSWORD=somepw
|
||||||
`)
|
`)
|
||||||
writeF(t, ldr, "/app/overlay/configmap/app-init.ini", `
|
th.writeF("/app/overlay/configmap/app-init.ini", `
|
||||||
FOO=bar
|
FOO=bar
|
||||||
BAR=baz
|
BAR=baz
|
||||||
`)
|
`)
|
||||||
writeF(t, ldr, "/app/overlay/deployment/deployment.yaml", `
|
th.writeF("/app/overlay/deployment/deployment.yaml", `
|
||||||
apiVersion: extensions/v1beta1
|
apiVersion: extensions/v1beta1
|
||||||
kind: Deployment
|
kind: Deployment
|
||||||
metadata:
|
metadata:
|
||||||
@@ -215,15 +206,11 @@ spec:
|
|||||||
name: app-env
|
name: app-env
|
||||||
name: app-env
|
name: app-env
|
||||||
`)
|
`)
|
||||||
m, err := makeKustTarget(t, ldr).MakeCustomizedResMap()
|
m, err := th.makeKustTarget().MakeCustomizedResMap()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("Err: %v", err)
|
t.Fatalf("Err: %v", err)
|
||||||
}
|
}
|
||||||
s, err := m.EncodeAsYaml()
|
th.assertActualEqualsExpected(m, `apiVersion: v1
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("Unexpected err: %v", err)
|
|
||||||
}
|
|
||||||
assertExpectedEqualsActual(t, s, `apiVersion: v1
|
|
||||||
data:
|
data:
|
||||||
app-init.ini: |2
|
app-init.ini: |2
|
||||||
|
|
||||||
|
|||||||
@@ -18,12 +18,10 @@ package target
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"sigs.k8s.io/kustomize/pkg/internal/loadertest"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func writeSmallBase(t *testing.T, ldr loadertest.FakeLoader) {
|
func writeSmallBase(th *KustTestHarness) {
|
||||||
writeK(t, ldr, "/app/base", `
|
th.writeK("/app/base", `
|
||||||
namePrefix: a-
|
namePrefix: a-
|
||||||
commonLabels:
|
commonLabels:
|
||||||
app: myApp
|
app: myApp
|
||||||
@@ -31,7 +29,7 @@ resources:
|
|||||||
- deployment.yaml
|
- deployment.yaml
|
||||||
- service.yaml
|
- service.yaml
|
||||||
`)
|
`)
|
||||||
writeF(t, ldr, "/app/base/service.yaml", `
|
th.writeF("/app/base/service.yaml", `
|
||||||
apiVersion: v1
|
apiVersion: v1
|
||||||
kind: Service
|
kind: Service
|
||||||
metadata:
|
metadata:
|
||||||
@@ -42,7 +40,7 @@ spec:
|
|||||||
ports:
|
ports:
|
||||||
- port: 7002
|
- port: 7002
|
||||||
`)
|
`)
|
||||||
writeF(t, ldr, "/app/base/deployment.yaml", `
|
th.writeF("/app/base/deployment.yaml", `
|
||||||
apiVersion: apps/v1
|
apiVersion: apps/v1
|
||||||
kind: Deployment
|
kind: Deployment
|
||||||
metadata:
|
metadata:
|
||||||
@@ -60,20 +58,13 @@ spec:
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestSmallBase(t *testing.T) {
|
func TestSmallBase(t *testing.T) {
|
||||||
ldr := loadertest.NewFakeLoader("/app/base")
|
th := NewKustTestHarness(t, "/app/base")
|
||||||
writeSmallBase(t, ldr)
|
writeSmallBase(th)
|
||||||
m, err := makeKustTarget(t, ldr).MakeCustomizedResMap()
|
m, err := th.makeKustTarget().MakeCustomizedResMap()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("Err: %v", err)
|
t.Fatalf("Err: %v", err)
|
||||||
}
|
}
|
||||||
if m == nil {
|
th.assertActualEqualsExpected(m, `apiVersion: v1
|
||||||
t.Fatalf("Empty map.")
|
|
||||||
}
|
|
||||||
s, err := m.EncodeAsYaml()
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("Err: %v", err)
|
|
||||||
}
|
|
||||||
assertExpectedEqualsActual(t, s, `apiVersion: v1
|
|
||||||
kind: Service
|
kind: Service
|
||||||
metadata:
|
metadata:
|
||||||
labels:
|
labels:
|
||||||
@@ -109,9 +100,9 @@ spec:
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestSmallOverlay(t *testing.T) {
|
func TestSmallOverlay(t *testing.T) {
|
||||||
ldr := loadertest.NewFakeLoader("/app/overlay")
|
th := NewKustTestHarness(t, "/app/overlay")
|
||||||
writeSmallBase(t, ldr)
|
writeSmallBase(th)
|
||||||
writeK(t, ldr, "/app/overlay", `
|
th.writeK("/app/overlay", `
|
||||||
namePrefix: b-
|
namePrefix: b-
|
||||||
commonLabels:
|
commonLabels:
|
||||||
env: prod
|
env: prod
|
||||||
@@ -123,15 +114,15 @@ imageTags:
|
|||||||
- name: whatever
|
- name: whatever
|
||||||
newTag: 1.8.0`)
|
newTag: 1.8.0`)
|
||||||
|
|
||||||
writeF(t, ldr, "/app/overlay/configmap/app.env", `
|
th.writeF("/app/overlay/configmap/app.env", `
|
||||||
DB_USERNAME=admin
|
DB_USERNAME=admin
|
||||||
DB_PASSWORD=somepw
|
DB_PASSWORD=somepw
|
||||||
`)
|
`)
|
||||||
writeF(t, ldr, "/app/overlay/configmap/app-init.ini", `
|
th.writeF("/app/overlay/configmap/app-init.ini", `
|
||||||
FOO=bar
|
FOO=bar
|
||||||
BAR=baz
|
BAR=baz
|
||||||
`)
|
`)
|
||||||
writeF(t, ldr, "/app/overlay/deployment/deployment.yaml", `
|
th.writeF("/app/overlay/deployment/deployment.yaml", `
|
||||||
apiVersion: apps/v1
|
apiVersion: apps/v1
|
||||||
kind: Deployment
|
kind: Deployment
|
||||||
metadata:
|
metadata:
|
||||||
@@ -139,15 +130,11 @@ metadata:
|
|||||||
spec:
|
spec:
|
||||||
replicas: 1000
|
replicas: 1000
|
||||||
`)
|
`)
|
||||||
m, err := makeKustTarget(t, ldr).MakeCustomizedResMap()
|
m, err := th.makeKustTarget().MakeCustomizedResMap()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("Err: %v", err)
|
t.Fatalf("Err: %v", err)
|
||||||
}
|
}
|
||||||
s, err := m.EncodeAsYaml()
|
th.assertActualEqualsExpected(m, `apiVersion: v1
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("Unexpected err: %v", err)
|
|
||||||
}
|
|
||||||
assertExpectedEqualsActual(t, s, `apiVersion: v1
|
|
||||||
kind: Service
|
kind: Service
|
||||||
metadata:
|
metadata:
|
||||||
labels:
|
labels:
|
||||||
|
|||||||
@@ -23,10 +23,8 @@ import (
|
|||||||
"strings"
|
"strings"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"sigs.k8s.io/kustomize/k8sdeps/kunstruct"
|
|
||||||
"sigs.k8s.io/kustomize/pkg/gvk"
|
"sigs.k8s.io/kustomize/pkg/gvk"
|
||||||
"sigs.k8s.io/kustomize/pkg/ifc"
|
"sigs.k8s.io/kustomize/pkg/ifc"
|
||||||
"sigs.k8s.io/kustomize/pkg/internal/loadertest"
|
|
||||||
"sigs.k8s.io/kustomize/pkg/resid"
|
"sigs.k8s.io/kustomize/pkg/resid"
|
||||||
"sigs.k8s.io/kustomize/pkg/resmap"
|
"sigs.k8s.io/kustomize/pkg/resmap"
|
||||||
"sigs.k8s.io/kustomize/pkg/resource"
|
"sigs.k8s.io/kustomize/pkg/resource"
|
||||||
@@ -91,27 +89,17 @@ metadata:
|
|||||||
]`
|
]`
|
||||||
)
|
)
|
||||||
|
|
||||||
var rf = resmap.NewFactory(resource.NewFactory(
|
|
||||||
kunstruct.NewKunstructuredFactoryImpl()))
|
|
||||||
|
|
||||||
var deploy = gvk.Gvk{Group: "apps", Version: "v1", Kind: "Deployment"}
|
|
||||||
var cmap = gvk.Gvk{Version: "v1", Kind: "ConfigMap"}
|
|
||||||
var secret = gvk.Gvk{Version: "v1", Kind: "Secret"}
|
|
||||||
var ns = gvk.Gvk{Version: "v1", Kind: "Namespace"}
|
|
||||||
|
|
||||||
func makeALoader(t *testing.T) ifc.Loader {
|
|
||||||
ldr := loadertest.NewFakeLoader("/testpath")
|
|
||||||
writeK(t, ldr, "/testpath/", kustomizationContent1)
|
|
||||||
writeF(t, ldr, "/testpath/deployment.yaml", deploymentContent)
|
|
||||||
writeF(t, ldr, "/testpath/namespace.yaml", namespaceContent)
|
|
||||||
writeF(t, ldr, "/testpath/jsonpatch.json", jsonpatchContent)
|
|
||||||
return ldr
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestResources1(t *testing.T) {
|
func TestResources1(t *testing.T) {
|
||||||
|
th := NewKustTestHarness(t, "/whatever")
|
||||||
|
th.writeK("/whatever/", kustomizationContent1)
|
||||||
|
th.writeF("/whatever/deployment.yaml", deploymentContent)
|
||||||
|
th.writeF("/whatever/namespace.yaml", namespaceContent)
|
||||||
|
th.writeF("/whatever/jsonpatch.json", jsonpatchContent)
|
||||||
|
|
||||||
expected := resmap.ResMap{
|
expected := resmap.ResMap{
|
||||||
resid.NewResIdWithPrefixSuffixNamespace(
|
resid.NewResIdWithPrefixSuffixNamespace(
|
||||||
deploy, "dply1", "foo-", "-bar", "ns1"): rf.RF().FromMap(
|
gvk.Gvk{Group: "apps", Version: "v1", Kind: "Deployment"},
|
||||||
|
"dply1", "foo-", "-bar", "ns1"): th.fromMap(
|
||||||
map[string]interface{}{
|
map[string]interface{}{
|
||||||
"apiVersion": "apps/v1",
|
"apiVersion": "apps/v1",
|
||||||
"kind": "Deployment",
|
"kind": "Deployment",
|
||||||
@@ -145,7 +133,8 @@ func TestResources1(t *testing.T) {
|
|||||||
},
|
},
|
||||||
}),
|
}),
|
||||||
resid.NewResIdWithPrefixSuffixNamespace(
|
resid.NewResIdWithPrefixSuffixNamespace(
|
||||||
cmap, "literalConfigMap", "foo-", "-bar", "ns1"): rf.RF().FromMap(
|
gvk.Gvk{Version: "v1", Kind: "ConfigMap"},
|
||||||
|
"literalConfigMap", "foo-", "-bar", "ns1"): th.fromMap(
|
||||||
map[string]interface{}{
|
map[string]interface{}{
|
||||||
"apiVersion": "v1",
|
"apiVersion": "v1",
|
||||||
"kind": "ConfigMap",
|
"kind": "ConfigMap",
|
||||||
@@ -165,7 +154,8 @@ func TestResources1(t *testing.T) {
|
|||||||
},
|
},
|
||||||
}).SetBehavior(ifc.BehaviorCreate),
|
}).SetBehavior(ifc.BehaviorCreate),
|
||||||
resid.NewResIdWithPrefixSuffixNamespace(
|
resid.NewResIdWithPrefixSuffixNamespace(
|
||||||
secret, "secret", "foo-", "-bar", "ns1"): rf.RF().FromMap(
|
gvk.Gvk{Version: "v1", Kind: "Secret"},
|
||||||
|
"secret", "foo-", "-bar", "ns1"): th.fromMap(
|
||||||
map[string]interface{}{
|
map[string]interface{}{
|
||||||
"apiVersion": "v1",
|
"apiVersion": "v1",
|
||||||
"kind": "Secret",
|
"kind": "Secret",
|
||||||
@@ -186,7 +176,8 @@ func TestResources1(t *testing.T) {
|
|||||||
},
|
},
|
||||||
}).SetBehavior(ifc.BehaviorCreate),
|
}).SetBehavior(ifc.BehaviorCreate),
|
||||||
resid.NewResIdWithPrefixSuffixNamespace(
|
resid.NewResIdWithPrefixSuffixNamespace(
|
||||||
ns, "ns1", "foo-", "-bar", ""): rf.RF().FromMap(
|
gvk.Gvk{Version: "v1", Kind: "Namespace"},
|
||||||
|
"ns1", "foo-", "-bar", ""): th.fromMap(
|
||||||
map[string]interface{}{
|
map[string]interface{}{
|
||||||
"apiVersion": "v1",
|
"apiVersion": "v1",
|
||||||
"kind": "Namespace",
|
"kind": "Namespace",
|
||||||
@@ -201,8 +192,7 @@ func TestResources1(t *testing.T) {
|
|||||||
},
|
},
|
||||||
}),
|
}),
|
||||||
}
|
}
|
||||||
actual, err := makeKustTarget(
|
actual, err := th.makeKustTarget().MakeCustomizedResMap()
|
||||||
t, makeALoader(t)).MakeCustomizedResMap()
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("unexpected Resources error %v", err)
|
t.Fatalf("unexpected Resources error %v", err)
|
||||||
}
|
}
|
||||||
@@ -214,9 +204,9 @@ func TestResources1(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestResourceNotFound(t *testing.T) {
|
func TestResourceNotFound(t *testing.T) {
|
||||||
l := loadertest.NewFakeLoader("/testpath")
|
th := NewKustTestHarness(t, "/whatever")
|
||||||
writeK(t, l, "/testpath", kustomizationContent1)
|
th.writeK("/whatever", kustomizationContent1)
|
||||||
_, err := makeKustTarget(t, l).MakeCustomizedResMap()
|
_, err := th.makeKustTarget().MakeCustomizedResMap()
|
||||||
if err == nil {
|
if err == nil {
|
||||||
t.Fatalf("Didn't get the expected error for an unknown resource")
|
t.Fatalf("Didn't get the expected error for an unknown resource")
|
||||||
}
|
}
|
||||||
@@ -226,9 +216,9 @@ func TestResourceNotFound(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestSecretTimeout(t *testing.T) {
|
func TestSecretTimeout(t *testing.T) {
|
||||||
l := loadertest.NewFakeLoader("/testpath")
|
th := NewKustTestHarness(t, "/whatever")
|
||||||
writeK(t, l, "/testpath", kustomizationContent2)
|
th.writeK("/whatever", kustomizationContent2)
|
||||||
_, err := makeKustTarget(t, l).MakeCustomizedResMap()
|
_, err := th.makeKustTarget().MakeCustomizedResMap()
|
||||||
if err == nil {
|
if err == nil {
|
||||||
t.Fatalf("Didn't get the expected error for an unknown resource")
|
t.Fatalf("Didn't get the expected error for an unknown resource")
|
||||||
}
|
}
|
||||||
@@ -247,8 +237,13 @@ func findSecret(m resmap.ResMap) *resource.Resource {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestDisableNameSuffixHash(t *testing.T) {
|
func TestDisableNameSuffixHash(t *testing.T) {
|
||||||
kt := makeKustTarget(t, makeALoader(t))
|
th := NewKustTestHarness(t, "/whatever")
|
||||||
|
th.writeK("/whatever/", kustomizationContent1)
|
||||||
|
th.writeF("/whatever/deployment.yaml", deploymentContent)
|
||||||
|
th.writeF("/whatever/namespace.yaml", namespaceContent)
|
||||||
|
th.writeF("/whatever/jsonpatch.json", jsonpatchContent)
|
||||||
|
|
||||||
|
kt := th.makeKustTarget()
|
||||||
m, err := kt.MakeCustomizedResMap()
|
m, err := kt.MakeCustomizedResMap()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("unexpected Resources error %v", err)
|
t.Fatalf("unexpected Resources error %v", err)
|
||||||
@@ -277,28 +272,25 @@ func TestDisableNameSuffixHash(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestIssue596AllowDirectoriesThatAreSubstringsOfEachOther(t *testing.T) {
|
func TestIssue596AllowDirectoriesThatAreSubstringsOfEachOther(t *testing.T) {
|
||||||
ldr := loadertest.NewFakeLoader(
|
th := NewKustTestHarness(t, "/app/overlays/aws-sandbox2.us-east-1")
|
||||||
"/app/overlays/aws-sandbox2.us-east-1")
|
th.writeK("/app/base", "")
|
||||||
writeK(t, ldr, "/app/base", "")
|
th.writeK("/app/overlays/aws", `
|
||||||
writeK(t, ldr, "/app/overlays/aws", `
|
|
||||||
bases:
|
bases:
|
||||||
- ../../base
|
- ../../base
|
||||||
`)
|
`)
|
||||||
writeK(t, ldr, "/app/overlays/aws-nonprod", `
|
th.writeK("/app/overlays/aws-nonprod", `
|
||||||
bases:
|
bases:
|
||||||
- ../aws
|
- ../aws
|
||||||
`)
|
`)
|
||||||
writeK(t, ldr, "/app/overlays/aws-sandbox2.us-east-1", `
|
th.writeK("/app/overlays/aws-sandbox2.us-east-1", `
|
||||||
bases:
|
bases:
|
||||||
- ../aws-nonprod
|
- ../aws-nonprod
|
||||||
`)
|
`)
|
||||||
m, err := makeKustTarget(t, ldr).MakeCustomizedResMap()
|
m, err := th.makeKustTarget().MakeCustomizedResMap()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("Err: %v", err)
|
t.Fatalf("Err: %v", err)
|
||||||
}
|
}
|
||||||
if m == nil {
|
th.assertActualEqualsExpected(m, "")
|
||||||
t.Fatalf("Empty map.")
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// To simplify tests, these vars specified in alphabetical order.
|
// To simplify tests, these vars specified in alphabetical order.
|
||||||
@@ -336,9 +328,8 @@ var someVars = []types.Var{
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestGetAllVarsSimple(t *testing.T) {
|
func TestGetAllVarsSimple(t *testing.T) {
|
||||||
ldr := loadertest.NewFakeLoader(
|
th := NewKustTestHarness(t, "/app")
|
||||||
"/app")
|
th.writeK("/app", `
|
||||||
writeK(t, ldr, "/app", `
|
|
||||||
vars:
|
vars:
|
||||||
- name: AWARD
|
- name: AWARD
|
||||||
objref:
|
objref:
|
||||||
@@ -353,7 +344,7 @@ vars:
|
|||||||
name: heron
|
name: heron
|
||||||
apiVersion: v300
|
apiVersion: v300
|
||||||
`)
|
`)
|
||||||
vars, err := makeKustTarget(t, ldr).getAllVars()
|
vars, err := th.makeKustTarget().getAllVars()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("Err: %v", err)
|
t.Fatalf("Err: %v", err)
|
||||||
}
|
}
|
||||||
@@ -376,9 +367,8 @@ func sortedKeys(m map[string]types.Var) (result []string) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestGetAllVarsNested(t *testing.T) {
|
func TestGetAllVarsNested(t *testing.T) {
|
||||||
ldr := loadertest.NewFakeLoader(
|
th := NewKustTestHarness(t, "/app/overlays/o2")
|
||||||
"/app/overlays/o2")
|
th.writeK("/app/base", `
|
||||||
writeK(t, ldr, "/app/base", `
|
|
||||||
vars:
|
vars:
|
||||||
- name: AWARD
|
- name: AWARD
|
||||||
objref:
|
objref:
|
||||||
@@ -393,7 +383,7 @@ vars:
|
|||||||
name: heron
|
name: heron
|
||||||
apiVersion: v300
|
apiVersion: v300
|
||||||
`)
|
`)
|
||||||
writeK(t, ldr, "/app/overlays/o1", `
|
th.writeK("/app/overlays/o1", `
|
||||||
vars:
|
vars:
|
||||||
- name: FRUIT
|
- name: FRUIT
|
||||||
objref:
|
objref:
|
||||||
@@ -402,7 +392,7 @@ vars:
|
|||||||
bases:
|
bases:
|
||||||
- ../../base
|
- ../../base
|
||||||
`)
|
`)
|
||||||
writeK(t, ldr, "/app/overlays/o2", `
|
th.writeK("/app/overlays/o2", `
|
||||||
vars:
|
vars:
|
||||||
- name: VEGETABLE
|
- name: VEGETABLE
|
||||||
objref:
|
objref:
|
||||||
@@ -411,7 +401,7 @@ vars:
|
|||||||
bases:
|
bases:
|
||||||
- ../o1
|
- ../o1
|
||||||
`)
|
`)
|
||||||
vars, err := makeKustTarget(t, ldr).getAllVars()
|
vars, err := th.makeKustTarget().getAllVars()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("Err: %v", err)
|
t.Fatalf("Err: %v", err)
|
||||||
}
|
}
|
||||||
@@ -426,9 +416,8 @@ bases:
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestVarCollisionsForbidden(t *testing.T) {
|
func TestVarCollisionsForbidden(t *testing.T) {
|
||||||
ldr := loadertest.NewFakeLoader(
|
th := NewKustTestHarness(t, "/app/overlays/o2")
|
||||||
"/app/overlays/o2")
|
th.writeK("/app/base", `
|
||||||
writeK(t, ldr, "/app/base", `
|
|
||||||
vars:
|
vars:
|
||||||
- name: AWARD
|
- name: AWARD
|
||||||
objref:
|
objref:
|
||||||
@@ -443,7 +432,7 @@ vars:
|
|||||||
name: heron
|
name: heron
|
||||||
apiVersion: v300
|
apiVersion: v300
|
||||||
`)
|
`)
|
||||||
writeK(t, ldr, "/app/overlays/o1", `
|
th.writeK("/app/overlays/o1", `
|
||||||
vars:
|
vars:
|
||||||
- name: AWARD
|
- name: AWARD
|
||||||
objref:
|
objref:
|
||||||
@@ -452,7 +441,7 @@ vars:
|
|||||||
bases:
|
bases:
|
||||||
- ../../base
|
- ../../base
|
||||||
`)
|
`)
|
||||||
writeK(t, ldr, "/app/overlays/o2", `
|
th.writeK("/app/overlays/o2", `
|
||||||
vars:
|
vars:
|
||||||
- name: VEGETABLE
|
- name: VEGETABLE
|
||||||
objref:
|
objref:
|
||||||
@@ -461,7 +450,7 @@ vars:
|
|||||||
bases:
|
bases:
|
||||||
- ../o1
|
- ../o1
|
||||||
`)
|
`)
|
||||||
_, err := makeKustTarget(t, ldr).getAllVars()
|
_, err := th.makeKustTarget().getAllVars()
|
||||||
if err == nil {
|
if err == nil {
|
||||||
t.Fatalf("expected var collision")
|
t.Fatalf("expected var collision")
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -19,20 +19,18 @@ package target
|
|||||||
import (
|
import (
|
||||||
"strings"
|
"strings"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"sigs.k8s.io/kustomize/pkg/internal/loadertest"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func writeCombinedOverlays(t *testing.T, ldr loadertest.FakeLoader) {
|
func writeCombinedOverlays(th *KustTestHarness) {
|
||||||
// Base
|
// Base
|
||||||
writeK(t, ldr, "/app/base", `
|
th.writeK("/app/base", `
|
||||||
resources:
|
resources:
|
||||||
- serviceaccount.yaml
|
- serviceaccount.yaml
|
||||||
- rolebinding.yaml
|
- rolebinding.yaml
|
||||||
namePrefix: base-
|
namePrefix: base-
|
||||||
nameSuffix: -suffix
|
nameSuffix: -suffix
|
||||||
`)
|
`)
|
||||||
writeF(t, ldr, "/app/base/rolebinding.yaml", `
|
th.writeF("/app/base/rolebinding.yaml", `
|
||||||
apiVersion: rbac.authorization.k8s.io/v1beta1
|
apiVersion: rbac.authorization.k8s.io/v1beta1
|
||||||
kind: RoleBinding
|
kind: RoleBinding
|
||||||
metadata:
|
metadata:
|
||||||
@@ -45,7 +43,7 @@ subjects:
|
|||||||
- kind: ServiceAccount
|
- kind: ServiceAccount
|
||||||
name: serviceaccount
|
name: serviceaccount
|
||||||
`)
|
`)
|
||||||
writeF(t, ldr, "/app/base/serviceaccount.yaml", `
|
th.writeF("/app/base/serviceaccount.yaml", `
|
||||||
apiVersion: v1
|
apiVersion: v1
|
||||||
kind: ServiceAccount
|
kind: ServiceAccount
|
||||||
metadata:
|
metadata:
|
||||||
@@ -53,13 +51,13 @@ metadata:
|
|||||||
`)
|
`)
|
||||||
|
|
||||||
// Mid-level overlays
|
// Mid-level overlays
|
||||||
writeK(t, ldr, "/app/overlays/a", `
|
th.writeK("/app/overlays/a", `
|
||||||
bases:
|
bases:
|
||||||
- ../../base
|
- ../../base
|
||||||
namePrefix: a-
|
namePrefix: a-
|
||||||
nameSuffix: -suffixA
|
nameSuffix: -suffixA
|
||||||
`)
|
`)
|
||||||
writeK(t, ldr, "/app/overlays/b", `
|
th.writeK("/app/overlays/b", `
|
||||||
bases:
|
bases:
|
||||||
- ../../base
|
- ../../base
|
||||||
namePrefix: b-
|
namePrefix: b-
|
||||||
@@ -67,7 +65,7 @@ nameSuffix: -suffixB
|
|||||||
`)
|
`)
|
||||||
|
|
||||||
// Top overlay, combining the mid-level overlays
|
// Top overlay, combining the mid-level overlays
|
||||||
writeK(t, ldr, "/app/combined", `
|
th.writeK("/app/combined", `
|
||||||
bases:
|
bases:
|
||||||
- ../overlays/a
|
- ../overlays/a
|
||||||
- ../overlays/b
|
- ../overlays/b
|
||||||
@@ -75,17 +73,13 @@ bases:
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestMultibasesNoConflict(t *testing.T) {
|
func TestMultibasesNoConflict(t *testing.T) {
|
||||||
ldr := loadertest.NewFakeLoader("/app/combined")
|
th := NewKustTestHarness(t, "/app/combined")
|
||||||
writeCombinedOverlays(t, ldr)
|
writeCombinedOverlays(th)
|
||||||
m, err := makeKustTarget(t, ldr).MakeCustomizedResMap()
|
m, err := th.makeKustTarget().MakeCustomizedResMap()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("Unexpected err: %v", err)
|
t.Fatalf("Unexpected err: %v", err)
|
||||||
}
|
}
|
||||||
s, err := m.EncodeAsYaml()
|
th.assertActualEqualsExpected(m, `apiVersion: v1
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("Unexpected err: %v", err)
|
|
||||||
}
|
|
||||||
assertExpectedEqualsActual(t, s, `apiVersion: v1
|
|
||||||
kind: ServiceAccount
|
kind: ServiceAccount
|
||||||
metadata:
|
metadata:
|
||||||
name: a-base-serviceaccount-suffix-suffixA
|
name: a-base-serviceaccount-suffix-suffixA
|
||||||
@@ -122,10 +116,10 @@ subjects:
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestMultibasesWithConflict(t *testing.T) {
|
func TestMultibasesWithConflict(t *testing.T) {
|
||||||
ldr := loadertest.NewFakeLoader("/app/combined")
|
th := NewKustTestHarness(t, "/app/combined")
|
||||||
writeCombinedOverlays(t, ldr)
|
writeCombinedOverlays(th)
|
||||||
|
|
||||||
writeK(t, ldr, "/app/overlays/a", `
|
th.writeK("/app/overlays/a", `
|
||||||
bases:
|
bases:
|
||||||
- ../../base
|
- ../../base
|
||||||
namePrefix: a-
|
namePrefix: a-
|
||||||
@@ -135,14 +129,14 @@ resources:
|
|||||||
`)
|
`)
|
||||||
// Expect an error because this resource in the overlay
|
// Expect an error because this resource in the overlay
|
||||||
// matches a resource in the base.
|
// matches a resource in the base.
|
||||||
writeF(t, ldr, "/app/overlays/a/serviceaccount.yaml", `
|
th.writeF("/app/overlays/a/serviceaccount.yaml", `
|
||||||
apiVersion: v1
|
apiVersion: v1
|
||||||
kind: ServiceAccount
|
kind: ServiceAccount
|
||||||
metadata:
|
metadata:
|
||||||
name: serviceaccount
|
name: serviceaccount
|
||||||
`)
|
`)
|
||||||
|
|
||||||
_, err := makeKustTarget(t, ldr).MakeCustomizedResMap()
|
_, err := th.makeKustTarget().MakeCustomizedResMap()
|
||||||
if err == nil {
|
if err == nil {
|
||||||
t.Fatalf("Expected resource conflict.")
|
t.Fatalf("Expected resource conflict.")
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -24,14 +24,30 @@ import (
|
|||||||
"strings"
|
"strings"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
|
"sigs.k8s.io/kustomize/k8sdeps/kunstruct"
|
||||||
"sigs.k8s.io/kustomize/k8sdeps/transformer"
|
"sigs.k8s.io/kustomize/k8sdeps/transformer"
|
||||||
"sigs.k8s.io/kustomize/pkg/constants"
|
"sigs.k8s.io/kustomize/pkg/constants"
|
||||||
"sigs.k8s.io/kustomize/pkg/fs"
|
"sigs.k8s.io/kustomize/pkg/fs"
|
||||||
"sigs.k8s.io/kustomize/pkg/ifc"
|
|
||||||
"sigs.k8s.io/kustomize/pkg/internal/loadertest"
|
"sigs.k8s.io/kustomize/pkg/internal/loadertest"
|
||||||
|
"sigs.k8s.io/kustomize/pkg/resmap"
|
||||||
|
"sigs.k8s.io/kustomize/pkg/resource"
|
||||||
)
|
)
|
||||||
|
|
||||||
func makeKustTarget(t *testing.T, l ifc.Loader) *KustTarget {
|
type KustTestHarness struct {
|
||||||
|
t *testing.T
|
||||||
|
rf *resmap.Factory
|
||||||
|
ldr loadertest.FakeLoader
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewKustTestHarness(t *testing.T, path string) *KustTestHarness {
|
||||||
|
return &KustTestHarness{
|
||||||
|
t: t,
|
||||||
|
rf: resmap.NewFactory(resource.NewFactory(
|
||||||
|
kunstruct.NewKunstructuredFactoryImpl())),
|
||||||
|
ldr: loadertest.NewFakeLoader(path)}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (th *KustTestHarness) makeKustTarget() *KustTarget {
|
||||||
// Warning: the following filesystem - a fake - must be rooted at /.
|
// Warning: the following filesystem - a fake - must be rooted at /.
|
||||||
// This fs root is used as the working directory for the shell spawned by
|
// This fs root is used as the working directory for the shell spawned by
|
||||||
// the secretgenerator, and has nothing to do with the filesystem used
|
// the secretgenerator, and has nothing to do with the filesystem used
|
||||||
@@ -42,29 +58,31 @@ func makeKustTarget(t *testing.T, l ifc.Loader) *KustTarget {
|
|||||||
fakeFs := fs.MakeFakeFS()
|
fakeFs := fs.MakeFakeFS()
|
||||||
fakeFs.Mkdir("/")
|
fakeFs.Mkdir("/")
|
||||||
kt, err := NewKustTarget(
|
kt, err := NewKustTarget(
|
||||||
l, fakeFs, rf, transformer.NewFactoryImpl())
|
th.ldr, fakeFs, th.rf, transformer.NewFactoryImpl())
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("Unexpected construction error %v", err)
|
th.t.Fatalf("Unexpected construction error %v", err)
|
||||||
}
|
}
|
||||||
return kt
|
return kt
|
||||||
}
|
}
|
||||||
|
|
||||||
func writeF(
|
func (th *KustTestHarness) writeF(dir string, content string) {
|
||||||
t *testing.T, ldr loadertest.FakeLoader, dir string, content string) {
|
err := th.ldr.AddFile(dir, []byte(content))
|
||||||
err := ldr.AddFile(dir, []byte(content))
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("failed write to %s; %v", dir, err)
|
th.t.Fatalf("failed write to %s; %v", dir, err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func writeK(
|
func (th *KustTestHarness) writeK(dir string, content string) {
|
||||||
t *testing.T, ldr loadertest.FakeLoader, dir string, content string) {
|
th.writeF(filepath.Join(dir, constants.KustomizationFileName), `
|
||||||
writeF(t, ldr, filepath.Join(dir, constants.KustomizationFileName), `
|
|
||||||
apiVersion: v1beta1
|
apiVersion: v1beta1
|
||||||
kind: Kustomization
|
kind: Kustomization
|
||||||
`+content)
|
`+content)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (th *KustTestHarness) fromMap(m map[string]interface{}) *resource.Resource {
|
||||||
|
return th.rf.RF().FromMap(m)
|
||||||
|
}
|
||||||
|
|
||||||
func tabToSpace(input string) string {
|
func tabToSpace(input string) string {
|
||||||
var result []string
|
var result []string
|
||||||
for _, i := range input {
|
for _, i := range input {
|
||||||
@@ -98,21 +116,30 @@ func hint(a, b string) string {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Pretty printing of file differences.
|
// Pretty printing of file differences.
|
||||||
func assertExpectedEqualsActual(t *testing.T, actual []byte, expected string) {
|
func (th *KustTestHarness) assertActualEqualsExpected(
|
||||||
if expected == string(actual) {
|
m resmap.ResMap, expected string) {
|
||||||
return
|
if m == nil {
|
||||||
|
th.t.Fatalf("Map should not be nil.")
|
||||||
}
|
}
|
||||||
|
actual, err := m.EncodeAsYaml()
|
||||||
|
if err != nil {
|
||||||
|
th.t.Fatalf("Unexpected err: %v", err)
|
||||||
|
}
|
||||||
|
if string(actual) != expected {
|
||||||
|
th.reportDiffAndFail(actual, expected)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (th *KustTestHarness) reportDiffAndFail(actual []byte, expected string) {
|
||||||
sE, maxLen := convertToArray(expected)
|
sE, maxLen := convertToArray(expected)
|
||||||
sA, _ := convertToArray(string(actual))
|
sA, _ := convertToArray(string(actual))
|
||||||
format := fmt.Sprintf("%%s %%-%ds %%s\n", maxLen+4)
|
format := fmt.Sprintf("%%s %%-%ds %%s\n", maxLen+4)
|
||||||
|
|
||||||
limit := 0
|
limit := 0
|
||||||
if len(sE) < len(sA) {
|
if len(sE) < len(sA) {
|
||||||
limit = len(sE)
|
limit = len(sE)
|
||||||
} else {
|
} else {
|
||||||
limit = len(sA)
|
limit = len(sA)
|
||||||
}
|
}
|
||||||
|
|
||||||
fmt.Printf(format, " ", "EXPECTED", "ACTUAL")
|
fmt.Printf(format, " ", "EXPECTED", "ACTUAL")
|
||||||
fmt.Printf(format, " ", "--------", "------")
|
fmt.Printf(format, " ", "--------", "------")
|
||||||
for i := 0; i < limit; i++ {
|
for i := 0; i < limit; i++ {
|
||||||
@@ -127,5 +154,5 @@ func assertExpectedEqualsActual(t *testing.T, actual []byte, expected string) {
|
|||||||
fmt.Printf(format, "X", sE[i], "")
|
fmt.Printf(format, "X", sE[i], "")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
t.Fatalf("Expected not equal to actual")
|
th.t.Fatalf("Expected not equal to actual")
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user