From d8802b7d4ac8cb32fa9d9f579d47deb86300a6f4 Mon Sep 17 00:00:00 2001 From: stefanprodan Date: Sun, 3 May 2020 13:25:32 +0300 Subject: [PATCH] Fix resume waiting --- .github/workflows/e2e.yaml | 1 + cmd/tk/resume_kustomization.go | 35 +++++++++++++++++++++++++++++++++- 2 files changed, 35 insertions(+), 1 deletion(-) diff --git a/.github/workflows/e2e.yaml b/.github/workflows/e2e.yaml index f7bdc646..1491fa09 100644 --- a/.github/workflows/e2e.yaml +++ b/.github/workflows/e2e.yaml @@ -99,5 +99,6 @@ jobs: kubectl version --client --short kustomize version --short kubectl -n gitops-system get all + kubectl -n gitops-system get kustomizations -oyaml kubectl -n gitops-system logs deploy/source-controller kubectl -n gitops-system logs deploy/kustomize-controller diff --git a/cmd/tk/resume_kustomization.go b/cmd/tk/resume_kustomization.go index 7712ab8e..e534642b 100644 --- a/cmd/tk/resume_kustomization.go +++ b/cmd/tk/resume_kustomization.go @@ -5,9 +5,12 @@ import ( "fmt" kustomizev1 "github.com/fluxcd/kustomize-controller/api/v1alpha1" + sourcev1 "github.com/fluxcd/source-controller/api/v1alpha1" "github.com/spf13/cobra" + corev1 "k8s.io/api/core/v1" "k8s.io/apimachinery/pkg/types" "k8s.io/apimachinery/pkg/util/wait" + "sigs.k8s.io/controller-runtime/pkg/client" ) var resumeKsCmd = &cobra.Command{ @@ -55,7 +58,7 @@ func resumeKsCmdRun(cmd *cobra.Command, args []string) error { logWaiting("waiting for kustomization sync") if err := wait.PollImmediate(pollInterval, timeout, - isKustomizationReady(ctx, kubeClient, name, namespace)); err != nil { + isKustomizationResumed(ctx, kubeClient, name, namespace)); err != nil { return err } @@ -74,3 +77,33 @@ func resumeKsCmdRun(cmd *cobra.Command, args []string) error { return nil } + +func isKustomizationResumed(ctx context.Context, kubeClient client.Client, name, namespace string) wait.ConditionFunc { + return func() (bool, error) { + var kustomization kustomizev1.Kustomization + namespacedName := types.NamespacedName{ + Namespace: namespace, + Name: name, + } + + err := kubeClient.Get(ctx, namespacedName, &kustomization) + if err != nil { + return false, err + } + + for _, condition := range kustomization.Status.Conditions { + if condition.Type == sourcev1.ReadyCondition { + if condition.Status == corev1.ConditionTrue { + return true, nil + } else if condition.Status == corev1.ConditionFalse { + if condition.Reason == kustomizev1.SuspendedReason { + return false, nil + } + + return false, fmt.Errorf(condition.Message) + } + } + } + return false, nil + } +}