From 724e0e57d885e3fa7eb55dc174afa0b460b8ffc7 Mon Sep 17 00:00:00 2001 From: The Magician Date: Wed, 26 Feb 2020 19:47:07 -0800 Subject: [PATCH] upstream https://github.com/terraform-providers/terraform-provider-google-beta/pull/1766 (#3178) (#5782) Signed-off-by: Modular Magician --- .changelog/3178.txt | 3 +++ google/resource_container_cluster.go | 9 +++++++-- 2 files changed, 10 insertions(+), 2 deletions(-) create mode 100644 .changelog/3178.txt diff --git a/.changelog/3178.txt b/.changelog/3178.txt new file mode 100644 index 00000000000..dd18d325147 --- /dev/null +++ b/.changelog/3178.txt @@ -0,0 +1,3 @@ +```release-note:bug +container: Fixed panic when upgrading `google_container_cluster` with autoscaling block +``` diff --git a/google/resource_container_cluster.go b/google/resource_container_cluster.go index 9dfac158af2..1cc48d7dab0 100644 --- a/google/resource_container_cluster.go +++ b/google/resource_container_cluster.go @@ -2196,9 +2196,12 @@ func flattenMasterAuth(ma *containerBeta.MasterAuth) []map[string]interface{} { func flattenClusterAutoscaling(a *containerBeta.ClusterAutoscaling) []map[string]interface{} { r := make(map[string]interface{}) - if a == nil || !a.EnableNodeAutoprovisioning { + if a == nil { r["enabled"] = false - } else { + return []map[string]interface{}{r} + } + + if a.EnableNodeAutoprovisioning { resourceLimits := make([]interface{}, 0, len(a.ResourceLimits)) for _, rl := range a.ResourceLimits { resourceLimits = append(resourceLimits, map[string]interface{}{ @@ -2210,6 +2213,8 @@ func flattenClusterAutoscaling(a *containerBeta.ClusterAutoscaling) []map[string r["resource_limits"] = resourceLimits r["enabled"] = true r["auto_provisioning_defaults"] = flattenAutoProvisioningDefaults(a.AutoprovisioningNodePoolDefaults) + } else { + r["enabled"] = false } return []map[string]interface{}{r}