Merge pull request #655 from monopole/makeTestHarness

Make KustTarget test harness to reduce boilerplate.
This commit is contained in:
Jeff Regan
2018-12-24 11:42:36 -08:00
committed by GitHub
5 changed files with 139 additions and 155 deletions

View File

@@ -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

View File

@@ -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:

View File

@@ -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")
} }

View File

@@ -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.")
} }

View File

@@ -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")
} }