diff --git a/mmv1/third_party/terraform/resources/resource_container_cluster.go.erb b/mmv1/third_party/terraform/resources/resource_container_cluster.go.erb old mode 100755 new mode 100644 index cb01cd9cc785..2043c2719c03 --- a/mmv1/third_party/terraform/resources/resource_container_cluster.go.erb +++ b/mmv1/third_party/terraform/resources/resource_container_cluster.go.erb @@ -502,6 +502,20 @@ func resourceContainerCluster() *schema.Resource { Default: "default", Description: `The Google Cloud Platform Service Account to be used by the node VMs.`, }, + "disk_size": { + Type: schema.TypeInt, + Optional: true, + Default: 100, + Description: `Size of the disk attached to each node, specified in GB. The smallest allowed disk size is 10GB.`, + ValidateFunc: validation.IntAtLeast(10), + }, + "disk_type": { + Type: schema.TypeString, + Optional: true, + Default: "pd-standard", + Description: `Type of the disk attached to each node.`, + ValidateFunc: validation.StringInSlice([]string{"pd-standard", "pd-ssd", "pd-balanced"}, false), + }, "image_type": { Type: schema.TypeString, Optional: true, @@ -3764,6 +3778,8 @@ func expandAutoProvisioningDefaults(configured interface{}, d *schema.ResourceDa npd := &container.AutoprovisioningNodePoolDefaults{ OauthScopes: convertStringArr(config["oauth_scopes"].([]interface{})), ServiceAccount: config["service_account"].(string), + DiskSizeGb: int64(config["disk_size"].(int)), + DiskType: config["disk_type"].(string), ImageType: config["image_type"].(string), BootDiskKmsKey: config["boot_disk_kms_key"].(string), } @@ -4242,7 +4258,7 @@ func flattenNodePoolDefaults(c *container.NodePoolDefaults) []map[string]interfa if c.NodeConfigDefaults != nil && c.NodeConfigDefaults.GcfsConfig != nil { result["node_config_defaults"] = flattenNodeConfigDefaults(c.NodeConfigDefaults) } - + return []map[string]interface{}{result} } <% end -%> @@ -4722,6 +4738,8 @@ func flattenAutoProvisioningDefaults(a *container.AutoprovisioningNodePoolDefaul r := make(map[string]interface{}) r["oauth_scopes"] = a.OauthScopes r["service_account"] = a.ServiceAccount + r["disk_size"] = a.DiskSizeGb + r["disk_type"] = a.DiskType r["image_type"] = a.ImageType <% unless version == 'ga' -%> r["min_cpu_platform"] = a.MinCpuPlatform diff --git a/mmv1/third_party/terraform/tests/resource_container_cluster_test.go.erb b/mmv1/third_party/terraform/tests/resource_container_cluster_test.go.erb old mode 100755 new mode 100644 index 9ed08e97499e..20c19c3c3ab2 --- a/mmv1/third_party/terraform/tests/resource_container_cluster_test.go.erb +++ b/mmv1/third_party/terraform/tests/resource_container_cluster_test.go.erb @@ -2694,6 +2694,72 @@ func TestAccContainerCluster_withFlexiblePodCIDR(t *testing.T) { } <% end -%> +func TestAccContainerCluster_nodeAutoprovisioningDefaultsDiskSizeGb(t *testing.T) { + t.Parallel() + + clusterName := fmt.Sprintf("tf-test-cluster-%s", randString(t, 10)) + includeDiskSizeGb := true + + vcrTest(t, resource.TestCase{ + PreCheck: func() { testAccPreCheck(t) }, + Providers: testAccProviders, + CheckDestroy: testAccCheckContainerClusterDestroyProducer(t), + Steps: []resource.TestStep{ + { + Config: testAccContainerCluster_autoprovisioningDefaultsDiskSizeGb(clusterName, includeDiskSizeGb), + }, + { + ResourceName: "google_container_cluster.with_autoprovisioning", + ImportState: true, + ImportStateVerify: true, + ImportStateVerifyIgnore: []string{"min_master_version"}, + }, + { + Config: testAccContainerCluster_autoprovisioningDefaultsDiskSizeGb(clusterName, !includeDiskSizeGb), + }, + { + ResourceName: "google_container_cluster.with_autoprovisioning", + ImportState: true, + ImportStateVerify: true, + ImportStateVerifyIgnore: []string{"min_master_version"}, + }, + }, + }) +} + +func TestAccContainerCluster_nodeAutoprovisioningDefaultsDiskType(t *testing.T) { + t.Parallel() + + clusterName := fmt.Sprintf("tf-test-cluster-%s", randString(t, 10)) + includeDiskType := true + + vcrTest(t, resource.TestCase{ + PreCheck: func() { testAccPreCheck(t) }, + Providers: testAccProviders, + CheckDestroy: testAccCheckContainerClusterDestroyProducer(t), + Steps: []resource.TestStep{ + { + Config: testAccContainerCluster_autoprovisioningDefaultsDiskType(clusterName, includeDiskType), + }, + { + ResourceName: "google_container_cluster.with_autoprovisioning", + ImportState: true, + ImportStateVerify: true, + ImportStateVerifyIgnore: []string{"min_master_version"}, + }, + { + Config: testAccContainerCluster_autoprovisioningDefaultsDiskType(clusterName, !includeDiskType), + }, + { + ResourceName: "google_container_cluster.with_autoprovisioning", + ImportState: true, + ImportStateVerify: true, + ImportStateVerifyIgnore: []string{"min_master_version"}, + }, + }, + }) +} + func TestAccContainerCluster_nodeAutoprovisioningDefaultsImageType(t *testing.T) { t.Parallel() @@ -4830,6 +4896,70 @@ resource "google_container_cluster" "with_autoprovisioning" { } <% end -%> +func testAccContainerCluster_autoprovisioningDefaultsDiskSizeGb(cluster string, includeDiskSizeGb bool) string { + DiskSizeGbCfg := "" + if includeDiskSizeGb { + DiskSizeGbCfg = `disk_size = 120` + } + + return fmt.Sprintf(` +data "google_container_engine_versions" "central1a" { + location = "us-central1-a" +} +resource "google_container_cluster" "with_autoprovisioning" { + name = "%s" + location = "us-central1-a" + initial_node_count = 1 + min_master_version = data.google_container_engine_versions.central1a.latest_master_version + cluster_autoscaling { + enabled = true + resource_limits { + resource_type = "cpu" + maximum = 2 + } + resource_limits { + resource_type = "memory" + maximum = 2048 + } + auto_provisioning_defaults { + %s + } + } +}`, cluster, DiskSizeGbCfg) +} + +func testAccContainerCluster_autoprovisioningDefaultsDiskType(cluster string, includeDiskType bool) string { + DiskTypeCfg := "" + if includeDiskType { + DiskTypeCfg = `disk_type = "pd-balanced"` + } + + return fmt.Sprintf(` +data "google_container_engine_versions" "central1a" { + location = "us-central1-a" +} +resource "google_container_cluster" "with_autoprovisioning" { + name = "%s" + location = "us-central1-a" + initial_node_count = 1 + min_master_version = data.google_container_engine_versions.central1a.latest_master_version + cluster_autoscaling { + enabled = true + resource_limits { + resource_type = "cpu" + maximum = 2 + } + resource_limits { + resource_type = "memory" + maximum = 2048 + } + auto_provisioning_defaults { + %s + } + } +}`, cluster, DiskTypeCfg) +} + func testAccContainerCluster_autoprovisioningDefaultsImageType(cluster string, includeImageType bool) string { imageTypeCfg := "" if includeImageType { diff --git a/mmv1/third_party/terraform/website/docs/r/container_cluster.html.markdown b/mmv1/third_party/terraform/website/docs/r/container_cluster.html.markdown old mode 100755 new mode 100644 index 4dc0e3a516eb..6e2687bb8f2a --- a/mmv1/third_party/terraform/website/docs/r/container_cluster.html.markdown +++ b/mmv1/third_party/terraform/website/docs/r/container_cluster.html.markdown @@ -507,6 +507,10 @@ as "Intel Haswell" or "Intel Sandy Bridge". * `boot_disk_kms_key` - (Optional) The Customer Managed Encryption Key used to encrypt the boot disk attached to each node in the node pool. This should be of the form projects/[KEY_PROJECT_ID]/locations/[LOCATION]/keyRings/[RING_NAME]/cryptoKeys/[KEY_NAME]. For more information about protecting resources with Cloud KMS Keys please see: https://cloud.google.com/compute/docs/disks/customer-managed-encryption +* `disk_size` - (Optional) Size of the disk attached to each node, specified in GB. The smallest allowed disk size is 10GB. Defaults to `100` + +* `disk_type` - (Optional) Type of the disk attached to each node (e.g. 'pd-standard', 'pd-ssd' or 'pd-balanced'). Defaults to `pd-standard` + * `image_type` - (Optional) The default image type used by NAP once a new node pool is being created. Please note that according to the [official documentation](https://cloud.google.com/kubernetes-engine/docs/how-to/node-auto-provisioning#default-image-type) the value must be one of the [COS_CONTAINERD, COS, UBUNTU_CONTAINERD, UBUNTU]. __NOTE__ : COS AND UBUNTU are deprecated as of `GKE 1.24` The `authenticator_groups_config` block supports: