mirror of
https://github.com/kubernetes-sigs/kustomize.git
synced 2026-06-10 16:42:51 +00:00
* test: use `T.TempDir` to create temporary test directory
This commit replaces `ioutil.TempDir` with `t.TempDir` in tests. The
directory created by `t.TempDir` is automatically removed when the test
and all its subtests complete.
Prior to this commit, temporary directory created using `ioutil.TempDir`
needs to be removed manually by calling `os.RemoveAll`, which is omitted
in some tests. The error handling boilerplate e.g.
defer func() {
if err := os.RemoveAll(dir); err != nil {
t.Fatal(err)
}
}
is also tedious, but `t.TempDir` handles this for us nicely.
Reference: https://pkg.go.dev/testing#T.TempDir
Signed-off-by: Eng Zer Jun <engzerjun@gmail.com>
* test: fix `TestInit_noargs` on Windows
--- FAIL: TestInit_noargs (0.01s)
testing.go:1090: TempDir RemoveAll cleanup: remove C:\Users\RUNNER~1\AppData\Local\Temp\TestInit_noargs3136084632\001: The process cannot access the file because it is being used by another process.
Signed-off-by: Eng Zer Jun <engzerjun@gmail.com>
* test: fix `TestTreeCommandDefaultCurDir_files` on Windows
--- FAIL: TestTreeCommandDefaultCurDir_files (0.01s)
testing.go:1090: TempDir RemoveAll cleanup: remove C:\Users\RUNNER~1\AppData\Local\Temp\TestTreeCommandDefaultCurDir_files716679291\001: The process cannot access the file because it is being used by another process.
Signed-off-by: Eng Zer Jun <engzerjun@gmail.com>
* test: fix `TestCreateSetterCommand` on Windows
--- FAIL: TestCreateSetterCommand (13.27s)
--- FAIL: TestCreateSetterCommand/add_replicas (1.45s)
testing.go:1090: TempDir RemoveAll cleanup: remove C:\Users\RUNNER~1\AppData\Local\Temp\TestCreateSetterCommandadd_replicas176222064\001\k8s-cli-487197005.yaml: The process cannot access the file because it is being used by another process.
...
and all subtests
...
Signed-off-by: Eng Zer Jun <engzerjun@gmail.com>
* test: fix `TestCreateSubstitutionCommand` on Windows
--- FAIL: TestCreateSubstitutionCommand (4.16s)
--- FAIL: TestCreateSubstitutionCommand/substitution_replicas (1.30s)
testing.go:1090: TempDir RemoveAll cleanup: remove C:\Users\RUNNER~1\AppData\Local\Temp\TestCreateSubstitutionCommandsubstitution_replicas1352417113\001\k8s-cli-3183612276.yaml: The process cannot access the file because it is being used by another process.
...
and all subtests
...
Signed-off-by: Eng Zer Jun <engzerjun@gmail.com>
* test: fix `TestDeleteSetterCommand` on Windows
--- FAIL: TestDeleteSetterCommand (4.36s)
--- FAIL: TestDeleteSetterCommand/delete_replicas (1.31s)
testing.go:1090: TempDir RemoveAll cleanup: remove C:\Users\RUNNER~1\AppData\Local\Temp\TestDeleteSetterCommanddelete_replicas3949811929\001\k8s-cli-957077271.yaml: The process cannot access the file because it is being used by another process.
...
and all subtests
...
Signed-off-by: Eng Zer Jun <engzerjun@gmail.com>
* test: fix `TestDeleteSubstitutionCommand` on Windows
--- FAIL: TestDeleteSubstitutionCommand (2.35s)
--- FAIL: TestDeleteSubstitutionCommand/delete_only_subst_if_setter_has_same_name_-_long_ref (1.15s)
testing.go:1090: TempDir RemoveAll cleanup: remove C:\Users\RUNNER~1\AppData\Local\Temp\TestDeleteSubstitutionCommanddelete_only_subst_if_setter_has_same_name_-_long_ref2039728641\001\k8s-cli-1602861478.yaml: The process cannot access the file because it is being used by another process.
...
and all subtests
...
Signed-off-by: Eng Zer Jun <engzerjun@gmail.com>
* test: fix `TestSetCommand` on Windows
--- FAIL: TestSetCommand (13.76s)
--- FAIL: TestSetCommand/set_replicas (1.13s)
testing.go:1090: TempDir RemoveAll cleanup: remove C:\Users\RUNNER~1\AppData\Local\Temp\TestSetCommandset_replicas3781384539\001\k8s-cli-1030344459.yaml: The process cannot access the file because it is being used by another process.
...
and all subtests
...
Signed-off-by: Eng Zer Jun <engzerjun@gmail.com>
560 lines
9.6 KiB
Go
560 lines
9.6 KiB
Go
// Copyright 2019 The Kubernetes Authors.
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
package commands_test
|
|
|
|
import (
|
|
"bytes"
|
|
"fmt"
|
|
"io/ioutil"
|
|
"os"
|
|
"path/filepath"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
"sigs.k8s.io/kustomize/cmd/config/internal/commands"
|
|
)
|
|
|
|
func TestTreeCommandDefaultCurDir_files(t *testing.T) {
|
|
d := t.TempDir()
|
|
cwd, err := os.Getwd()
|
|
if !assert.NoError(t, err) {
|
|
t.FailNow()
|
|
}
|
|
|
|
if !assert.NoError(t, os.Chdir(d)) {
|
|
return
|
|
}
|
|
|
|
t.Cleanup(func() {
|
|
if !assert.NoError(t, os.Chdir(cwd)) {
|
|
t.FailNow()
|
|
}
|
|
})
|
|
|
|
err = ioutil.WriteFile(filepath.Join(d, "f1.yaml"), []byte(`
|
|
apiVersion: v1
|
|
kind: Abstraction
|
|
metadata:
|
|
name: foo
|
|
configFn:
|
|
container:
|
|
image: gcr.io/example/reconciler:v1
|
|
annotations:
|
|
config.kubernetes.io/local-config: "true"
|
|
spec:
|
|
replicas: 1
|
|
---
|
|
kind: Deployment
|
|
metadata:
|
|
labels:
|
|
app: nginx2
|
|
name: foo
|
|
annotations:
|
|
app: nginx2
|
|
spec:
|
|
replicas: 1
|
|
---
|
|
kind: Service
|
|
metadata:
|
|
name: foo
|
|
annotations:
|
|
app: nginx
|
|
spec:
|
|
selector:
|
|
app: nginx
|
|
`), 0600)
|
|
if !assert.NoError(t, err) {
|
|
return
|
|
}
|
|
err = ioutil.WriteFile(filepath.Join(d, "f2.yaml"), []byte(`kind: Deployment
|
|
metadata:
|
|
labels:
|
|
app: nginx
|
|
name: bar
|
|
annotations:
|
|
app: nginx
|
|
spec:
|
|
replicas: 3
|
|
`), 0600)
|
|
if !assert.NoError(t, err) {
|
|
return
|
|
}
|
|
|
|
// fmt the files
|
|
b := &bytes.Buffer{}
|
|
r := commands.GetTreeRunner("")
|
|
r.Command.SetArgs([]string{})
|
|
r.Command.SetOut(b)
|
|
if !assert.NoError(t, r.Command.Execute()) {
|
|
return
|
|
}
|
|
|
|
if !assert.Equal(t, `.
|
|
├── [f1.yaml] Deployment foo
|
|
├── [f1.yaml] Service foo
|
|
└── [f2.yaml] Deployment bar
|
|
`, b.String()) {
|
|
return
|
|
}
|
|
}
|
|
|
|
// TestCmd_files verifies fmt reads the files and filters them
|
|
func TestTreeCommand_files(t *testing.T) {
|
|
d := t.TempDir()
|
|
|
|
err := ioutil.WriteFile(filepath.Join(d, "f1.yaml"), []byte(`
|
|
apiVersion: v1
|
|
kind: Abstraction
|
|
metadata:
|
|
name: foo
|
|
configFn:
|
|
container:
|
|
image: gcr.io/example/reconciler:v1
|
|
annotations:
|
|
config.kubernetes.io/local-config: "true"
|
|
spec:
|
|
replicas: 1
|
|
---
|
|
kind: Deployment
|
|
metadata:
|
|
labels:
|
|
app: nginx2
|
|
name: foo
|
|
annotations:
|
|
app: nginx2
|
|
spec:
|
|
replicas: 1
|
|
---
|
|
kind: Service
|
|
metadata:
|
|
name: foo
|
|
annotations:
|
|
app: nginx
|
|
spec:
|
|
selector:
|
|
app: nginx
|
|
`), 0600)
|
|
if !assert.NoError(t, err) {
|
|
return
|
|
}
|
|
err = ioutil.WriteFile(filepath.Join(d, "f2.yaml"), []byte(`kind: Deployment
|
|
metadata:
|
|
labels:
|
|
app: nginx
|
|
name: bar
|
|
annotations:
|
|
app: nginx
|
|
spec:
|
|
replicas: 3
|
|
`), 0600)
|
|
if !assert.NoError(t, err) {
|
|
return
|
|
}
|
|
|
|
// fmt the files
|
|
b := &bytes.Buffer{}
|
|
r := commands.GetTreeRunner("")
|
|
r.Command.SetArgs([]string{d})
|
|
r.Command.SetOut(b)
|
|
if !assert.NoError(t, r.Command.Execute()) {
|
|
return
|
|
}
|
|
|
|
if !assert.Equal(t, fmt.Sprintf(`%s
|
|
├── [f1.yaml] Deployment foo
|
|
├── [f1.yaml] Service foo
|
|
└── [f2.yaml] Deployment bar
|
|
`, d), b.String()) {
|
|
return
|
|
}
|
|
}
|
|
|
|
func TestTreeCommand_Kustomization(t *testing.T) {
|
|
d := t.TempDir()
|
|
|
|
err := ioutil.WriteFile(filepath.Join(d, "f2.yaml"), []byte(`kind: Deployment
|
|
metadata:
|
|
labels:
|
|
app: nginx
|
|
name: bar
|
|
annotations:
|
|
app: nginx
|
|
spec:
|
|
replicas: 3
|
|
`), 0600)
|
|
if !assert.NoError(t, err) {
|
|
return
|
|
}
|
|
|
|
err = ioutil.WriteFile(filepath.Join(d, "Kustomization"), []byte(`apiVersion: kustomize.config.k8s.io/v1beta1
|
|
kind: Kustomization
|
|
resources:
|
|
- f2.yaml
|
|
`), 0600)
|
|
if !assert.NoError(t, err) {
|
|
return
|
|
}
|
|
|
|
// fmt the files
|
|
b := &bytes.Buffer{}
|
|
r := commands.GetTreeRunner("")
|
|
r.Command.SetArgs([]string{d})
|
|
r.Command.SetOut(b)
|
|
if !assert.NoError(t, r.Command.Execute()) {
|
|
return
|
|
}
|
|
|
|
if !assert.Equal(t, fmt.Sprintf(`%s
|
|
└── [f2.yaml] Deployment bar
|
|
`, d), b.String()) {
|
|
return
|
|
}
|
|
}
|
|
|
|
func TestTreeCommand_subpkgs(t *testing.T) {
|
|
d := t.TempDir()
|
|
|
|
err := os.MkdirAll(filepath.Join(d, "subpkg"), 0700)
|
|
if !assert.NoError(t, err) {
|
|
t.FailNow()
|
|
}
|
|
|
|
err = ioutil.WriteFile(filepath.Join(d, "f1.yaml"), []byte(`
|
|
apiVersion: v1
|
|
kind: Abstraction
|
|
metadata:
|
|
name: foo
|
|
configFn:
|
|
container:
|
|
image: gcr.io/example/reconciler:v1
|
|
annotations:
|
|
config.kubernetes.io/local-config: "true"
|
|
spec:
|
|
replicas: 1
|
|
---
|
|
kind: Deployment
|
|
metadata:
|
|
labels:
|
|
app: nginx2
|
|
name: foo
|
|
annotations:
|
|
app: nginx2
|
|
spec:
|
|
replicas: 1
|
|
---
|
|
kind: Service
|
|
metadata:
|
|
name: foo
|
|
annotations:
|
|
app: nginx
|
|
spec:
|
|
selector:
|
|
app: nginx
|
|
`), 0600)
|
|
if !assert.NoError(t, err) {
|
|
return
|
|
}
|
|
err = ioutil.WriteFile(filepath.Join(d, "subpkg", "f2.yaml"), []byte(`kind: Deployment
|
|
metadata:
|
|
labels:
|
|
app: nginx
|
|
name: bar
|
|
annotations:
|
|
app: nginx
|
|
spec:
|
|
replicas: 3
|
|
`), 0600)
|
|
if !assert.NoError(t, err) {
|
|
return
|
|
}
|
|
|
|
err = ioutil.WriteFile(filepath.Join(d, "Krmfile"), []byte(`apiVersion: kpt.dev/v1alpha1
|
|
kind: Krmfile
|
|
metadata:
|
|
name: mainpkg
|
|
openAPI:
|
|
definitions:
|
|
`), 0600)
|
|
if !assert.NoError(t, err) {
|
|
return
|
|
}
|
|
err = ioutil.WriteFile(filepath.Join(d, "subpkg", "Krmfile"), []byte(`apiVersion: kpt.dev/v1alpha1
|
|
kind: Krmfile
|
|
metadata:
|
|
name: subpkg
|
|
openAPI:
|
|
definitions:
|
|
`), 0600)
|
|
if !assert.NoError(t, err) {
|
|
return
|
|
}
|
|
|
|
// fmt the files
|
|
b := &bytes.Buffer{}
|
|
r := commands.GetTreeRunner("")
|
|
r.Command.SetArgs([]string{d})
|
|
r.Command.SetOut(b)
|
|
if !assert.NoError(t, r.Command.Execute()) {
|
|
return
|
|
}
|
|
|
|
if !assert.Equal(t, fmt.Sprintf(`%s
|
|
├── [f1.yaml] Deployment foo
|
|
├── [f1.yaml] Service foo
|
|
└── Pkg: subpkg
|
|
└── [f2.yaml] Deployment bar
|
|
`, d), b.String()) {
|
|
return
|
|
}
|
|
}
|
|
|
|
func TestTreeCommand_stdin(t *testing.T) {
|
|
// fmt the files
|
|
b := &bytes.Buffer{}
|
|
r := commands.GetTreeRunner("")
|
|
r.Command.SetArgs([]string{"-"})
|
|
r.Command.SetIn(bytes.NewBufferString(`apiVersion: extensions/v1
|
|
kind: Deployment
|
|
metadata:
|
|
labels:
|
|
app: nginx2
|
|
name: foo3
|
|
namespace: default
|
|
annotations:
|
|
app: nginx2
|
|
config.kubernetes.io/path: f1.yaml
|
|
spec:
|
|
replicas: 1
|
|
---
|
|
apiVersion: extensions/v1
|
|
kind: Deployment
|
|
metadata:
|
|
labels:
|
|
app: nginx2
|
|
name: foo3
|
|
namespace: default
|
|
annotations:
|
|
app: nginx2
|
|
config.kubernetes.io/path: f1.yaml
|
|
spec:
|
|
replicas: 1
|
|
---
|
|
apiVersion: apps/v1
|
|
kind: Deployment
|
|
metadata:
|
|
labels:
|
|
app: nginx2
|
|
name: foo3
|
|
namespace: default
|
|
annotations:
|
|
app: nginx2
|
|
config.kubernetes.io/path: f1.yaml
|
|
spec:
|
|
replicas: 1
|
|
---
|
|
apiVersion: apps/v1
|
|
kind: Deployment
|
|
metadata:
|
|
labels:
|
|
app: nginx2
|
|
name: foo2
|
|
namespace: default2
|
|
annotations:
|
|
app: nginx2
|
|
config.kubernetes.io/path: f1.yaml
|
|
spec:
|
|
replicas: 1
|
|
---
|
|
apiVersion: apps/v1
|
|
kind: Deployment
|
|
metadata:
|
|
labels:
|
|
app: nginx3
|
|
name: foo
|
|
namespace: default
|
|
annotations:
|
|
app: nginx3
|
|
config.kubernetes.io/path: f1.yaml
|
|
spec:
|
|
replicas: 1
|
|
---
|
|
kind: Deployment
|
|
metadata:
|
|
labels:
|
|
app: nginx
|
|
annotations:
|
|
app: nginx
|
|
config.kubernetes.io/path: bar-package/f2.yaml
|
|
name: bar
|
|
spec:
|
|
replicas: 3
|
|
---
|
|
kind: Service
|
|
metadata:
|
|
name: foo
|
|
namespace: default
|
|
annotations:
|
|
app: nginx
|
|
config.kubernetes.io/path: f1.yaml
|
|
spec:
|
|
selector:
|
|
app: nginx
|
|
`))
|
|
r.Command.SetOut(b)
|
|
if !assert.NoError(t, r.Command.Execute()) {
|
|
return
|
|
}
|
|
|
|
if !assert.Equal(t, `.
|
|
├── [f1.yaml] Deployment default/foo
|
|
├── [f1.yaml] Service default/foo
|
|
├── [f1.yaml] Deployment default/foo3
|
|
├── [f1.yaml] Deployment default/foo3
|
|
├── [f1.yaml] Deployment default/foo3
|
|
├── [f1.yaml] Deployment default2/foo2
|
|
└── bar-package
|
|
└── [f2.yaml] Deployment bar
|
|
`, b.String()) {
|
|
return
|
|
}
|
|
}
|
|
|
|
func TestTreeCommand_includeReconcilers(t *testing.T) {
|
|
d := t.TempDir()
|
|
|
|
err := ioutil.WriteFile(filepath.Join(d, "f1.yaml"), []byte(`
|
|
kind: Deployment
|
|
metadata:
|
|
labels:
|
|
app: nginx2
|
|
name: foo
|
|
annotations:
|
|
app: nginx2
|
|
spec:
|
|
replicas: 1
|
|
---
|
|
kind: Service
|
|
metadata:
|
|
name: foo
|
|
annotations:
|
|
app: nginx
|
|
spec:
|
|
selector:
|
|
app: nginx
|
|
`), 0600)
|
|
if !assert.NoError(t, err) {
|
|
return
|
|
}
|
|
err = ioutil.WriteFile(filepath.Join(d, "f2.yaml"), []byte(`
|
|
apiVersion: gcr.io/example/reconciler:v1
|
|
kind: Abstraction
|
|
metadata:
|
|
name: foo
|
|
spec:
|
|
replicas: 1
|
|
---
|
|
apiVersion: apps/v1
|
|
kind: Deployment
|
|
metadata:
|
|
labels:
|
|
app: nginx
|
|
name: bar
|
|
annotations:
|
|
app: nginx
|
|
spec:
|
|
replicas: 3
|
|
`), 0600)
|
|
if !assert.NoError(t, err) {
|
|
return
|
|
}
|
|
|
|
// fmt the files
|
|
b := &bytes.Buffer{}
|
|
r := commands.GetTreeRunner("")
|
|
r.Command.SetArgs([]string{d, "--include-local"})
|
|
r.Command.SetOut(b)
|
|
if !assert.NoError(t, r.Command.Execute()) {
|
|
return
|
|
}
|
|
|
|
if !assert.Equal(t, fmt.Sprintf(`%s
|
|
├── [f1.yaml] Deployment foo
|
|
├── [f1.yaml] Service foo
|
|
├── [f2.yaml] Deployment bar
|
|
└── [f2.yaml] Abstraction foo
|
|
`, d), b.String()) {
|
|
return
|
|
}
|
|
}
|
|
|
|
func TestTreeCommand_excludeNonReconcilers(t *testing.T) {
|
|
d := t.TempDir()
|
|
|
|
err := ioutil.WriteFile(filepath.Join(d, "f1.yaml"), []byte(`
|
|
kind: Deployment
|
|
metadata:
|
|
labels:
|
|
app: nginx2
|
|
name: foo
|
|
annotations:
|
|
app: nginx2
|
|
spec:
|
|
replicas: 1
|
|
---
|
|
kind: Service
|
|
metadata:
|
|
name: foo
|
|
annotations:
|
|
app: nginx
|
|
spec:
|
|
selector:
|
|
app: nginx
|
|
`), 0600)
|
|
if !assert.NoError(t, err) {
|
|
return
|
|
}
|
|
err = ioutil.WriteFile(filepath.Join(d, "f2.yaml"), []byte(`
|
|
apiVersion: v1
|
|
kind: Abstraction
|
|
metadata:
|
|
name: foo
|
|
configFn:
|
|
container:
|
|
image: gcr.io/example/reconciler:v1
|
|
annotations:
|
|
config.kubernetes.io/local-config: "true"
|
|
spec:
|
|
replicas: 1
|
|
---
|
|
apiVersion: apps/v1
|
|
kind: Deployment
|
|
metadata:
|
|
labels:
|
|
app: nginx
|
|
name: bar
|
|
annotations:
|
|
app: nginx
|
|
spec:
|
|
replicas: 3
|
|
`), 0600)
|
|
if !assert.NoError(t, err) {
|
|
return
|
|
}
|
|
|
|
// fmt the files
|
|
b := &bytes.Buffer{}
|
|
r := commands.GetTreeRunner("")
|
|
r.Command.SetArgs([]string{d, "--include-local", "--exclude-non-local"})
|
|
r.Command.SetOut(b)
|
|
if !assert.NoError(t, r.Command.Execute()) {
|
|
return
|
|
}
|
|
|
|
if !assert.Equal(t, fmt.Sprintf(`%s
|
|
└── [f2.yaml] Abstraction foo
|
|
`, d), b.String()) {
|
|
return
|
|
}
|
|
}
|