mirror of
https://github.com/kubernetes-sigs/kustomize.git
synced 2026-06-12 01:14:22 +00:00
Allow directory substrings in cycle check.
This commit is contained in:
@@ -190,8 +190,9 @@ func newGitLoader(
|
|||||||
// seenBefore tests whether the current or any previously
|
// seenBefore tests whether the current or any previously
|
||||||
// visited root begins with the given path.
|
// visited root begins with the given path.
|
||||||
func (l *fileLoader) seenBefore(path string) error {
|
func (l *fileLoader) seenBefore(path string) error {
|
||||||
|
terminated := path + string(filepath.Separator)
|
||||||
for _, r := range l.roots {
|
for _, r := range l.roots {
|
||||||
if strings.HasPrefix(r, path) {
|
if r == path || strings.HasPrefix(r, terminated) {
|
||||||
return fmt.Errorf(
|
return fmt.Errorf(
|
||||||
"cycle detected: new root '%s' contains previous root '%s'",
|
"cycle detected: new root '%s' contains previous root '%s'",
|
||||||
path, r)
|
path, r)
|
||||||
|
|||||||
@@ -243,7 +243,7 @@ func (kt *KustTarget) loadCustomizedBases() (resmap.ResMap, *interror.Kustomizat
|
|||||||
for _, path := range kt.kustomization.Bases {
|
for _, path := range kt.kustomization.Bases {
|
||||||
ldr, err := kt.ldr.New(path)
|
ldr, err := kt.ldr.New(path)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
errs.Append(errors.Wrap(err, "couldn't make ldr for "+path))
|
errs.Append(errors.Wrap(err, "couldn't make loader for "+path))
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
target, err := NewKustTarget(
|
target, err := NewKustTarget(
|
||||||
|
|||||||
@@ -18,6 +18,7 @@ package target
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"encoding/base64"
|
"encoding/base64"
|
||||||
|
"path/filepath"
|
||||||
"reflect"
|
"reflect"
|
||||||
"strings"
|
"strings"
|
||||||
"testing"
|
"testing"
|
||||||
@@ -298,3 +299,40 @@ func TestDisableNameSuffixHash(t *testing.T) {
|
|||||||
t.Errorf("unexpected secret resource name: %s", secret.GetName())
|
t.Errorf("unexpected secret resource name: %s", secret.GetName())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func write(t *testing.T, ldr loadertest.FakeLoader, dir string, content string) {
|
||||||
|
err := ldr.AddFile(
|
||||||
|
filepath.Join(dir, constants.KustomizationFileName),
|
||||||
|
[]byte(`
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Kustomization
|
||||||
|
`+content))
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("Failed to setup fake loader.")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestIssue596AllowDirectoriesThatAreSubstringsOfEachOther(t *testing.T) {
|
||||||
|
ldr := loadertest.NewFakeLoader(
|
||||||
|
"/app/overlays/aws-sandbox2.us-east-1")
|
||||||
|
write(t, ldr, "/app/base", "")
|
||||||
|
write(t, ldr, "/app/overlays/aws", `
|
||||||
|
bases:
|
||||||
|
- ../../base
|
||||||
|
`)
|
||||||
|
write(t, ldr, "/app/overlays/aws-nonprod", `
|
||||||
|
bases:
|
||||||
|
- ../aws
|
||||||
|
`)
|
||||||
|
write(t, ldr, "/app/overlays/aws-sandbox2.us-east-1", `
|
||||||
|
bases:
|
||||||
|
- ../aws-nonprod
|
||||||
|
`)
|
||||||
|
m, err := makeKustTarget(t, ldr).MakeCustomizedResMap()
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("Err: %v", err)
|
||||||
|
}
|
||||||
|
if m == nil {
|
||||||
|
t.Fatalf("Empty map.")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user