fix: spec.KubeContext does not fallback to HelmDefaults.KubeContext (#1789)
* fix: spec.KubeContext does not fallback to HelmDefaults.KubeContext Fixes #1782 * Add testcases to test without default kubecontext
This commit is contained in:
parent
41cbc25c35
commit
8702639510
File diff suppressed because it is too large
Load Diff
|
|
@ -277,12 +277,12 @@ Affected releases are:
|
||||||
|
|
||||||
processing 2 groups of releases in this order:
|
processing 2 groups of releases in this order:
|
||||||
GROUP RELEASES
|
GROUP RELEASES
|
||||||
1 default/external-secrets
|
1 default/default/external-secrets
|
||||||
2 default/my-release
|
2 default/default/my-release
|
||||||
|
|
||||||
processing releases in group 1/2: default/external-secrets
|
processing releases in group 1/2: default/default/external-secrets
|
||||||
getting deployed release version failed:unexpected list key: {^external-secrets$ --kube-contextdefault--deleting--deployed--failed--pending}
|
getting deployed release version failed:unexpected list key: {^external-secrets$ --kube-contextdefault--deleting--deployed--failed--pending}
|
||||||
processing releases in group 2/2: default/my-release
|
processing releases in group 2/2: default/default/my-release
|
||||||
getting deployed release version failed:unexpected list key: {^my-release$ --kube-contextdefault--deleting--deployed--failed--pending}
|
getting deployed release version failed:unexpected list key: {^my-release$ --kube-contextdefault--deleting--deployed--failed--pending}
|
||||||
|
|
||||||
UPDATED RELEASES:
|
UPDATED RELEASES:
|
||||||
|
|
@ -408,9 +408,9 @@ Affected releases are:
|
||||||
|
|
||||||
processing 1 groups of releases in this order:
|
processing 1 groups of releases in this order:
|
||||||
GROUP RELEASES
|
GROUP RELEASES
|
||||||
1 default/external-secrets
|
1 default/default/external-secrets
|
||||||
|
|
||||||
processing releases in group 1/1: default/external-secrets
|
processing releases in group 1/1: default/default/external-secrets
|
||||||
|
|
||||||
UPDATED RELEASES:
|
UPDATED RELEASES:
|
||||||
NAME CHART VERSION
|
NAME CHART VERSION
|
||||||
|
|
@ -532,15 +532,15 @@ Affected releases are:
|
||||||
|
|
||||||
processing 3 groups of releases in this order:
|
processing 3 groups of releases in this order:
|
||||||
GROUP RELEASES
|
GROUP RELEASES
|
||||||
1 kube-system/kubernetes-external-secrets
|
1 default/kube-system/kubernetes-external-secrets
|
||||||
2 default/external-secrets
|
2 default/default/external-secrets
|
||||||
3 default/my-release
|
3 default/default/my-release
|
||||||
|
|
||||||
processing releases in group 1/3: kube-system/kubernetes-external-secrets
|
processing releases in group 1/3: default/kube-system/kubernetes-external-secrets
|
||||||
getting deployed release version failed:unexpected list key: {^kubernetes-external-secrets$ --kube-contextdefault--deleting--deployed--failed--pending}
|
getting deployed release version failed:unexpected list key: {^kubernetes-external-secrets$ --kube-contextdefault--deleting--deployed--failed--pending}
|
||||||
processing releases in group 2/3: default/external-secrets
|
processing releases in group 2/3: default/default/external-secrets
|
||||||
getting deployed release version failed:unexpected list key: {^external-secrets$ --kube-contextdefault--deleting--deployed--failed--pending}
|
getting deployed release version failed:unexpected list key: {^external-secrets$ --kube-contextdefault--deleting--deployed--failed--pending}
|
||||||
processing releases in group 3/3: default/my-release
|
processing releases in group 3/3: default/default/my-release
|
||||||
getting deployed release version failed:unexpected list key: {^my-release$ --kube-contextdefault--deleting--deployed--failed--pending}
|
getting deployed release version failed:unexpected list key: {^my-release$ --kube-contextdefault--deleting--deployed--failed--pending}
|
||||||
|
|
||||||
UPDATED RELEASES:
|
UPDATED RELEASES:
|
||||||
|
|
@ -665,12 +665,12 @@ Affected releases are:
|
||||||
|
|
||||||
processing 2 groups of releases in this order:
|
processing 2 groups of releases in this order:
|
||||||
GROUP RELEASES
|
GROUP RELEASES
|
||||||
1 default/external-secrets
|
1 default/default/external-secrets
|
||||||
2 default/my-release
|
2 default/default/my-release
|
||||||
|
|
||||||
processing releases in group 1/2: default/external-secrets
|
processing releases in group 1/2: default/default/external-secrets
|
||||||
getting deployed release version failed:unexpected list key: {^external-secrets$ --kube-contextdefault--deleting--deployed--failed--pending}
|
getting deployed release version failed:unexpected list key: {^external-secrets$ --kube-contextdefault--deleting--deployed--failed--pending}
|
||||||
processing releases in group 2/2: default/my-release
|
processing releases in group 2/2: default/default/my-release
|
||||||
getting deployed release version failed:unexpected list key: {^my-release$ --kube-contextdefault--deleting--deployed--failed--pending}
|
getting deployed release version failed:unexpected list key: {^my-release$ --kube-contextdefault--deleting--deployed--failed--pending}
|
||||||
|
|
||||||
UPDATED RELEASES:
|
UPDATED RELEASES:
|
||||||
|
|
@ -802,17 +802,17 @@ Affected releases are:
|
||||||
|
|
||||||
processing 1 groups of releases in this order:
|
processing 1 groups of releases in this order:
|
||||||
GROUP RELEASES
|
GROUP RELEASES
|
||||||
1 kube-system/kubernetes-external-secrets
|
1 default/kube-system/kubernetes-external-secrets
|
||||||
|
|
||||||
processing releases in group 1/1: kube-system/kubernetes-external-secrets
|
processing releases in group 1/1: default/kube-system/kubernetes-external-secrets
|
||||||
processing 2 groups of releases in this order:
|
processing 2 groups of releases in this order:
|
||||||
GROUP RELEASES
|
GROUP RELEASES
|
||||||
1 default/external-secrets
|
1 default/default/external-secrets
|
||||||
2 default/my-release
|
2 default/default/my-release
|
||||||
|
|
||||||
processing releases in group 1/2: default/external-secrets
|
processing releases in group 1/2: default/default/external-secrets
|
||||||
getting deployed release version failed:unexpected list key: {^external-secrets$ --kube-contextdefault--deleting--deployed--failed--pending}
|
getting deployed release version failed:unexpected list key: {^external-secrets$ --kube-contextdefault--deleting--deployed--failed--pending}
|
||||||
processing releases in group 2/2: default/my-release
|
processing releases in group 2/2: default/default/my-release
|
||||||
getting deployed release version failed:unexpected list key: {^my-release$ --kube-contextdefault--deleting--deployed--failed--pending}
|
getting deployed release version failed:unexpected list key: {^my-release$ --kube-contextdefault--deleting--deployed--failed--pending}
|
||||||
|
|
||||||
UPDATED RELEASES:
|
UPDATED RELEASES:
|
||||||
|
|
@ -945,12 +945,12 @@ Affected releases are:
|
||||||
|
|
||||||
processing 2 groups of releases in this order:
|
processing 2 groups of releases in this order:
|
||||||
GROUP RELEASES
|
GROUP RELEASES
|
||||||
1 default/external-secrets
|
1 default/default/external-secrets
|
||||||
2 default/my-release
|
2 default/default/my-release
|
||||||
|
|
||||||
processing releases in group 1/2: default/external-secrets
|
processing releases in group 1/2: default/default/external-secrets
|
||||||
getting deployed release version failed:unexpected list key: {^external-secrets$ --kube-contextdefault--deleting--deployed--failed--pending}
|
getting deployed release version failed:unexpected list key: {^external-secrets$ --kube-contextdefault--deleting--deployed--failed--pending}
|
||||||
processing releases in group 2/2: default/my-release
|
processing releases in group 2/2: default/default/my-release
|
||||||
getting deployed release version failed:unexpected list key: {^my-release$ --kube-contextdefault--deleting--deployed--failed--pending}
|
getting deployed release version failed:unexpected list key: {^my-release$ --kube-contextdefault--deleting--deployed--failed--pending}
|
||||||
|
|
||||||
UPDATED RELEASES:
|
UPDATED RELEASES:
|
||||||
|
|
|
||||||
|
|
@ -271,12 +271,12 @@ Affected releases are:
|
||||||
|
|
||||||
processing 2 groups of releases in this order:
|
processing 2 groups of releases in this order:
|
||||||
GROUP RELEASES
|
GROUP RELEASES
|
||||||
1 default/external-secrets
|
1 default/default/external-secrets
|
||||||
2 default/my-release
|
2 default/default/my-release
|
||||||
|
|
||||||
processing releases in group 1/2: default/external-secrets
|
processing releases in group 1/2: default/default/external-secrets
|
||||||
getting deployed release version failed:unexpected list key: {^external-secrets$ --kube-contextdefault--deleting--deployed--failed--pending}
|
getting deployed release version failed:unexpected list key: {^external-secrets$ --kube-contextdefault--deleting--deployed--failed--pending}
|
||||||
processing releases in group 2/2: default/my-release
|
processing releases in group 2/2: default/default/my-release
|
||||||
getting deployed release version failed:unexpected list key: {^my-release$ --kube-contextdefault--deleting--deployed--failed--pending}
|
getting deployed release version failed:unexpected list key: {^my-release$ --kube-contextdefault--deleting--deployed--failed--pending}
|
||||||
|
|
||||||
UPDATED RELEASES:
|
UPDATED RELEASES:
|
||||||
|
|
@ -395,15 +395,15 @@ Affected releases are:
|
||||||
|
|
||||||
processing 3 groups of releases in this order:
|
processing 3 groups of releases in this order:
|
||||||
GROUP RELEASES
|
GROUP RELEASES
|
||||||
1 kube-system/kubernetes-external-secrets
|
1 default/kube-system/kubernetes-external-secrets
|
||||||
2 default/external-secrets
|
2 default/default/external-secrets
|
||||||
3 default/my-release
|
3 default/default/my-release
|
||||||
|
|
||||||
processing releases in group 1/3: kube-system/kubernetes-external-secrets
|
processing releases in group 1/3: default/kube-system/kubernetes-external-secrets
|
||||||
getting deployed release version failed:unexpected list key: {^kubernetes-external-secrets$ --kube-contextdefault--deleting--deployed--failed--pending}
|
getting deployed release version failed:unexpected list key: {^kubernetes-external-secrets$ --kube-contextdefault--deleting--deployed--failed--pending}
|
||||||
processing releases in group 2/3: default/external-secrets
|
processing releases in group 2/3: default/default/external-secrets
|
||||||
getting deployed release version failed:unexpected list key: {^external-secrets$ --kube-contextdefault--deleting--deployed--failed--pending}
|
getting deployed release version failed:unexpected list key: {^external-secrets$ --kube-contextdefault--deleting--deployed--failed--pending}
|
||||||
processing releases in group 3/3: default/my-release
|
processing releases in group 3/3: default/default/my-release
|
||||||
getting deployed release version failed:unexpected list key: {^my-release$ --kube-contextdefault--deleting--deployed--failed--pending}
|
getting deployed release version failed:unexpected list key: {^my-release$ --kube-contextdefault--deleting--deployed--failed--pending}
|
||||||
|
|
||||||
UPDATED RELEASES:
|
UPDATED RELEASES:
|
||||||
|
|
@ -532,17 +532,17 @@ Affected releases are:
|
||||||
|
|
||||||
processing 1 groups of releases in this order:
|
processing 1 groups of releases in this order:
|
||||||
GROUP RELEASES
|
GROUP RELEASES
|
||||||
1 kube-system/kubernetes-external-secrets
|
1 default/kube-system/kubernetes-external-secrets
|
||||||
|
|
||||||
processing releases in group 1/1: kube-system/kubernetes-external-secrets
|
processing releases in group 1/1: default/kube-system/kubernetes-external-secrets
|
||||||
processing 2 groups of releases in this order:
|
processing 2 groups of releases in this order:
|
||||||
GROUP RELEASES
|
GROUP RELEASES
|
||||||
1 default/external-secrets
|
1 default/default/external-secrets
|
||||||
2 default/my-release
|
2 default/default/my-release
|
||||||
|
|
||||||
processing releases in group 1/2: default/external-secrets
|
processing releases in group 1/2: default/default/external-secrets
|
||||||
getting deployed release version failed:unexpected list key: {^external-secrets$ --kube-contextdefault--deleting--deployed--failed--pending}
|
getting deployed release version failed:unexpected list key: {^external-secrets$ --kube-contextdefault--deleting--deployed--failed--pending}
|
||||||
processing releases in group 2/2: default/my-release
|
processing releases in group 2/2: default/default/my-release
|
||||||
getting deployed release version failed:unexpected list key: {^my-release$ --kube-contextdefault--deleting--deployed--failed--pending}
|
getting deployed release version failed:unexpected list key: {^my-release$ --kube-contextdefault--deleting--deployed--failed--pending}
|
||||||
|
|
||||||
UPDATED RELEASES:
|
UPDATED RELEASES:
|
||||||
|
|
@ -671,12 +671,12 @@ Affected releases are:
|
||||||
|
|
||||||
processing 2 groups of releases in this order:
|
processing 2 groups of releases in this order:
|
||||||
GROUP RELEASES
|
GROUP RELEASES
|
||||||
1 default/external-secrets
|
1 default/default/external-secrets
|
||||||
2 default/my-release
|
2 default/default/my-release
|
||||||
|
|
||||||
processing releases in group 1/2: default/external-secrets
|
processing releases in group 1/2: default/default/external-secrets
|
||||||
getting deployed release version failed:unexpected list key: {^external-secrets$ --kube-contextdefault--deleting--deployed--failed--pending}
|
getting deployed release version failed:unexpected list key: {^external-secrets$ --kube-contextdefault--deleting--deployed--failed--pending}
|
||||||
processing releases in group 2/2: default/my-release
|
processing releases in group 2/2: default/default/my-release
|
||||||
getting deployed release version failed:unexpected list key: {^my-release$ --kube-contextdefault--deleting--deployed--failed--pending}
|
getting deployed release version failed:unexpected list key: {^my-release$ --kube-contextdefault--deleting--deployed--failed--pending}
|
||||||
|
|
||||||
UPDATED RELEASES:
|
UPDATED RELEASES:
|
||||||
|
|
|
||||||
|
|
@ -499,7 +499,7 @@ releases:
|
||||||
{label: "name!=", expectedCount: 0, expectErr: true, errMsg: "in ./helmfile.yaml: in .helmfiles[0]: in /path/to/helmfile.d/a1.yaml: Malformed label: name!=. Expected label in form k=v or k!=v"},
|
{label: "name!=", expectedCount: 0, expectErr: true, errMsg: "in ./helmfile.yaml: in .helmfiles[0]: in /path/to/helmfile.d/a1.yaml: Malformed label: name!=. Expected label in form k=v or k!=v"},
|
||||||
{label: "name", expectedCount: 0, expectErr: true, errMsg: "in ./helmfile.yaml: in .helmfiles[0]: in /path/to/helmfile.d/a1.yaml: Malformed label: name. Expected label in form k=v or k!=v"},
|
{label: "name", expectedCount: 0, expectErr: true, errMsg: "in ./helmfile.yaml: in .helmfiles[0]: in /path/to/helmfile.d/a1.yaml: Malformed label: name. Expected label in form k=v or k!=v"},
|
||||||
// See https://github.com/roboll/helmfile/issues/193
|
// See https://github.com/roboll/helmfile/issues/193
|
||||||
{label: "duplicatedNs=yes", expectedCount: 0, expectErr: true, errMsg: "in ./helmfile.yaml: in .helmfiles[2]: in /path/to/helmfile.d/b.yaml: duplicate release \"foo\" found in namespace \"zoo\": there were 2 releases named \"foo\" matching specified selector"},
|
{label: "duplicatedNs=yes", expectedCount: 0, expectErr: true, errMsg: "in ./helmfile.yaml: in .helmfiles[2]: in /path/to/helmfile.d/b.yaml: duplicate release \"foo\" found in namespace \"zoo\" in kubecontext \"default\": there were 2 releases named \"foo\" matching specified selector"},
|
||||||
{label: "duplicatedCtx=yes", expectedCount: 0, expectErr: true, errMsg: "in ./helmfile.yaml: in .helmfiles[2]: in /path/to/helmfile.d/b.yaml: duplicate release \"foo\" found in namespace \"zoo\" in kubecontext \"baz\": there were 2 releases named \"foo\" matching specified selector"},
|
{label: "duplicatedCtx=yes", expectedCount: 0, expectErr: true, errMsg: "in ./helmfile.yaml: in .helmfiles[2]: in /path/to/helmfile.d/b.yaml: duplicate release \"foo\" found in namespace \"zoo\" in kubecontext \"baz\": there were 2 releases named \"foo\" matching specified selector"},
|
||||||
{label: "duplicatedOK=yes", expectedCount: 2, expectErr: false},
|
{label: "duplicatedOK=yes", expectedCount: 2, expectErr: false},
|
||||||
}
|
}
|
||||||
|
|
@ -2979,30 +2979,30 @@ Affected releases are:
|
||||||
|
|
||||||
processing 2 groups of releases in this order:
|
processing 2 groups of releases in this order:
|
||||||
GROUP RELEASES
|
GROUP RELEASES
|
||||||
1 frontend-v1
|
1 default/frontend-v1
|
||||||
2 backend-v1
|
2 default/backend-v1
|
||||||
|
|
||||||
processing releases in group 1/2: frontend-v1
|
processing releases in group 1/2: default/frontend-v1
|
||||||
processing releases in group 2/2: backend-v1
|
processing releases in group 2/2: default/backend-v1
|
||||||
processing 5 groups of releases in this order:
|
processing 5 groups of releases in this order:
|
||||||
GROUP RELEASES
|
GROUP RELEASES
|
||||||
1 logging, front-proxy
|
1 default/logging, default/front-proxy
|
||||||
2 database, servicemesh
|
2 default/database, default/servicemesh
|
||||||
3 anotherbackend
|
3 default/anotherbackend
|
||||||
4 backend-v2
|
4 default/backend-v2
|
||||||
5 frontend-v3
|
5 default/frontend-v3
|
||||||
|
|
||||||
processing releases in group 1/5: logging, front-proxy
|
processing releases in group 1/5: default/logging, default/front-proxy
|
||||||
getting deployed release version failed:unexpected list key: {^logging$ --kube-contextdefault--deleting--deployed--failed--pending}
|
getting deployed release version failed:unexpected list key: {^logging$ --kube-contextdefault--deleting--deployed--failed--pending}
|
||||||
getting deployed release version failed:unexpected list key: {^front-proxy$ --kube-contextdefault--deleting--deployed--failed--pending}
|
getting deployed release version failed:unexpected list key: {^front-proxy$ --kube-contextdefault--deleting--deployed--failed--pending}
|
||||||
processing releases in group 2/5: database, servicemesh
|
processing releases in group 2/5: default/database, default/servicemesh
|
||||||
getting deployed release version failed:unexpected list key: {^database$ --kube-contextdefault--deleting--deployed--failed--pending}
|
getting deployed release version failed:unexpected list key: {^database$ --kube-contextdefault--deleting--deployed--failed--pending}
|
||||||
getting deployed release version failed:unexpected list key: {^servicemesh$ --kube-contextdefault--deleting--deployed--failed--pending}
|
getting deployed release version failed:unexpected list key: {^servicemesh$ --kube-contextdefault--deleting--deployed--failed--pending}
|
||||||
processing releases in group 3/5: anotherbackend
|
processing releases in group 3/5: default/anotherbackend
|
||||||
getting deployed release version failed:unexpected list key: {^anotherbackend$ --kube-contextdefault--deleting--deployed--failed--pending}
|
getting deployed release version failed:unexpected list key: {^anotherbackend$ --kube-contextdefault--deleting--deployed--failed--pending}
|
||||||
processing releases in group 4/5: backend-v2
|
processing releases in group 4/5: default/backend-v2
|
||||||
getting deployed release version failed:unexpected list key: {^backend-v2$ --kube-contextdefault--deleting--deployed--failed--pending}
|
getting deployed release version failed:unexpected list key: {^backend-v2$ --kube-contextdefault--deleting--deployed--failed--pending}
|
||||||
processing releases in group 5/5: frontend-v3
|
processing releases in group 5/5: default/frontend-v3
|
||||||
getting deployed release version failed:unexpected list key: {^frontend-v3$ --kube-contextdefault--deleting--deployed--failed--pending}
|
getting deployed release version failed:unexpected list key: {^frontend-v3$ --kube-contextdefault--deleting--deployed--failed--pending}
|
||||||
|
|
||||||
UPDATED RELEASES:
|
UPDATED RELEASES:
|
||||||
|
|
@ -3128,13 +3128,13 @@ Affected releases are:
|
||||||
|
|
||||||
processing 2 groups of releases in this order:
|
processing 2 groups of releases in this order:
|
||||||
GROUP RELEASES
|
GROUP RELEASES
|
||||||
1 baz, bar
|
1 default/baz, default/bar
|
||||||
2 foo
|
2 default/foo
|
||||||
|
|
||||||
processing releases in group 1/2: baz, bar
|
processing releases in group 1/2: default/baz, default/bar
|
||||||
getting deployed release version failed:unexpected list key: {^baz$ --kube-contextdefault--deleting--deployed--failed--pending}
|
getting deployed release version failed:unexpected list key: {^baz$ --kube-contextdefault--deleting--deployed--failed--pending}
|
||||||
getting deployed release version failed:unexpected list key: {^bar$ --kube-contextdefault--deleting--deployed--failed--pending}
|
getting deployed release version failed:unexpected list key: {^bar$ --kube-contextdefault--deleting--deployed--failed--pending}
|
||||||
processing releases in group 2/2: foo
|
processing releases in group 2/2: default/foo
|
||||||
getting deployed release version failed:unexpected list key: {^foo$ --kube-contextdefault--deleting--deployed--failed--pending}
|
getting deployed release version failed:unexpected list key: {^foo$ --kube-contextdefault--deleting--deployed--failed--pending}
|
||||||
|
|
||||||
UPDATED RELEASES:
|
UPDATED RELEASES:
|
||||||
|
|
@ -3238,11 +3238,11 @@ Affected releases are:
|
||||||
|
|
||||||
processing 2 groups of releases in this order:
|
processing 2 groups of releases in this order:
|
||||||
GROUP RELEASES
|
GROUP RELEASES
|
||||||
1 baz, bar
|
1 default/baz, default/bar
|
||||||
2 foo
|
2 default/foo
|
||||||
|
|
||||||
processing releases in group 1/2: baz, bar
|
processing releases in group 1/2: default/baz, default/bar
|
||||||
processing releases in group 2/2: foo
|
processing releases in group 2/2: default/foo
|
||||||
getting deployed release version failed:Failed to get the version for:mychart1
|
getting deployed release version failed:Failed to get the version for:mychart1
|
||||||
|
|
||||||
UPDATED RELEASES:
|
UPDATED RELEASES:
|
||||||
|
|
@ -3346,11 +3346,11 @@ Affected releases are:
|
||||||
|
|
||||||
processing 2 groups of releases in this order:
|
processing 2 groups of releases in this order:
|
||||||
GROUP RELEASES
|
GROUP RELEASES
|
||||||
1 baz, bar
|
1 default/baz, default/bar
|
||||||
2 foo
|
2 default/foo
|
||||||
|
|
||||||
processing releases in group 1/2: baz, bar
|
processing releases in group 1/2: default/baz, default/bar
|
||||||
processing releases in group 2/2: foo
|
processing releases in group 2/2: default/foo
|
||||||
getting deployed release version failed:Failed to get the version for:mychart1
|
getting deployed release version failed:Failed to get the version for:mychart1
|
||||||
|
|
||||||
UPDATED RELEASES:
|
UPDATED RELEASES:
|
||||||
|
|
@ -3611,12 +3611,12 @@ Affected releases are:
|
||||||
|
|
||||||
processing 2 groups of releases in this order:
|
processing 2 groups of releases in this order:
|
||||||
GROUP RELEASES
|
GROUP RELEASES
|
||||||
1 tns1/ns1/foo
|
1 default/tns1/ns1/foo
|
||||||
2 tns2/ns2/bar
|
2 default/tns2/ns2/bar
|
||||||
|
|
||||||
processing releases in group 1/2: tns1/ns1/foo
|
processing releases in group 1/2: default/tns1/ns1/foo
|
||||||
getting deployed release version failed:unexpected list key: {^foo$ --tiller-namespacetns1--kube-contextdefault--deleting--deployed--failed--pending}
|
getting deployed release version failed:unexpected list key: {^foo$ --tiller-namespacetns1--kube-contextdefault--deleting--deployed--failed--pending}
|
||||||
processing releases in group 2/2: tns2/ns2/bar
|
processing releases in group 2/2: default/tns2/ns2/bar
|
||||||
getting deployed release version failed:unexpected list key: {^bar$ --tiller-namespacetns2--kube-contextdefault--deleting--deployed--failed--pending}
|
getting deployed release version failed:unexpected list key: {^bar$ --tiller-namespacetns2--kube-contextdefault--deleting--deployed--failed--pending}
|
||||||
|
|
||||||
UPDATED RELEASES:
|
UPDATED RELEASES:
|
||||||
|
|
@ -3950,12 +3950,12 @@ Affected releases are:
|
||||||
|
|
||||||
processing 2 groups of releases in this order:
|
processing 2 groups of releases in this order:
|
||||||
GROUP RELEASES
|
GROUP RELEASES
|
||||||
1 default/external-secrets
|
1 default/default/external-secrets
|
||||||
2 default/my-release
|
2 default/default/my-release
|
||||||
|
|
||||||
processing releases in group 1/2: default/external-secrets
|
processing releases in group 1/2: default/default/external-secrets
|
||||||
getting deployed release version failed:unexpected list key: {^external-secrets$ --kube-contextdefault--deleting--deployed--failed--pending}
|
getting deployed release version failed:unexpected list key: {^external-secrets$ --kube-contextdefault--deleting--deployed--failed--pending}
|
||||||
processing releases in group 2/2: default/my-release
|
processing releases in group 2/2: default/default/my-release
|
||||||
getting deployed release version failed:unexpected list key: {^my-release$ --kube-contextdefault--deleting--deployed--failed--pending}
|
getting deployed release version failed:unexpected list key: {^my-release$ --kube-contextdefault--deleting--deployed--failed--pending}
|
||||||
|
|
||||||
UPDATED RELEASES:
|
UPDATED RELEASES:
|
||||||
|
|
@ -3973,7 +3973,7 @@ my-release incubator/raw
|
||||||
skipNeeds: false,
|
skipNeeds: false,
|
||||||
includeNeeds: true,
|
includeNeeds: true,
|
||||||
},
|
},
|
||||||
error: `in ./helmfile.yaml: release "default/external-secrets" depends on "kube-system/kubernetes-external-secrets" which does not match the selectors. Please add a selector like "--selector name=kubernetes-external-secrets", or indicate whether to skip (--skip-needs) or include (--include-needs) these dependencies`,
|
error: `in ./helmfile.yaml: release "default/default/external-secrets" depends on "default/kube-system/kubernetes-external-secrets" which does not match the selectors. Please add a selector like "--selector name=kubernetes-external-secrets", or indicate whether to skip (--skip-needs) or include (--include-needs) these dependencies`,
|
||||||
files: map[string]string{
|
files: map[string]string{
|
||||||
"/path/to/helmfile.yaml": `
|
"/path/to/helmfile.yaml": `
|
||||||
{{ $mark := "a" }}
|
{{ $mark := "a" }}
|
||||||
|
|
@ -4071,7 +4071,7 @@ second-pass rendering result of "helmfile.yaml.part.0":
|
||||||
merged environment: &{default map[] map[]}
|
merged environment: &{default map[] map[]}
|
||||||
2 release(s) matching app=test found in helmfile.yaml
|
2 release(s) matching app=test found in helmfile.yaml
|
||||||
|
|
||||||
err: release "default/external-secrets" depends on "kube-system/kubernetes-external-secrets" which does not match the selectors. Please add a selector like "--selector name=kubernetes-external-secrets", or indicate whether to skip (--skip-needs) or include (--include-needs) these dependencies
|
err: release "default/default/external-secrets" depends on "default/kube-system/kubernetes-external-secrets" which does not match the selectors. Please add a selector like "--selector name=kubernetes-external-secrets", or indicate whether to skip (--skip-needs) or include (--include-needs) these dependencies
|
||||||
`,
|
`,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
|
@ -4201,7 +4201,7 @@ releases:
|
||||||
upgraded: []exectest.Release{},
|
upgraded: []exectest.Release{},
|
||||||
deleted: []exectest.Release{},
|
deleted: []exectest.Release{},
|
||||||
concurrency: 1,
|
concurrency: 1,
|
||||||
error: `in ./helmfile.yaml: "foo" depends on nonexistent release "bar"`,
|
error: `in ./helmfile.yaml: "default/foo" depends on nonexistent release "default/bar"`,
|
||||||
log: `processing file "helmfile.yaml" in directory "."
|
log: `processing file "helmfile.yaml" in directory "."
|
||||||
first-pass rendering starting for "helmfile.yaml.part.0": inherited=&{default map[] map[]}, overrode=<nil>
|
first-pass rendering starting for "helmfile.yaml.part.0": inherited=&{default map[] map[]}, overrode=<nil>
|
||||||
first-pass uses: &{default map[] map[]}
|
first-pass uses: &{default map[] map[]}
|
||||||
|
|
@ -4237,7 +4237,7 @@ second-pass rendering result of "helmfile.yaml.part.0":
|
||||||
merged environment: &{default map[] map[]}
|
merged environment: &{default map[] map[]}
|
||||||
2 release(s) found in helmfile.yaml
|
2 release(s) found in helmfile.yaml
|
||||||
|
|
||||||
err: "foo" depends on nonexistent release "bar"
|
err: "default/foo" depends on nonexistent release "default/bar"
|
||||||
`,
|
`,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,765 @@
|
||||||
|
package app
|
||||||
|
|
||||||
|
import (
|
||||||
|
"bufio"
|
||||||
|
"bytes"
|
||||||
|
"io"
|
||||||
|
"path/filepath"
|
||||||
|
"sync"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/roboll/helmfile/pkg/exectest"
|
||||||
|
"github.com/roboll/helmfile/pkg/helmexec"
|
||||||
|
"github.com/roboll/helmfile/pkg/testhelper"
|
||||||
|
"github.com/variantdev/vals"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestDestroy_2(t *testing.T) {
|
||||||
|
type testcase struct {
|
||||||
|
helm3 bool
|
||||||
|
ns string
|
||||||
|
concurrency int
|
||||||
|
error string
|
||||||
|
files map[string]string
|
||||||
|
selectors []string
|
||||||
|
lists map[exectest.ListKey]string
|
||||||
|
diffs map[exectest.DiffKey]error
|
||||||
|
upgraded []exectest.Release
|
||||||
|
deleted []exectest.Release
|
||||||
|
log string
|
||||||
|
}
|
||||||
|
|
||||||
|
check := func(t *testing.T, tc testcase) {
|
||||||
|
t.Helper()
|
||||||
|
|
||||||
|
wantUpgrades := tc.upgraded
|
||||||
|
wantDeletes := tc.deleted
|
||||||
|
|
||||||
|
var helm = &exectest.Helm{
|
||||||
|
Helm3: tc.helm3,
|
||||||
|
FailOnUnexpectedList: true,
|
||||||
|
FailOnUnexpectedDiff: true,
|
||||||
|
Lists: tc.lists,
|
||||||
|
Diffs: tc.diffs,
|
||||||
|
DiffMutex: &sync.Mutex{},
|
||||||
|
ChartsMutex: &sync.Mutex{},
|
||||||
|
ReleasesMutex: &sync.Mutex{},
|
||||||
|
}
|
||||||
|
|
||||||
|
bs := &bytes.Buffer{}
|
||||||
|
|
||||||
|
func() {
|
||||||
|
t.Helper()
|
||||||
|
|
||||||
|
logReader, logWriter := io.Pipe()
|
||||||
|
|
||||||
|
logFlushed := &sync.WaitGroup{}
|
||||||
|
// Ensure all the log is consumed into `bs` by calling `logWriter.Close()` followed by `logFlushed.Wait()`
|
||||||
|
logFlushed.Add(1)
|
||||||
|
go func() {
|
||||||
|
scanner := bufio.NewScanner(logReader)
|
||||||
|
for scanner.Scan() {
|
||||||
|
bs.Write(scanner.Bytes())
|
||||||
|
bs.WriteString("\n")
|
||||||
|
}
|
||||||
|
logFlushed.Done()
|
||||||
|
}()
|
||||||
|
|
||||||
|
defer func() {
|
||||||
|
// This is here to avoid data-trace on bytes buffer `bs` to capture logs
|
||||||
|
if err := logWriter.Close(); err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
logFlushed.Wait()
|
||||||
|
}()
|
||||||
|
|
||||||
|
logger := helmexec.NewLogger(logWriter, "debug")
|
||||||
|
|
||||||
|
valsRuntime, err := vals.New(vals.Options{CacheSize: 32})
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("unexpected error creating vals runtime: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
app := appWithFs(&App{
|
||||||
|
OverrideHelmBinary: DefaultHelmBinary,
|
||||||
|
glob: filepath.Glob,
|
||||||
|
abs: filepath.Abs,
|
||||||
|
OverrideKubeContext: "",
|
||||||
|
Env: "default",
|
||||||
|
Logger: logger,
|
||||||
|
helms: map[helmKey]helmexec.Interface{
|
||||||
|
createHelmKey("helm", ""): helm,
|
||||||
|
},
|
||||||
|
valsRuntime: valsRuntime,
|
||||||
|
}, tc.files)
|
||||||
|
|
||||||
|
if tc.ns != "" {
|
||||||
|
app.Namespace = tc.ns
|
||||||
|
}
|
||||||
|
|
||||||
|
if tc.selectors != nil {
|
||||||
|
app.Selectors = tc.selectors
|
||||||
|
}
|
||||||
|
|
||||||
|
destroyErr := app.Destroy(destroyConfig{
|
||||||
|
// if we check log output, concurrency must be 1. otherwise the test becomes non-deterministic.
|
||||||
|
concurrency: tc.concurrency,
|
||||||
|
logger: logger,
|
||||||
|
})
|
||||||
|
|
||||||
|
if tc.error == "" && destroyErr != nil {
|
||||||
|
t.Fatalf("unexpected error: %v", destroyErr)
|
||||||
|
} else if tc.error != "" && destroyErr == nil {
|
||||||
|
t.Fatal("expected error did not occur")
|
||||||
|
} else if tc.error != "" && destroyErr != nil && tc.error != destroyErr.Error() {
|
||||||
|
t.Fatalf("invalid error: expected %q, got %q", tc.error, destroyErr.Error())
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(wantUpgrades) > len(helm.Releases) {
|
||||||
|
t.Fatalf("insufficient number of upgrades: got %d, want %d", len(helm.Releases), len(wantUpgrades))
|
||||||
|
}
|
||||||
|
|
||||||
|
for relIdx := range wantUpgrades {
|
||||||
|
if wantUpgrades[relIdx].Name != helm.Releases[relIdx].Name {
|
||||||
|
t.Errorf("releases[%d].name: got %q, want %q", relIdx, helm.Releases[relIdx].Name, wantUpgrades[relIdx].Name)
|
||||||
|
}
|
||||||
|
for flagIdx := range wantUpgrades[relIdx].Flags {
|
||||||
|
if wantUpgrades[relIdx].Flags[flagIdx] != helm.Releases[relIdx].Flags[flagIdx] {
|
||||||
|
t.Errorf("releaes[%d].flags[%d]: got %v, want %v", relIdx, flagIdx, helm.Releases[relIdx].Flags[flagIdx], wantUpgrades[relIdx].Flags[flagIdx])
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(wantDeletes) > len(helm.Deleted) {
|
||||||
|
t.Fatalf("insufficient number of deletes: got %d, want %d", len(helm.Deleted), len(wantDeletes))
|
||||||
|
}
|
||||||
|
|
||||||
|
for relIdx := range wantDeletes {
|
||||||
|
if wantDeletes[relIdx].Name != helm.Deleted[relIdx].Name {
|
||||||
|
t.Errorf("releases[%d].name: got %q, want %q", relIdx, helm.Deleted[relIdx].Name, wantDeletes[relIdx].Name)
|
||||||
|
}
|
||||||
|
for flagIdx := range wantDeletes[relIdx].Flags {
|
||||||
|
if wantDeletes[relIdx].Flags[flagIdx] != helm.Deleted[relIdx].Flags[flagIdx] {
|
||||||
|
t.Errorf("releaes[%d].flags[%d]: got %v, want %v", relIdx, flagIdx, helm.Deleted[relIdx].Flags[flagIdx], wantDeletes[relIdx].Flags[flagIdx])
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}()
|
||||||
|
|
||||||
|
if tc.log != "" {
|
||||||
|
actual := bs.String()
|
||||||
|
|
||||||
|
diff, exists := testhelper.Diff(tc.log, actual, 3)
|
||||||
|
if exists {
|
||||||
|
t.Errorf("unexpected log:\nDIFF\n%s\nEOD", diff)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
files := map[string]string{
|
||||||
|
"/path/to/helmfile.yaml": `
|
||||||
|
releases:
|
||||||
|
- name: database
|
||||||
|
chart: charts/mysql
|
||||||
|
needs:
|
||||||
|
- logging
|
||||||
|
- name: frontend-v1
|
||||||
|
chart: charts/frontend
|
||||||
|
installed: false
|
||||||
|
needs:
|
||||||
|
- servicemesh
|
||||||
|
- logging
|
||||||
|
- backend-v1
|
||||||
|
- name: frontend-v2
|
||||||
|
chart: charts/frontend
|
||||||
|
needs:
|
||||||
|
- servicemesh
|
||||||
|
- logging
|
||||||
|
- backend-v2
|
||||||
|
- name: frontend-v3
|
||||||
|
chart: charts/frontend
|
||||||
|
needs:
|
||||||
|
- servicemesh
|
||||||
|
- logging
|
||||||
|
- backend-v2
|
||||||
|
- name: backend-v1
|
||||||
|
chart: charts/backend
|
||||||
|
installed: false
|
||||||
|
needs:
|
||||||
|
- servicemesh
|
||||||
|
- logging
|
||||||
|
- database
|
||||||
|
- anotherbackend
|
||||||
|
- name: backend-v2
|
||||||
|
chart: charts/backend
|
||||||
|
needs:
|
||||||
|
- servicemesh
|
||||||
|
- logging
|
||||||
|
- database
|
||||||
|
- anotherbackend
|
||||||
|
- name: anotherbackend
|
||||||
|
chart: charts/anotherbackend
|
||||||
|
needs:
|
||||||
|
- servicemesh
|
||||||
|
- logging
|
||||||
|
- database
|
||||||
|
- name: servicemesh
|
||||||
|
chart: charts/istio
|
||||||
|
needs:
|
||||||
|
- logging
|
||||||
|
- name: logging
|
||||||
|
chart: charts/fluent-bit
|
||||||
|
- name: front-proxy
|
||||||
|
chart: stable/envoy
|
||||||
|
`,
|
||||||
|
}
|
||||||
|
|
||||||
|
filesForTwoReleases := map[string]string{
|
||||||
|
"/path/to/helmfile.yaml": `
|
||||||
|
releases:
|
||||||
|
- name: backend-v1
|
||||||
|
chart: charts/backend
|
||||||
|
installed: false
|
||||||
|
- name: frontend-v1
|
||||||
|
chart: charts/frontend
|
||||||
|
needs:
|
||||||
|
- backend-v1
|
||||||
|
`,
|
||||||
|
}
|
||||||
|
|
||||||
|
t.Run("smoke", func(t *testing.T) {
|
||||||
|
//
|
||||||
|
// complex test cases for smoke testing
|
||||||
|
//
|
||||||
|
check(t, testcase{
|
||||||
|
files: files,
|
||||||
|
diffs: map[exectest.DiffKey]error{},
|
||||||
|
lists: map[exectest.ListKey]string{
|
||||||
|
exectest.ListKey{Filter: "^frontend-v1$", Flags: helmV2ListFlagsWithoutKubeContext}: `NAME REVISION UPDATED STATUS CHART APP VERSION NAMESPACE
|
||||||
|
`,
|
||||||
|
exectest.ListKey{Filter: "^frontend-v2$", Flags: helmV2ListFlagsWithoutKubeContext}: `NAME REVISION UPDATED STATUS CHART APP VERSION NAMESPACE
|
||||||
|
frontend-v2 4 Fri Nov 1 08:40:07 2019 DEPLOYED frontend-3.1.0 3.1.0 default
|
||||||
|
`,
|
||||||
|
exectest.ListKey{Filter: "^frontend-v3$", Flags: helmV2ListFlagsWithoutKubeContext}: `NAME REVISION UPDATED STATUS CHART APP VERSION NAMESPACE
|
||||||
|
frontend-v3 4 Fri Nov 1 08:40:07 2019 DEPLOYED frontend-3.1.0 3.1.0 default
|
||||||
|
`,
|
||||||
|
exectest.ListKey{Filter: "^backend-v1$", Flags: helmV2ListFlagsWithoutKubeContext}: `NAME REVISION UPDATED STATUS CHART APP VERSION NAMESPACE
|
||||||
|
`,
|
||||||
|
exectest.ListKey{Filter: "^backend-v2$", Flags: helmV2ListFlagsWithoutKubeContext}: `NAME REVISION UPDATED STATUS CHART APP VERSION NAMESPACE
|
||||||
|
backend-v2 4 Fri Nov 1 08:40:07 2019 DEPLOYED backend-3.1.0 3.1.0 default
|
||||||
|
`,
|
||||||
|
exectest.ListKey{Filter: "^logging$", Flags: helmV2ListFlagsWithoutKubeContext}: `NAME REVISION UPDATED STATUS CHART APP VERSION NAMESPACE
|
||||||
|
logging 4 Fri Nov 1 08:40:07 2019 DEPLOYED fluent-bit-3.1.0 3.1.0 default
|
||||||
|
`,
|
||||||
|
exectest.ListKey{Filter: "^front-proxy$", Flags: helmV2ListFlagsWithoutKubeContext}: `NAME REVISION UPDATED STATUS CHART APP VERSION NAMESPACE
|
||||||
|
front-proxy 4 Fri Nov 1 08:40:07 2019 DEPLOYED envoy-3.1.0 3.1.0 default
|
||||||
|
`,
|
||||||
|
exectest.ListKey{Filter: "^servicemesh$", Flags: helmV2ListFlagsWithoutKubeContext}: `NAME REVISION UPDATED STATUS CHART APP VERSION NAMESPACE
|
||||||
|
servicemesh 4 Fri Nov 1 08:40:07 2019 DEPLOYED istio-3.1.0 3.1.0 default
|
||||||
|
`,
|
||||||
|
exectest.ListKey{Filter: "^database$", Flags: helmV2ListFlagsWithoutKubeContext}: `NAME REVISION UPDATED STATUS CHART APP VERSION NAMESPACE
|
||||||
|
database 4 Fri Nov 1 08:40:07 2019 DEPLOYED mysql-3.1.0 3.1.0 default
|
||||||
|
`,
|
||||||
|
exectest.ListKey{Filter: "^anotherbackend$", Flags: helmV2ListFlagsWithoutKubeContext}: `NAME REVISION UPDATED STATUS CHART APP VERSION NAMESPACE
|
||||||
|
anotherbackend 4 Fri Nov 1 08:40:07 2019 DEPLOYED anotherbackend-3.1.0 3.1.0 default
|
||||||
|
`,
|
||||||
|
},
|
||||||
|
// Disable concurrency to avoid in-deterministic result
|
||||||
|
concurrency: 1,
|
||||||
|
upgraded: []exectest.Release{},
|
||||||
|
deleted: []exectest.Release{
|
||||||
|
{Name: "frontend-v3", Flags: []string{}},
|
||||||
|
{Name: "frontend-v2", Flags: []string{}},
|
||||||
|
{Name: "frontend-v1", Flags: []string{}},
|
||||||
|
{Name: "backend-v2", Flags: []string{}},
|
||||||
|
{Name: "backend-v1", Flags: []string{}},
|
||||||
|
{Name: "anotherbackend", Flags: []string{}},
|
||||||
|
{Name: "servicemesh", Flags: []string{}},
|
||||||
|
{Name: "database", Flags: []string{}},
|
||||||
|
{Name: "front-proxy", Flags: []string{}},
|
||||||
|
{Name: "logging", Flags: []string{}},
|
||||||
|
},
|
||||||
|
log: `processing file "helmfile.yaml" in directory "."
|
||||||
|
first-pass rendering starting for "helmfile.yaml.part.0": inherited=&{default map[] map[]}, overrode=<nil>
|
||||||
|
first-pass uses: &{default map[] map[]}
|
||||||
|
first-pass rendering output of "helmfile.yaml.part.0":
|
||||||
|
0:
|
||||||
|
1: releases:
|
||||||
|
2: - name: database
|
||||||
|
3: chart: charts/mysql
|
||||||
|
4: needs:
|
||||||
|
5: - logging
|
||||||
|
6: - name: frontend-v1
|
||||||
|
7: chart: charts/frontend
|
||||||
|
8: installed: false
|
||||||
|
9: needs:
|
||||||
|
10: - servicemesh
|
||||||
|
11: - logging
|
||||||
|
12: - backend-v1
|
||||||
|
13: - name: frontend-v2
|
||||||
|
14: chart: charts/frontend
|
||||||
|
15: needs:
|
||||||
|
16: - servicemesh
|
||||||
|
17: - logging
|
||||||
|
18: - backend-v2
|
||||||
|
19: - name: frontend-v3
|
||||||
|
20: chart: charts/frontend
|
||||||
|
21: needs:
|
||||||
|
22: - servicemesh
|
||||||
|
23: - logging
|
||||||
|
24: - backend-v2
|
||||||
|
25: - name: backend-v1
|
||||||
|
26: chart: charts/backend
|
||||||
|
27: installed: false
|
||||||
|
28: needs:
|
||||||
|
29: - servicemesh
|
||||||
|
30: - logging
|
||||||
|
31: - database
|
||||||
|
32: - anotherbackend
|
||||||
|
33: - name: backend-v2
|
||||||
|
34: chart: charts/backend
|
||||||
|
35: needs:
|
||||||
|
36: - servicemesh
|
||||||
|
37: - logging
|
||||||
|
38: - database
|
||||||
|
39: - anotherbackend
|
||||||
|
40: - name: anotherbackend
|
||||||
|
41: chart: charts/anotherbackend
|
||||||
|
42: needs:
|
||||||
|
43: - servicemesh
|
||||||
|
44: - logging
|
||||||
|
45: - database
|
||||||
|
46: - name: servicemesh
|
||||||
|
47: chart: charts/istio
|
||||||
|
48: needs:
|
||||||
|
49: - logging
|
||||||
|
50: - name: logging
|
||||||
|
51: chart: charts/fluent-bit
|
||||||
|
52: - name: front-proxy
|
||||||
|
53: chart: stable/envoy
|
||||||
|
54:
|
||||||
|
|
||||||
|
first-pass produced: &{default map[] map[]}
|
||||||
|
first-pass rendering result of "helmfile.yaml.part.0": {default map[] map[]}
|
||||||
|
vals:
|
||||||
|
map[]
|
||||||
|
defaultVals:[]
|
||||||
|
second-pass rendering result of "helmfile.yaml.part.0":
|
||||||
|
0:
|
||||||
|
1: releases:
|
||||||
|
2: - name: database
|
||||||
|
3: chart: charts/mysql
|
||||||
|
4: needs:
|
||||||
|
5: - logging
|
||||||
|
6: - name: frontend-v1
|
||||||
|
7: chart: charts/frontend
|
||||||
|
8: installed: false
|
||||||
|
9: needs:
|
||||||
|
10: - servicemesh
|
||||||
|
11: - logging
|
||||||
|
12: - backend-v1
|
||||||
|
13: - name: frontend-v2
|
||||||
|
14: chart: charts/frontend
|
||||||
|
15: needs:
|
||||||
|
16: - servicemesh
|
||||||
|
17: - logging
|
||||||
|
18: - backend-v2
|
||||||
|
19: - name: frontend-v3
|
||||||
|
20: chart: charts/frontend
|
||||||
|
21: needs:
|
||||||
|
22: - servicemesh
|
||||||
|
23: - logging
|
||||||
|
24: - backend-v2
|
||||||
|
25: - name: backend-v1
|
||||||
|
26: chart: charts/backend
|
||||||
|
27: installed: false
|
||||||
|
28: needs:
|
||||||
|
29: - servicemesh
|
||||||
|
30: - logging
|
||||||
|
31: - database
|
||||||
|
32: - anotherbackend
|
||||||
|
33: - name: backend-v2
|
||||||
|
34: chart: charts/backend
|
||||||
|
35: needs:
|
||||||
|
36: - servicemesh
|
||||||
|
37: - logging
|
||||||
|
38: - database
|
||||||
|
39: - anotherbackend
|
||||||
|
40: - name: anotherbackend
|
||||||
|
41: chart: charts/anotherbackend
|
||||||
|
42: needs:
|
||||||
|
43: - servicemesh
|
||||||
|
44: - logging
|
||||||
|
45: - database
|
||||||
|
46: - name: servicemesh
|
||||||
|
47: chart: charts/istio
|
||||||
|
48: needs:
|
||||||
|
49: - logging
|
||||||
|
50: - name: logging
|
||||||
|
51: chart: charts/fluent-bit
|
||||||
|
52: - name: front-proxy
|
||||||
|
53: chart: stable/envoy
|
||||||
|
54:
|
||||||
|
|
||||||
|
merged environment: &{default map[] map[]}
|
||||||
|
10 release(s) found in helmfile.yaml
|
||||||
|
|
||||||
|
processing 5 groups of releases in this order:
|
||||||
|
GROUP RELEASES
|
||||||
|
1 frontend-v3, frontend-v2, frontend-v1
|
||||||
|
2 backend-v2, backend-v1
|
||||||
|
3 anotherbackend
|
||||||
|
4 servicemesh, database
|
||||||
|
5 front-proxy, logging
|
||||||
|
|
||||||
|
processing releases in group 1/5: frontend-v3, frontend-v2, frontend-v1
|
||||||
|
release "frontend-v3" processed
|
||||||
|
release "frontend-v2" processed
|
||||||
|
release "frontend-v1" processed
|
||||||
|
processing releases in group 2/5: backend-v2, backend-v1
|
||||||
|
release "backend-v2" processed
|
||||||
|
release "backend-v1" processed
|
||||||
|
processing releases in group 3/5: anotherbackend
|
||||||
|
release "anotherbackend" processed
|
||||||
|
processing releases in group 4/5: servicemesh, database
|
||||||
|
release "servicemesh" processed
|
||||||
|
release "database" processed
|
||||||
|
processing releases in group 5/5: front-proxy, logging
|
||||||
|
release "front-proxy" processed
|
||||||
|
release "logging" processed
|
||||||
|
|
||||||
|
DELETED RELEASES:
|
||||||
|
NAME
|
||||||
|
frontend-v3
|
||||||
|
frontend-v2
|
||||||
|
frontend-v1
|
||||||
|
backend-v2
|
||||||
|
backend-v1
|
||||||
|
anotherbackend
|
||||||
|
servicemesh
|
||||||
|
database
|
||||||
|
front-proxy
|
||||||
|
logging
|
||||||
|
`,
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
t.Run("destroy only one release with selector", func(t *testing.T) {
|
||||||
|
check(t, testcase{
|
||||||
|
files: files,
|
||||||
|
selectors: []string{"name=logging"},
|
||||||
|
diffs: map[exectest.DiffKey]error{},
|
||||||
|
lists: map[exectest.ListKey]string{
|
||||||
|
exectest.ListKey{Filter: "^frontend-v1$", Flags: helmV2ListFlagsWithoutKubeContext}: `NAME REVISION UPDATED STATUS CHART APP VERSION NAMESPACE
|
||||||
|
`,
|
||||||
|
exectest.ListKey{Filter: "^frontend-v2$", Flags: helmV2ListFlagsWithoutKubeContext}: `NAME REVISION UPDATED STATUS CHART APP VERSION NAMESPACE
|
||||||
|
frontend-v2 4 Fri Nov 1 08:40:07 2019 DEPLOYED frontend-3.1.0 3.1.0 default
|
||||||
|
`,
|
||||||
|
exectest.ListKey{Filter: "^frontend-v3$", Flags: helmV2ListFlagsWithoutKubeContext}: `NAME REVISION UPDATED STATUS CHART APP VERSION NAMESPACE
|
||||||
|
frontend-v3 4 Fri Nov 1 08:40:07 2019 DEPLOYED frontend-3.1.0 3.1.0 default
|
||||||
|
`,
|
||||||
|
exectest.ListKey{Filter: "^backend-v1$", Flags: helmV2ListFlagsWithoutKubeContext}: `NAME REVISION UPDATED STATUS CHART APP VERSION NAMESPACE
|
||||||
|
`,
|
||||||
|
exectest.ListKey{Filter: "^backend-v2$", Flags: helmV2ListFlagsWithoutKubeContext}: `NAME REVISION UPDATED STATUS CHART APP VERSION NAMESPACE
|
||||||
|
backend-v2 4 Fri Nov 1 08:40:07 2019 DEPLOYED backend-3.1.0 3.1.0 default
|
||||||
|
`,
|
||||||
|
exectest.ListKey{Filter: "^logging$", Flags: helmV2ListFlagsWithoutKubeContext}: `NAME REVISION UPDATED STATUS CHART APP VERSION NAMESPACE
|
||||||
|
logging 4 Fri Nov 1 08:40:07 2019 DEPLOYED fluent-bit-3.1.0 3.1.0 default
|
||||||
|
`,
|
||||||
|
exectest.ListKey{Filter: "^front-proxy$", Flags: helmV2ListFlagsWithoutKubeContext}: `NAME REVISION UPDATED STATUS CHART APP VERSION NAMESPACE
|
||||||
|
front-proxy 4 Fri Nov 1 08:40:07 2019 DEPLOYED envoy-3.1.0 3.1.0 default
|
||||||
|
`,
|
||||||
|
exectest.ListKey{Filter: "^servicemesh$", Flags: helmV2ListFlagsWithoutKubeContext}: `NAME REVISION UPDATED STATUS CHART APP VERSION NAMESPACE
|
||||||
|
servicemesh 4 Fri Nov 1 08:40:07 2019 DEPLOYED istio-3.1.0 3.1.0 default
|
||||||
|
`,
|
||||||
|
exectest.ListKey{Filter: "^database$", Flags: helmV2ListFlagsWithoutKubeContext}: `NAME REVISION UPDATED STATUS CHART APP VERSION NAMESPACE
|
||||||
|
database 4 Fri Nov 1 08:40:07 2019 DEPLOYED mysql-3.1.0 3.1.0 default
|
||||||
|
`,
|
||||||
|
exectest.ListKey{Filter: "^anotherbackend$", Flags: helmV2ListFlagsWithoutKubeContext}: `NAME REVISION UPDATED STATUS CHART APP VERSION NAMESPACE
|
||||||
|
anotherbackend 4 Fri Nov 1 08:40:07 2019 DEPLOYED anotherbackend-3.1.0 3.1.0 default
|
||||||
|
`,
|
||||||
|
},
|
||||||
|
// Disable concurrency to avoid in-deterministic result
|
||||||
|
concurrency: 1,
|
||||||
|
upgraded: []exectest.Release{},
|
||||||
|
deleted: []exectest.Release{
|
||||||
|
{Name: "logging", Flags: []string{}},
|
||||||
|
},
|
||||||
|
log: `processing file "helmfile.yaml" in directory "."
|
||||||
|
first-pass rendering starting for "helmfile.yaml.part.0": inherited=&{default map[] map[]}, overrode=<nil>
|
||||||
|
first-pass uses: &{default map[] map[]}
|
||||||
|
first-pass rendering output of "helmfile.yaml.part.0":
|
||||||
|
0:
|
||||||
|
1: releases:
|
||||||
|
2: - name: database
|
||||||
|
3: chart: charts/mysql
|
||||||
|
4: needs:
|
||||||
|
5: - logging
|
||||||
|
6: - name: frontend-v1
|
||||||
|
7: chart: charts/frontend
|
||||||
|
8: installed: false
|
||||||
|
9: needs:
|
||||||
|
10: - servicemesh
|
||||||
|
11: - logging
|
||||||
|
12: - backend-v1
|
||||||
|
13: - name: frontend-v2
|
||||||
|
14: chart: charts/frontend
|
||||||
|
15: needs:
|
||||||
|
16: - servicemesh
|
||||||
|
17: - logging
|
||||||
|
18: - backend-v2
|
||||||
|
19: - name: frontend-v3
|
||||||
|
20: chart: charts/frontend
|
||||||
|
21: needs:
|
||||||
|
22: - servicemesh
|
||||||
|
23: - logging
|
||||||
|
24: - backend-v2
|
||||||
|
25: - name: backend-v1
|
||||||
|
26: chart: charts/backend
|
||||||
|
27: installed: false
|
||||||
|
28: needs:
|
||||||
|
29: - servicemesh
|
||||||
|
30: - logging
|
||||||
|
31: - database
|
||||||
|
32: - anotherbackend
|
||||||
|
33: - name: backend-v2
|
||||||
|
34: chart: charts/backend
|
||||||
|
35: needs:
|
||||||
|
36: - servicemesh
|
||||||
|
37: - logging
|
||||||
|
38: - database
|
||||||
|
39: - anotherbackend
|
||||||
|
40: - name: anotherbackend
|
||||||
|
41: chart: charts/anotherbackend
|
||||||
|
42: needs:
|
||||||
|
43: - servicemesh
|
||||||
|
44: - logging
|
||||||
|
45: - database
|
||||||
|
46: - name: servicemesh
|
||||||
|
47: chart: charts/istio
|
||||||
|
48: needs:
|
||||||
|
49: - logging
|
||||||
|
50: - name: logging
|
||||||
|
51: chart: charts/fluent-bit
|
||||||
|
52: - name: front-proxy
|
||||||
|
53: chart: stable/envoy
|
||||||
|
54:
|
||||||
|
|
||||||
|
first-pass produced: &{default map[] map[]}
|
||||||
|
first-pass rendering result of "helmfile.yaml.part.0": {default map[] map[]}
|
||||||
|
vals:
|
||||||
|
map[]
|
||||||
|
defaultVals:[]
|
||||||
|
second-pass rendering result of "helmfile.yaml.part.0":
|
||||||
|
0:
|
||||||
|
1: releases:
|
||||||
|
2: - name: database
|
||||||
|
3: chart: charts/mysql
|
||||||
|
4: needs:
|
||||||
|
5: - logging
|
||||||
|
6: - name: frontend-v1
|
||||||
|
7: chart: charts/frontend
|
||||||
|
8: installed: false
|
||||||
|
9: needs:
|
||||||
|
10: - servicemesh
|
||||||
|
11: - logging
|
||||||
|
12: - backend-v1
|
||||||
|
13: - name: frontend-v2
|
||||||
|
14: chart: charts/frontend
|
||||||
|
15: needs:
|
||||||
|
16: - servicemesh
|
||||||
|
17: - logging
|
||||||
|
18: - backend-v2
|
||||||
|
19: - name: frontend-v3
|
||||||
|
20: chart: charts/frontend
|
||||||
|
21: needs:
|
||||||
|
22: - servicemesh
|
||||||
|
23: - logging
|
||||||
|
24: - backend-v2
|
||||||
|
25: - name: backend-v1
|
||||||
|
26: chart: charts/backend
|
||||||
|
27: installed: false
|
||||||
|
28: needs:
|
||||||
|
29: - servicemesh
|
||||||
|
30: - logging
|
||||||
|
31: - database
|
||||||
|
32: - anotherbackend
|
||||||
|
33: - name: backend-v2
|
||||||
|
34: chart: charts/backend
|
||||||
|
35: needs:
|
||||||
|
36: - servicemesh
|
||||||
|
37: - logging
|
||||||
|
38: - database
|
||||||
|
39: - anotherbackend
|
||||||
|
40: - name: anotherbackend
|
||||||
|
41: chart: charts/anotherbackend
|
||||||
|
42: needs:
|
||||||
|
43: - servicemesh
|
||||||
|
44: - logging
|
||||||
|
45: - database
|
||||||
|
46: - name: servicemesh
|
||||||
|
47: chart: charts/istio
|
||||||
|
48: needs:
|
||||||
|
49: - logging
|
||||||
|
50: - name: logging
|
||||||
|
51: chart: charts/fluent-bit
|
||||||
|
52: - name: front-proxy
|
||||||
|
53: chart: stable/envoy
|
||||||
|
54:
|
||||||
|
|
||||||
|
merged environment: &{default map[] map[]}
|
||||||
|
1 release(s) matching name=logging found in helmfile.yaml
|
||||||
|
|
||||||
|
processing 1 groups of releases in this order:
|
||||||
|
GROUP RELEASES
|
||||||
|
1 logging
|
||||||
|
|
||||||
|
processing releases in group 1/1: logging
|
||||||
|
release "logging" processed
|
||||||
|
|
||||||
|
DELETED RELEASES:
|
||||||
|
NAME
|
||||||
|
logging
|
||||||
|
`,
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
t.Run("destroy installed but disabled release", func(t *testing.T) {
|
||||||
|
check(t, testcase{
|
||||||
|
files: filesForTwoReleases,
|
||||||
|
diffs: map[exectest.DiffKey]error{},
|
||||||
|
lists: map[exectest.ListKey]string{
|
||||||
|
exectest.ListKey{Filter: "^frontend-v1$", Flags: helmV2ListFlagsWithoutKubeContext}: `NAME REVISION UPDATED STATUS CHART APP VERSION NAMESPACE
|
||||||
|
`,
|
||||||
|
exectest.ListKey{Filter: "^backend-v1$", Flags: helmV2ListFlagsWithoutKubeContext}: `NAME REVISION UPDATED STATUS CHART APP VERSION NAMESPACE
|
||||||
|
`,
|
||||||
|
},
|
||||||
|
// Disable concurrency to avoid in-deterministic result
|
||||||
|
concurrency: 1,
|
||||||
|
upgraded: []exectest.Release{},
|
||||||
|
deleted: []exectest.Release{
|
||||||
|
{Name: "frontend-v1", Flags: []string{}},
|
||||||
|
},
|
||||||
|
log: `processing file "helmfile.yaml" in directory "."
|
||||||
|
first-pass rendering starting for "helmfile.yaml.part.0": inherited=&{default map[] map[]}, overrode=<nil>
|
||||||
|
first-pass uses: &{default map[] map[]}
|
||||||
|
first-pass rendering output of "helmfile.yaml.part.0":
|
||||||
|
0:
|
||||||
|
1: releases:
|
||||||
|
2: - name: backend-v1
|
||||||
|
3: chart: charts/backend
|
||||||
|
4: installed: false
|
||||||
|
5: - name: frontend-v1
|
||||||
|
6: chart: charts/frontend
|
||||||
|
7: needs:
|
||||||
|
8: - backend-v1
|
||||||
|
9:
|
||||||
|
|
||||||
|
first-pass produced: &{default map[] map[]}
|
||||||
|
first-pass rendering result of "helmfile.yaml.part.0": {default map[] map[]}
|
||||||
|
vals:
|
||||||
|
map[]
|
||||||
|
defaultVals:[]
|
||||||
|
second-pass rendering result of "helmfile.yaml.part.0":
|
||||||
|
0:
|
||||||
|
1: releases:
|
||||||
|
2: - name: backend-v1
|
||||||
|
3: chart: charts/backend
|
||||||
|
4: installed: false
|
||||||
|
5: - name: frontend-v1
|
||||||
|
6: chart: charts/frontend
|
||||||
|
7: needs:
|
||||||
|
8: - backend-v1
|
||||||
|
9:
|
||||||
|
|
||||||
|
merged environment: &{default map[] map[]}
|
||||||
|
2 release(s) found in helmfile.yaml
|
||||||
|
|
||||||
|
processing 2 groups of releases in this order:
|
||||||
|
GROUP RELEASES
|
||||||
|
1 frontend-v1
|
||||||
|
2 backend-v1
|
||||||
|
|
||||||
|
processing releases in group 1/2: frontend-v1
|
||||||
|
release "frontend-v1" processed
|
||||||
|
processing releases in group 2/2: backend-v1
|
||||||
|
release "backend-v1" processed
|
||||||
|
|
||||||
|
DELETED RELEASES:
|
||||||
|
NAME
|
||||||
|
frontend-v1
|
||||||
|
backend-v1
|
||||||
|
`,
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
t.Run("helm3", func(t *testing.T) {
|
||||||
|
check(t, testcase{
|
||||||
|
helm3: true,
|
||||||
|
files: filesForTwoReleases,
|
||||||
|
diffs: map[exectest.DiffKey]error{},
|
||||||
|
lists: map[exectest.ListKey]string{
|
||||||
|
exectest.ListKey{Filter: "^frontend-v1$", Flags: helmV3ListFlagsWithoutKubeContext}: `NAME REVISION UPDATED STATUS CHART APP VERSION NAMESPACE
|
||||||
|
`,
|
||||||
|
exectest.ListKey{Filter: "^backend-v1$", Flags: helmV3ListFlagsWithoutKubeContext}: `NAME REVISION UPDATED STATUS CHART APP VERSION NAMESPACE
|
||||||
|
`,
|
||||||
|
},
|
||||||
|
// Disable concurrency to avoid in-deterministic result
|
||||||
|
concurrency: 1,
|
||||||
|
upgraded: []exectest.Release{},
|
||||||
|
deleted: []exectest.Release{
|
||||||
|
{Name: "frontend-v1", Flags: []string{}},
|
||||||
|
},
|
||||||
|
log: `processing file "helmfile.yaml" in directory "."
|
||||||
|
first-pass rendering starting for "helmfile.yaml.part.0": inherited=&{default map[] map[]}, overrode=<nil>
|
||||||
|
first-pass uses: &{default map[] map[]}
|
||||||
|
first-pass rendering output of "helmfile.yaml.part.0":
|
||||||
|
0:
|
||||||
|
1: releases:
|
||||||
|
2: - name: backend-v1
|
||||||
|
3: chart: charts/backend
|
||||||
|
4: installed: false
|
||||||
|
5: - name: frontend-v1
|
||||||
|
6: chart: charts/frontend
|
||||||
|
7: needs:
|
||||||
|
8: - backend-v1
|
||||||
|
9:
|
||||||
|
|
||||||
|
first-pass produced: &{default map[] map[]}
|
||||||
|
first-pass rendering result of "helmfile.yaml.part.0": {default map[] map[]}
|
||||||
|
vals:
|
||||||
|
map[]
|
||||||
|
defaultVals:[]
|
||||||
|
second-pass rendering result of "helmfile.yaml.part.0":
|
||||||
|
0:
|
||||||
|
1: releases:
|
||||||
|
2: - name: backend-v1
|
||||||
|
3: chart: charts/backend
|
||||||
|
4: installed: false
|
||||||
|
5: - name: frontend-v1
|
||||||
|
6: chart: charts/frontend
|
||||||
|
7: needs:
|
||||||
|
8: - backend-v1
|
||||||
|
9:
|
||||||
|
|
||||||
|
merged environment: &{default map[] map[]}
|
||||||
|
2 release(s) found in helmfile.yaml
|
||||||
|
|
||||||
|
processing 2 groups of releases in this order:
|
||||||
|
GROUP RELEASES
|
||||||
|
1 frontend-v1
|
||||||
|
2 backend-v1
|
||||||
|
|
||||||
|
processing releases in group 1/2: frontend-v1
|
||||||
|
release "frontend-v1" processed
|
||||||
|
processing releases in group 2/2: backend-v1
|
||||||
|
release "backend-v1" processed
|
||||||
|
|
||||||
|
DELETED RELEASES:
|
||||||
|
NAME
|
||||||
|
frontend-v1
|
||||||
|
backend-v1
|
||||||
|
`,
|
||||||
|
})
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
@ -17,7 +17,9 @@ import (
|
||||||
|
|
||||||
const (
|
const (
|
||||||
helmV2ListFlags = "--kube-contextdefault--deleting--deployed--failed--pending"
|
helmV2ListFlags = "--kube-contextdefault--deleting--deployed--failed--pending"
|
||||||
|
helmV2ListFlagsWithoutKubeContext = "--deleting--deployed--failed--pending"
|
||||||
helmV3ListFlags = "--kube-contextdefault--uninstalling--deployed--failed--pending"
|
helmV3ListFlags = "--kube-contextdefault--uninstalling--deployed--failed--pending"
|
||||||
|
helmV3ListFlagsWithoutKubeContext = "--uninstalling--deployed--failed--pending"
|
||||||
)
|
)
|
||||||
|
|
||||||
type destroyConfig struct {
|
type destroyConfig struct {
|
||||||
|
|
@ -435,25 +437,25 @@ merged environment: &{default map[] map[]}
|
||||||
|
|
||||||
processing 5 groups of releases in this order:
|
processing 5 groups of releases in this order:
|
||||||
GROUP RELEASES
|
GROUP RELEASES
|
||||||
1 frontend-v3, frontend-v2, frontend-v1
|
1 default/frontend-v3, default/frontend-v2, default/frontend-v1
|
||||||
2 backend-v2, backend-v1
|
2 default/backend-v2, default/backend-v1
|
||||||
3 anotherbackend
|
3 default/anotherbackend
|
||||||
4 servicemesh, database
|
4 default/servicemesh, default/database
|
||||||
5 front-proxy, logging
|
5 default/front-proxy, default/logging
|
||||||
|
|
||||||
processing releases in group 1/5: frontend-v3, frontend-v2, frontend-v1
|
processing releases in group 1/5: default/frontend-v3, default/frontend-v2, default/frontend-v1
|
||||||
release "frontend-v3" processed
|
release "frontend-v3" processed
|
||||||
release "frontend-v2" processed
|
release "frontend-v2" processed
|
||||||
release "frontend-v1" processed
|
release "frontend-v1" processed
|
||||||
processing releases in group 2/5: backend-v2, backend-v1
|
processing releases in group 2/5: default/backend-v2, default/backend-v1
|
||||||
release "backend-v2" processed
|
release "backend-v2" processed
|
||||||
release "backend-v1" processed
|
release "backend-v1" processed
|
||||||
processing releases in group 3/5: anotherbackend
|
processing releases in group 3/5: default/anotherbackend
|
||||||
release "anotherbackend" processed
|
release "anotherbackend" processed
|
||||||
processing releases in group 4/5: servicemesh, database
|
processing releases in group 4/5: default/servicemesh, default/database
|
||||||
release "servicemesh" processed
|
release "servicemesh" processed
|
||||||
release "database" processed
|
release "database" processed
|
||||||
processing releases in group 5/5: front-proxy, logging
|
processing releases in group 5/5: default/front-proxy, default/logging
|
||||||
release "front-proxy" processed
|
release "front-proxy" processed
|
||||||
release "logging" processed
|
release "logging" processed
|
||||||
|
|
||||||
|
|
@ -641,9 +643,9 @@ merged environment: &{default map[] map[]}
|
||||||
|
|
||||||
processing 1 groups of releases in this order:
|
processing 1 groups of releases in this order:
|
||||||
GROUP RELEASES
|
GROUP RELEASES
|
||||||
1 logging
|
1 default/logging
|
||||||
|
|
||||||
processing releases in group 1/1: logging
|
processing releases in group 1/1: default/logging
|
||||||
release "logging" processed
|
release "logging" processed
|
||||||
|
|
||||||
DELETED RELEASES:
|
DELETED RELEASES:
|
||||||
|
|
@ -706,12 +708,12 @@ merged environment: &{default map[] map[]}
|
||||||
|
|
||||||
processing 2 groups of releases in this order:
|
processing 2 groups of releases in this order:
|
||||||
GROUP RELEASES
|
GROUP RELEASES
|
||||||
1 frontend-v1
|
1 default/frontend-v1
|
||||||
2 backend-v1
|
2 default/backend-v1
|
||||||
|
|
||||||
processing releases in group 1/2: frontend-v1
|
processing releases in group 1/2: default/frontend-v1
|
||||||
release "frontend-v1" processed
|
release "frontend-v1" processed
|
||||||
processing releases in group 2/2: backend-v1
|
processing releases in group 2/2: default/backend-v1
|
||||||
release "backend-v1" processed
|
release "backend-v1" processed
|
||||||
|
|
||||||
DELETED RELEASES:
|
DELETED RELEASES:
|
||||||
|
|
@ -776,12 +778,12 @@ merged environment: &{default map[] map[]}
|
||||||
|
|
||||||
processing 2 groups of releases in this order:
|
processing 2 groups of releases in this order:
|
||||||
GROUP RELEASES
|
GROUP RELEASES
|
||||||
1 frontend-v1
|
1 default/frontend-v1
|
||||||
2 backend-v1
|
2 default/backend-v1
|
||||||
|
|
||||||
processing releases in group 1/2: frontend-v1
|
processing releases in group 1/2: default/frontend-v1
|
||||||
release "frontend-v1" processed
|
release "frontend-v1" processed
|
||||||
processing releases in group 2/2: backend-v1
|
processing releases in group 2/2: default/backend-v1
|
||||||
release "backend-v1" processed
|
release "backend-v1" processed
|
||||||
|
|
||||||
DELETED RELEASES:
|
DELETED RELEASES:
|
||||||
|
|
|
||||||
File diff suppressed because it is too large
Load Diff
|
|
@ -1067,7 +1067,7 @@ releases:
|
||||||
upgraded: []exectest.Release{},
|
upgraded: []exectest.Release{},
|
||||||
// as we check for log output, set concurrency to 1 to avoid non-deterministic test result
|
// as we check for log output, set concurrency to 1 to avoid non-deterministic test result
|
||||||
concurrency: 1,
|
concurrency: 1,
|
||||||
error: `in ./helmfile.yaml: release "default/external-secrets" depends on "kube-system/kubernetes-external-secrets" which does not match the selectors. Please add a selector like "--selector name=kubernetes-external-secrets", or indicate whether to skip (--skip-needs) or include (--include-needs) these dependencies`,
|
error: `in ./helmfile.yaml: release "default/default/external-secrets" depends on "default/kube-system/kubernetes-external-secrets" which does not match the selectors. Please add a selector like "--selector name=kubernetes-external-secrets", or indicate whether to skip (--skip-needs) or include (--include-needs) these dependencies`,
|
||||||
log: `processing file "helmfile.yaml" in directory "."
|
log: `processing file "helmfile.yaml" in directory "."
|
||||||
first-pass rendering starting for "helmfile.yaml.part.0": inherited=&{default map[] map[]}, overrode=<nil>
|
first-pass rendering starting for "helmfile.yaml.part.0": inherited=&{default map[] map[]}, overrode=<nil>
|
||||||
first-pass uses: &{default map[] map[]}
|
first-pass uses: &{default map[] map[]}
|
||||||
|
|
@ -1131,7 +1131,7 @@ second-pass rendering result of "helmfile.yaml.part.0":
|
||||||
merged environment: &{default map[] map[]}
|
merged environment: &{default map[] map[]}
|
||||||
2 release(s) matching app=test found in helmfile.yaml
|
2 release(s) matching app=test found in helmfile.yaml
|
||||||
|
|
||||||
err: release "default/external-secrets" depends on "kube-system/kubernetes-external-secrets" which does not match the selectors. Please add a selector like "--selector name=kubernetes-external-secrets", or indicate whether to skip (--skip-needs) or include (--include-needs) these dependencies
|
err: release "default/default/external-secrets" depends on "default/kube-system/kubernetes-external-secrets" which does not match the selectors. Please add a selector like "--selector name=kubernetes-external-secrets", or indicate whether to skip (--skip-needs) or include (--include-needs) these dependencies
|
||||||
`,
|
`,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
|
@ -1263,7 +1263,7 @@ releases:
|
||||||
upgraded: []exectest.Release{},
|
upgraded: []exectest.Release{},
|
||||||
deleted: []exectest.Release{},
|
deleted: []exectest.Release{},
|
||||||
concurrency: 1,
|
concurrency: 1,
|
||||||
error: `in ./helmfile.yaml: "foo" depends on nonexistent release "bar"`,
|
error: `in ./helmfile.yaml: "default/foo" depends on nonexistent release "default/bar"`,
|
||||||
log: `processing file "helmfile.yaml" in directory "."
|
log: `processing file "helmfile.yaml" in directory "."
|
||||||
first-pass rendering starting for "helmfile.yaml.part.0": inherited=&{default map[] map[]}, overrode=<nil>
|
first-pass rendering starting for "helmfile.yaml.part.0": inherited=&{default map[] map[]}, overrode=<nil>
|
||||||
first-pass uses: &{default map[] map[]}
|
first-pass uses: &{default map[] map[]}
|
||||||
|
|
@ -1299,7 +1299,7 @@ second-pass rendering result of "helmfile.yaml.part.0":
|
||||||
merged environment: &{default map[] map[]}
|
merged environment: &{default map[] map[]}
|
||||||
2 release(s) found in helmfile.yaml
|
2 release(s) found in helmfile.yaml
|
||||||
|
|
||||||
err: "foo" depends on nonexistent release "bar"
|
err: "default/foo" depends on nonexistent release "default/bar"
|
||||||
`,
|
`,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -332,6 +332,9 @@ const MissingFileHandlerWarn = "Warn"
|
||||||
const MissingFileHandlerDebug = "Debug"
|
const MissingFileHandlerDebug = "Debug"
|
||||||
|
|
||||||
func (st *HelmState) ApplyOverrides(spec *ReleaseSpec) {
|
func (st *HelmState) ApplyOverrides(spec *ReleaseSpec) {
|
||||||
|
if spec.KubeContext == "" {
|
||||||
|
spec.KubeContext = st.HelmDefaults.KubeContext
|
||||||
|
}
|
||||||
if st.OverrideNamespace != "" {
|
if st.OverrideNamespace != "" {
|
||||||
spec.Namespace = st.OverrideNamespace
|
spec.Namespace = st.OverrideNamespace
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -151,13 +151,27 @@ func GroupReleasesByDependency(releases []Release, opts PlanOptions) ([][]Releas
|
||||||
|
|
||||||
// Only compute dependencies from non-filtered releases
|
// Only compute dependencies from non-filtered releases
|
||||||
if !r.Filtered {
|
if !r.Filtered {
|
||||||
d.Add(id, dag.Dependencies(r.Needs))
|
// Since the representation differs between needs and id,
|
||||||
|
// correct it by prepending KubeContext.
|
||||||
|
var needs []string
|
||||||
|
for i := 0; i < len(r.Needs); i++ {
|
||||||
|
n := r.Needs[i]
|
||||||
|
if r.KubeContext != "" {
|
||||||
|
n = r.KubeContext + "/" + n
|
||||||
|
}
|
||||||
|
needs = append(needs, n)
|
||||||
|
}
|
||||||
|
d.Add(id, dag.Dependencies(needs))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, r := range releases {
|
for _, r := range releases {
|
||||||
if !r.Filtered {
|
if !r.Filtered {
|
||||||
for _, n := range r.Needs {
|
for _, n := range r.Needs {
|
||||||
|
// To map n into idToReleases correctly, prepend KubeContext to n.
|
||||||
|
if r.KubeContext != "" {
|
||||||
|
n = r.KubeContext + "/" + n
|
||||||
|
}
|
||||||
if _, ok := idToReleases[n]; !ok {
|
if _, ok := idToReleases[n]; !ok {
|
||||||
id := ReleaseToID(&r.ReleaseSpec)
|
id := ReleaseToID(&r.ReleaseSpec)
|
||||||
return nil, fmt.Errorf("%q depends on nonexistent release %q", id, n)
|
return nil, fmt.Errorf("%q depends on nonexistent release %q", id, n)
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue