From 1ac2c5c1a090eeb8cd07f88902770637378d1ec8 Mon Sep 17 00:00:00 2001 From: Bharath KKB Date: Fri, 27 Mar 2020 01:46:09 -0500 Subject: [PATCH] feat: Added support for specifying autoscaling_profile in var.cluster_autoscaling (#456) * add autoscaling_profile * default to balanced if autoscaling_profile is null * default to balanced if autoscaling_profile is null --- autogen/main/cluster.tf.tmpl | 3 ++- autogen/main/variables.tf.tmpl | 22 ++++++++++--------- examples/node_pool/main.tf | 2 +- examples/node_pool/variables.tf | 22 ++++++++++--------- examples/node_pool_update_variant/main.tf | 2 +- .../node_pool_update_variant_beta/main.tf | 2 +- examples/safer_cluster/main.tf | 4 ++-- examples/simple_regional_beta/main.tf | 2 +- examples/simple_regional_private_beta/main.tf | 4 ++-- examples/workload_identity/main.tf | 2 +- examples/workload_metadata_config/main.tf | 2 +- .../cluster.tf | 3 ++- .../variables.tf | 22 ++++++++++--------- modules/beta-private-cluster/cluster.tf | 3 ++- modules/beta-private-cluster/variables.tf | 22 ++++++++++--------- modules/beta-public-cluster/cluster.tf | 3 ++- modules/beta-public-cluster/variables.tf | 22 ++++++++++--------- test/fixtures/node_pool/example.tf | 11 +++++----- test/integration/node_pool/controls/gcloud.rb | 3 ++- 19 files changed, 86 insertions(+), 70 deletions(-) diff --git a/autogen/main/cluster.tf.tmpl b/autogen/main/cluster.tf.tmpl index b2b4245a0e..7acbf184ee 100644 --- a/autogen/main/cluster.tf.tmpl +++ b/autogen/main/cluster.tf.tmpl @@ -68,7 +68,8 @@ resource "google_container_cluster" "primary" { {% if beta_cluster %} cluster_autoscaling { - enabled = var.cluster_autoscaling.enabled + enabled = var.cluster_autoscaling.enabled + autoscaling_profile = var.cluster_autoscaling.autoscaling_profile != null ? var.cluster_autoscaling.autoscaling_profile : "BALANCED" dynamic "resource_limits" { for_each = local.autoscalling_resource_limits content { diff --git a/autogen/main/variables.tf.tmpl b/autogen/main/variables.tf.tmpl index db83f3e690..10121535a5 100644 --- a/autogen/main/variables.tf.tmpl +++ b/autogen/main/variables.tf.tmpl @@ -198,18 +198,20 @@ variable "enable_kubernetes_alpha" { variable "cluster_autoscaling" { type = object({ - enabled = bool - min_cpu_cores = number - max_cpu_cores = number - min_memory_gb = number - max_memory_gb = number + enabled = bool + autoscaling_profile = string + min_cpu_cores = number + max_cpu_cores = number + min_memory_gb = number + max_memory_gb = number }) default = { - enabled = false - max_cpu_cores = 0 - min_cpu_cores = 0 - max_memory_gb = 0 - min_memory_gb = 0 + enabled = false + autoscaling_profile = "BALANCED" + max_cpu_cores = 0 + min_cpu_cores = 0 + max_memory_gb = 0 + min_memory_gb = 0 } description = "Cluster autoscaling configuration. See [more details](https://cloud.google.com/kubernetes-engine/docs/reference/rest/v1beta1/projects.locations.clusters#clusterautoscaling)" } diff --git a/examples/node_pool/main.tf b/examples/node_pool/main.tf index bcb3a1bc78..6bcf9994bf 100644 --- a/examples/node_pool/main.tf +++ b/examples/node_pool/main.tf @@ -19,7 +19,7 @@ locals { } provider "google-beta" { - version = "~> 3.3.0" + version = "~> 3.12.0" region = var.region } diff --git a/examples/node_pool/variables.tf b/examples/node_pool/variables.tf index c8e443fbc4..e46f8f927a 100644 --- a/examples/node_pool/variables.tf +++ b/examples/node_pool/variables.tf @@ -54,18 +54,20 @@ variable "compute_engine_service_account" { variable "cluster_autoscaling" { type = object({ - enabled = bool - min_cpu_cores = number - max_cpu_cores = number - min_memory_gb = number - max_memory_gb = number + enabled = bool + autoscaling_profile = string + min_cpu_cores = number + max_cpu_cores = number + min_memory_gb = number + max_memory_gb = number }) default = { - enabled = false - max_cpu_cores = 0 - min_cpu_cores = 0 - max_memory_gb = 0 - min_memory_gb = 0 + enabled = false + autoscaling_profile = "BALANCED" + max_cpu_cores = 0 + min_cpu_cores = 0 + max_memory_gb = 0 + min_memory_gb = 0 } description = "Cluster autoscaling configuration. See [more details](https://cloud.google.com/kubernetes-engine/docs/reference/rest/v1beta1/projects.locations.clusters#clusterautoscaling)" } diff --git a/examples/node_pool_update_variant/main.tf b/examples/node_pool_update_variant/main.tf index 092e03020c..f027970d30 100644 --- a/examples/node_pool_update_variant/main.tf +++ b/examples/node_pool_update_variant/main.tf @@ -19,7 +19,7 @@ locals { } provider "google" { - version = "~> 3.3.0" + version = "~> 3.12.0" region = var.region } diff --git a/examples/node_pool_update_variant_beta/main.tf b/examples/node_pool_update_variant_beta/main.tf index 7526572c8d..e2fee1bcf1 100644 --- a/examples/node_pool_update_variant_beta/main.tf +++ b/examples/node_pool_update_variant_beta/main.tf @@ -19,7 +19,7 @@ locals { } provider "google-beta" { - version = "~> 3.3.0" + version = "~> 3.12.0" credentials = file(var.credentials_path) region = var.region } diff --git a/examples/safer_cluster/main.tf b/examples/safer_cluster/main.tf index 4d6e7e4dbc..d91eb93abd 100644 --- a/examples/safer_cluster/main.tf +++ b/examples/safer_cluster/main.tf @@ -30,11 +30,11 @@ locals { } provider "google" { - version = "~> 3.3.0" + version = "~> 3.12.0" } provider "google-beta" { - version = "~> 3.3.0" + version = "~> 3.12.0" } module "gke" { diff --git a/examples/simple_regional_beta/main.tf b/examples/simple_regional_beta/main.tf index 9f27517836..1434894a16 100644 --- a/examples/simple_regional_beta/main.tf +++ b/examples/simple_regional_beta/main.tf @@ -19,7 +19,7 @@ locals { } provider "google-beta" { - version = "~> 3.3.0" + version = "~> 3.12.0" region = var.region } diff --git a/examples/simple_regional_private_beta/main.tf b/examples/simple_regional_private_beta/main.tf index 9b32877fab..04c00f0240 100644 --- a/examples/simple_regional_private_beta/main.tf +++ b/examples/simple_regional_private_beta/main.tf @@ -19,12 +19,12 @@ locals { } provider "google" { - version = "~> 3.3.0" + version = "~> 3.12.0" region = var.region } provider "google-beta" { - version = "~> 3.3.0" + version = "~> 3.12.0" region = var.region } diff --git a/examples/workload_identity/main.tf b/examples/workload_identity/main.tf index 77970a5b51..eb27bcdb55 100644 --- a/examples/workload_identity/main.tf +++ b/examples/workload_identity/main.tf @@ -19,7 +19,7 @@ locals { } provider "google" { - version = "~> 2.20.1" + version = "~> 3.12.0" region = var.region } diff --git a/examples/workload_metadata_config/main.tf b/examples/workload_metadata_config/main.tf index f49fa444cb..8ef920199b 100644 --- a/examples/workload_metadata_config/main.tf +++ b/examples/workload_metadata_config/main.tf @@ -19,7 +19,7 @@ locals { } provider "google-beta" { - version = "~> 3.3.0" + version = "~> 3.12.0" region = var.region } diff --git a/modules/beta-private-cluster-update-variant/cluster.tf b/modules/beta-private-cluster-update-variant/cluster.tf index b870fd244b..4479611ca0 100644 --- a/modules/beta-private-cluster-update-variant/cluster.tf +++ b/modules/beta-private-cluster-update-variant/cluster.tf @@ -57,7 +57,8 @@ resource "google_container_cluster" "primary" { monitoring_service = var.monitoring_service cluster_autoscaling { - enabled = var.cluster_autoscaling.enabled + enabled = var.cluster_autoscaling.enabled + autoscaling_profile = var.cluster_autoscaling.autoscaling_profile != null ? var.cluster_autoscaling.autoscaling_profile : "BALANCED" dynamic "resource_limits" { for_each = local.autoscalling_resource_limits content { diff --git a/modules/beta-private-cluster-update-variant/variables.tf b/modules/beta-private-cluster-update-variant/variables.tf index e1a26aafc8..08bdb04b43 100644 --- a/modules/beta-private-cluster-update-variant/variables.tf +++ b/modules/beta-private-cluster-update-variant/variables.tf @@ -195,18 +195,20 @@ variable "enable_kubernetes_alpha" { variable "cluster_autoscaling" { type = object({ - enabled = bool - min_cpu_cores = number - max_cpu_cores = number - min_memory_gb = number - max_memory_gb = number + enabled = bool + autoscaling_profile = string + min_cpu_cores = number + max_cpu_cores = number + min_memory_gb = number + max_memory_gb = number }) default = { - enabled = false - max_cpu_cores = 0 - min_cpu_cores = 0 - max_memory_gb = 0 - min_memory_gb = 0 + enabled = false + autoscaling_profile = "BALANCED" + max_cpu_cores = 0 + min_cpu_cores = 0 + max_memory_gb = 0 + min_memory_gb = 0 } description = "Cluster autoscaling configuration. See [more details](https://cloud.google.com/kubernetes-engine/docs/reference/rest/v1beta1/projects.locations.clusters#clusterautoscaling)" } diff --git a/modules/beta-private-cluster/cluster.tf b/modules/beta-private-cluster/cluster.tf index 1c73331c02..a414426a91 100644 --- a/modules/beta-private-cluster/cluster.tf +++ b/modules/beta-private-cluster/cluster.tf @@ -57,7 +57,8 @@ resource "google_container_cluster" "primary" { monitoring_service = var.monitoring_service cluster_autoscaling { - enabled = var.cluster_autoscaling.enabled + enabled = var.cluster_autoscaling.enabled + autoscaling_profile = var.cluster_autoscaling.autoscaling_profile != null ? var.cluster_autoscaling.autoscaling_profile : "BALANCED" dynamic "resource_limits" { for_each = local.autoscalling_resource_limits content { diff --git a/modules/beta-private-cluster/variables.tf b/modules/beta-private-cluster/variables.tf index e1a26aafc8..08bdb04b43 100644 --- a/modules/beta-private-cluster/variables.tf +++ b/modules/beta-private-cluster/variables.tf @@ -195,18 +195,20 @@ variable "enable_kubernetes_alpha" { variable "cluster_autoscaling" { type = object({ - enabled = bool - min_cpu_cores = number - max_cpu_cores = number - min_memory_gb = number - max_memory_gb = number + enabled = bool + autoscaling_profile = string + min_cpu_cores = number + max_cpu_cores = number + min_memory_gb = number + max_memory_gb = number }) default = { - enabled = false - max_cpu_cores = 0 - min_cpu_cores = 0 - max_memory_gb = 0 - min_memory_gb = 0 + enabled = false + autoscaling_profile = "BALANCED" + max_cpu_cores = 0 + min_cpu_cores = 0 + max_memory_gb = 0 + min_memory_gb = 0 } description = "Cluster autoscaling configuration. See [more details](https://cloud.google.com/kubernetes-engine/docs/reference/rest/v1beta1/projects.locations.clusters#clusterautoscaling)" } diff --git a/modules/beta-public-cluster/cluster.tf b/modules/beta-public-cluster/cluster.tf index 3fc4c75034..e5ccd2f9a6 100644 --- a/modules/beta-public-cluster/cluster.tf +++ b/modules/beta-public-cluster/cluster.tf @@ -57,7 +57,8 @@ resource "google_container_cluster" "primary" { monitoring_service = var.monitoring_service cluster_autoscaling { - enabled = var.cluster_autoscaling.enabled + enabled = var.cluster_autoscaling.enabled + autoscaling_profile = var.cluster_autoscaling.autoscaling_profile != null ? var.cluster_autoscaling.autoscaling_profile : "BALANCED" dynamic "resource_limits" { for_each = local.autoscalling_resource_limits content { diff --git a/modules/beta-public-cluster/variables.tf b/modules/beta-public-cluster/variables.tf index c04d860ef4..086478d083 100644 --- a/modules/beta-public-cluster/variables.tf +++ b/modules/beta-public-cluster/variables.tf @@ -195,18 +195,20 @@ variable "enable_kubernetes_alpha" { variable "cluster_autoscaling" { type = object({ - enabled = bool - min_cpu_cores = number - max_cpu_cores = number - min_memory_gb = number - max_memory_gb = number + enabled = bool + autoscaling_profile = string + min_cpu_cores = number + max_cpu_cores = number + min_memory_gb = number + max_memory_gb = number }) default = { - enabled = false - max_cpu_cores = 0 - min_cpu_cores = 0 - max_memory_gb = 0 - min_memory_gb = 0 + enabled = false + autoscaling_profile = "BALANCED" + max_cpu_cores = 0 + min_cpu_cores = 0 + max_memory_gb = 0 + min_memory_gb = 0 } description = "Cluster autoscaling configuration. See [more details](https://cloud.google.com/kubernetes-engine/docs/reference/rest/v1beta1/projects.locations.clusters#clusterautoscaling)" } diff --git a/test/fixtures/node_pool/example.tf b/test/fixtures/node_pool/example.tf index 8c787f94d6..f2298c3865 100644 --- a/test/fixtures/node_pool/example.tf +++ b/test/fixtures/node_pool/example.tf @@ -28,11 +28,12 @@ module "example" { compute_engine_service_account = var.compute_engine_service_accounts[0] cluster_autoscaling = { - enabled = true - max_cpu_cores = 20 - min_cpu_cores = 5 - max_memory_gb = 30 - min_memory_gb = 10 + enabled = true + autoscaling_profile = "OPTIMIZE_UTILIZATION" + max_cpu_cores = 20 + min_cpu_cores = 5 + max_memory_gb = 30 + min_memory_gb = 10 } } diff --git a/test/integration/node_pool/controls/gcloud.rb b/test/integration/node_pool/controls/gcloud.rb index c08b61f1c6..4291b13141 100644 --- a/test/integration/node_pool/controls/gcloud.rb +++ b/test/integration/node_pool/controls/gcloud.rb @@ -21,7 +21,7 @@ control "gcloud" do title "Google Compute Engine GKE configuration" - describe command("gcloud --project=#{project_id} container clusters --zone=#{location} describe #{cluster_name} --format=json") do + describe command("gcloud beta --project=#{project_id} container clusters --zone=#{location} describe #{cluster_name} --format=json") do its(:exit_status) { should eq 0 } its(:stderr) { should eq '' } @@ -40,6 +40,7 @@ "oauthScopes" => %w(https://www.googleapis.com/auth/logging.write https://www.googleapis.com/auth/monitoring), "serviceAccount" => "default" }, + "autoscalingProfile" => "OPTIMIZE_UTILIZATION", "enableNodeAutoprovisioning" => true, "resourceLimits" => [ {