From d7382d41290ab0bc0e37c7f8d4a62ed95761dbdc Mon Sep 17 00:00:00 2001 From: Chris Stephens Date: Wed, 10 Jul 2019 20:59:05 +0000 Subject: [PATCH] Don't clear cluster from state if cleanup fails Signed-off-by: Modular Magician --- google-beta/resource_container_cluster.go | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/google-beta/resource_container_cluster.go b/google-beta/resource_container_cluster.go index b044d1f7e7..82db11e14f 100644 --- a/google-beta/resource_container_cluster.go +++ b/google-beta/resource_container_cluster.go @@ -1060,17 +1060,18 @@ func resourceContainerClusterCreate(d *schema.ResourceData, meta interface{}) er // Try a GET on the cluster so we can see the state in debug logs. This will help classify error states. _, getErr := config.clientContainerBeta.Projects.Locations.Clusters.Get(containerClusterFullName(project, location, clusterName)).Do() if getErr != nil { - // Make errcheck happy log.Printf("[WARN] Cluster %s was created in an error state and not found", clusterName) + d.SetId("") } if deleteErr := cleanFailedContainerCluster(d, meta); deleteErr != nil { log.Printf("[WARN] Unable to clean up cluster from failed creation: %s", deleteErr) + // Leave ID set as the cluster likely still exists and should not be removed from state yet. } else { log.Printf("[WARN] Verified failed creation of cluster %s was cleaned up", d.Id()) + d.SetId("") } // The resource didn't actually create - d.SetId("") return waitErr }