From 1bc1b1e20c087d88d9c600784f89391966cf6d17 Mon Sep 17 00:00:00 2001 From: Alexander Chernov Date: Wed, 16 Oct 2024 17:47:23 +0100 Subject: [PATCH] Fix a `wait_for` condition where the status is already present in the first observation --- kubernetes/resource_kubectl_manifest.go | 17 +++++++--- kubernetes/resource_kubectl_manifest_test.go | 34 ++++++++++++++++++++ 2 files changed, 47 insertions(+), 4 deletions(-) diff --git a/kubernetes/resource_kubectl_manifest.go b/kubernetes/resource_kubectl_manifest.go index b45232a2..1e150720 100644 --- a/kubernetes/resource_kubectl_manifest.go +++ b/kubernetes/resource_kubectl_manifest.go @@ -1198,18 +1198,25 @@ func waitForApiService(ctx context.Context, provider *KubeProvider, name string, func waitForConditions(ctx context.Context, restClient *RestClientResult, waitFields []types.WaitForField, waitConditions []types.WaitForStatusCondition, name string, resourceVersion string, timeout time.Duration) error { timeoutSeconds := int64(timeout.Seconds()) - watcher, err := restClient.ResourceInterface.Watch(ctx, meta_v1.ListOptions{Watch: true, TimeoutSeconds: &timeoutSeconds, FieldSelector: fields.OneTermEqualSelector("metadata.name", name).String(), ResourceVersion: resourceVersion}) + watcher, err := restClient.ResourceInterface.Watch( + ctx, + meta_v1.ListOptions{ + Watch: true, + TimeoutSeconds: &timeoutSeconds, + FieldSelector: fields.OneTermEqualSelector("metadata.name", name).String(), + }, + ) if err != nil { return err } - defer watcher.Stop() done := false for !done { select { case event := <-watcher.ResultChan(): - if event.Type == watch.Modified { + log.Printf("[TRACE] Received event type %s for %s", event.Type, name) + if event.Type == watch.Modified || event.Type == watch.Added { rawResponse, ok := event.Object.(*meta_v1_unstruct.Unstructured) if !ok { return fmt.Errorf("%s could not cast resource to unstructured", name) @@ -1224,7 +1231,9 @@ func waitForConditions(ctx context.Context, restClient *RestClientResult, waitFi for _, c := range waitConditions { // Find the conditions by status and type - v := gq.Reset().From("status.conditions").Where("type", "=", c.Type).Where("status", "=", c.Status) + v := gq.Reset().From("status.conditions"). + Where("type", "=", c.Type). + Where("status", "=", c.Status) if v == nil { continue } diff --git a/kubernetes/resource_kubectl_manifest_test.go b/kubernetes/resource_kubectl_manifest_test.go index 1d930f39..20e12b77 100644 --- a/kubernetes/resource_kubectl_manifest_test.go +++ b/kubernetes/resource_kubectl_manifest_test.go @@ -413,6 +413,40 @@ YAML }) } +func TestAccKubectl_WaitForNS(t *testing.T) { + //language=hcl + config := ` +resource "kubectl_manifest" "test_wait_for" { + timeouts { + create = "200s" + } + yaml_body = <