From 212ea60e6ac4b4cd3b696be8f1ae3a5d25360fbd Mon Sep 17 00:00:00 2001 From: Armin Buerkle Date: Tue, 22 Oct 2019 11:31:41 +0200 Subject: [PATCH] Add unit test for kustomize render Signed-off-by: Armin Buerkle --- pkg/skaffold/deploy/kustomize_test.go | 58 ++++++++++++++++++++++++--- 1 file changed, 52 insertions(+), 6 deletions(-) diff --git a/pkg/skaffold/deploy/kustomize_test.go b/pkg/skaffold/deploy/kustomize_test.go index 187d5f2d59d..0a3ed40547d 100644 --- a/pkg/skaffold/deploy/kustomize_test.go +++ b/pkg/skaffold/deploy/kustomize_test.go @@ -17,6 +17,7 @@ limitations under the License. package deploy import ( + "bytes" "context" "io/ioutil" "testing" @@ -398,26 +399,71 @@ func TestKustomizeBuildCommandArgs(t *testing.T) { func TestKustomizeRender(t *testing.T) { tests := []struct { description string + builds []build.Artifact + input string + expected string shouldErr bool }{ { - description: "calling render returns error", - shouldErr: true, + description: "should succeed without error", + builds: []build.Artifact{ + { + ImageName: "gcr.io/project/image1", + Tag: "gcr.io/project/image1:tag1", + }, + { + ImageName: "gcr.io/project/image2", + Tag: "gcr.io/project/image2:tag2", + }, + }, + input: `apiVersion: v1 +kind: Pod +spec: + containers: + - image: gcr.io/project/image1 + name: image1 + - image: gcr.io/project/image2 + name: image2 +`, + expected: `apiVersion: v1 +kind: Pod +spec: + containers: + - image: gcr.io/project/image1:tag1 + name: image1 + - image: gcr.io/project/image2:tag2 + name: image2 +`, }, } for _, test := range tests { testutil.Run(t, test.description, func(t *testutil.T) { - deployer := NewKustomizeDeployer(&runcontext.RunContext{ + t.Override(&util.DefaultExecCommand, testutil. + CmdRunOut("kubectl version --client -ojson", kubectlVersion). + AndRunOut("kustomize build .", test.input)) + t.NewTempDir(). + Chdir() + + k := NewKustomizeDeployer(&runcontext.RunContext{ + WorkingDir: ".", Cfg: latest.Pipeline{ Deploy: latest.DeployConfig{ DeployType: latest.DeployType{ - KustomizeDeploy: &latest.KustomizeDeploy{}, + KustomizeDeploy: &latest.KustomizeDeploy{ + KustomizePath: ".", + }, }, }, }, + KubeContext: testKubeContext, + Opts: config.SkaffoldOptions{ + Namespace: testNamespace, + }, }) - actual := deployer.Render(context.Background(), ioutil.Discard, []build.Artifact{}, "tmp/dir") - t.CheckError(test.shouldErr, actual) + var b bytes.Buffer + err := k.Render(context.Background(), &b, test.builds, "") + t.CheckError(test.shouldErr, err) + t.CheckDeepEqual(test.expected, b.String()) }) } }