From 9bad71f21471df9bbd18447232590b998dd2d8ad Mon Sep 17 00:00:00 2001 From: Aris van Ommeren Date: Mon, 19 Jul 2021 21:48:24 +0200 Subject: [PATCH 1/2] `azurerm_kubernetes_cluster`: Support for downgrade `sku_tier` --- .../kubernetes_cluster_other_resource_test.go | 18 ++++++++++-------- .../containers/kubernetes_cluster_resource.go | 11 +---------- .../docs/r/kubernetes_cluster.html.markdown | 2 -- 3 files changed, 11 insertions(+), 20 deletions(-) diff --git a/azurerm/internal/services/containers/kubernetes_cluster_other_resource_test.go b/azurerm/internal/services/containers/kubernetes_cluster_other_resource_test.go index 1d4726c3f622..33ab0ddbc300 100644 --- a/azurerm/internal/services/containers/kubernetes_cluster_other_resource_test.go +++ b/azurerm/internal/services/containers/kubernetes_cluster_other_resource_test.go @@ -344,6 +344,13 @@ func testAccKubernetesCluster_upgradeSkuTier(t *testing.T) { ), }, data.ImportStep(), + { + Config: r.freeSkuConfig(data), + Check: acceptance.ComposeTestCheckFunc( + check.That(data.ResourceName).ExistsInAzure(r), + ), + }, + data.ImportStep(), }) } @@ -1156,9 +1163,6 @@ resource "azurerm_kubernetes_cluster" "test" { } func (KubernetesClusterResource) paidSkuConfig(data acceptance.TestData) string { - // @tombuildsstuff (2020-05-29) - this is only supported in a handful of regions - // whilst in Preview - hard-coding for now - location := "westus2" // TODO: data.Locations.Primary return fmt.Sprintf(` provider "azurerm" { features {} @@ -1186,13 +1190,10 @@ resource "azurerm_kubernetes_cluster" "test" { type = "SystemAssigned" } } -`, data.RandomInteger, location, data.RandomInteger, data.RandomInteger) +`, data.RandomInteger, data.Locations.Primary, data.RandomInteger, data.RandomInteger) } func (KubernetesClusterResource) freeSkuConfig(data acceptance.TestData) string { - // @tombuildsstuff (2020-05-29) - this is only supported in a handful of regions - // whilst in Preview - hard-coding for now - location := "westus2" // TODO: data.Locations.Primary return fmt.Sprintf(` provider "azurerm" { features {} @@ -1208,6 +1209,7 @@ resource "azurerm_kubernetes_cluster" "test" { location = azurerm_resource_group.test.location resource_group_name = azurerm_resource_group.test.name dns_prefix = "acctestaks%d" + sku_tier = "Free" default_node_pool { name = "default" @@ -1219,7 +1221,7 @@ resource "azurerm_kubernetes_cluster" "test" { type = "SystemAssigned" } } -`, data.RandomInteger, location, data.RandomInteger, data.RandomInteger) +`, data.RandomInteger, data.Locations.Primary, data.RandomInteger, data.RandomInteger) } func (KubernetesClusterResource) tagsConfig(data acceptance.TestData) string { diff --git a/azurerm/internal/services/containers/kubernetes_cluster_resource.go b/azurerm/internal/services/containers/kubernetes_cluster_resource.go index 14a7db46e67f..c8c7d075a862 100644 --- a/azurerm/internal/services/containers/kubernetes_cluster_resource.go +++ b/azurerm/internal/services/containers/kubernetes_cluster_resource.go @@ -41,10 +41,6 @@ func resourceKubernetesCluster() *pluginsdk.Resource { }), CustomizeDiff: pluginsdk.CustomDiffInSequence( - // Downgrade from Paid to Free is not supported and requires rebuild to apply - pluginsdk.ForceNewIfChange("sku_tier", func(ctx context.Context, old, new, meta interface{}) bool { - return new == "Free" - }), // Migration of `identity` to `service_principal` is not allowed, the other way around is pluginsdk.ForceNewIfChange("service_principal.0.client_id", func(ctx context.Context, old, new, meta interface{}) bool { return old == "msi" || old == "" @@ -657,12 +653,7 @@ func resourceKubernetesCluster() *pluginsdk.Resource { "sku_tier": { Type: pluginsdk.TypeString, Optional: true, - // @tombuildsstuff (2020-05-29) - Preview limitations: - // * Currently, there is no way to remove Uptime SLA from an AKS cluster after creation with it enabled. - // * Private clusters aren't currently supported. - // @jackofallops (2020-07-21) - Update: - // * sku_tier can now be upgraded in place, downgrade requires rebuild - Default: string(containerservice.ManagedClusterSKUTierFree), + Default: string(containerservice.ManagedClusterSKUTierFree), ValidateFunc: validation.StringInSlice([]string{ string(containerservice.ManagedClusterSKUTierFree), string(containerservice.ManagedClusterSKUTierPaid), diff --git a/website/docs/r/kubernetes_cluster.html.markdown b/website/docs/r/kubernetes_cluster.html.markdown index aa77a872b646..715b410dfcca 100644 --- a/website/docs/r/kubernetes_cluster.html.markdown +++ b/website/docs/r/kubernetes_cluster.html.markdown @@ -166,8 +166,6 @@ resource "azurerm_kubernetes_cluster" "example" { * `sku_tier` - (Optional) The SKU Tier that should be used for this Kubernetes Cluster. Possible values are `Free` and `Paid` (which includes the Uptime SLA). Defaults to `Free`. -~> **Note:** It is currently possible to upgrade in place from `Free` to `Paid`. However, changing this value from `Paid` to `Free` will force a new resource to be created. - * `tags` - (Optional) A mapping of tags to assign to the resource. * `windows_profile` - (Optional) A `windows_profile` block as defined below. From 4177162496a71cb2cc32326468ca1ddbf398b214 Mon Sep 17 00:00:00 2001 From: Aris van Ommeren Date: Mon, 19 Jul 2021 22:04:34 +0200 Subject: [PATCH 2/2] remove default `sku_tier` value from testcase --- .../containers/kubernetes_cluster_other_resource_test.go | 1 - 1 file changed, 1 deletion(-) diff --git a/azurerm/internal/services/containers/kubernetes_cluster_other_resource_test.go b/azurerm/internal/services/containers/kubernetes_cluster_other_resource_test.go index 33ab0ddbc300..359ade3e6824 100644 --- a/azurerm/internal/services/containers/kubernetes_cluster_other_resource_test.go +++ b/azurerm/internal/services/containers/kubernetes_cluster_other_resource_test.go @@ -1209,7 +1209,6 @@ resource "azurerm_kubernetes_cluster" "test" { location = azurerm_resource_group.test.location resource_group_name = azurerm_resource_group.test.name dns_prefix = "acctestaks%d" - sku_tier = "Free" default_node_pool { name = "default"