From 8a5dd30e33226495ce291125522fed1d79673fae Mon Sep 17 00:00:00 2001 From: Modular Magician Date: Thu, 18 Apr 2024 19:19:15 +0000 Subject: [PATCH] appengine: Suppress null automatic_scaling blocks during Read (#10476) [upstream:b27fe0a9d25ae29790edee20e14c93fa80bd3aa1] Signed-off-by: Modular Magician --- .changelog/10476.txt | 3 ++ ...esource_app_engine_standard_app_version.go | 29 +++++++++++++++++++ 2 files changed, 32 insertions(+) create mode 100644 .changelog/10476.txt diff --git a/.changelog/10476.txt b/.changelog/10476.txt new file mode 100644 index 0000000000..2a7a071f04 --- /dev/null +++ b/.changelog/10476.txt @@ -0,0 +1,3 @@ +```release-note:bug +appengine: added suppression for a diff in google_app_engine_standard_app_version.automatic_scaling when the block is unset in configuration +``` \ No newline at end of file diff --git a/google-beta/services/appengine/resource_app_engine_standard_app_version.go b/google-beta/services/appengine/resource_app_engine_standard_app_version.go index 1ef67f237b..6b54b5695e 100644 --- a/google-beta/services/appengine/resource_app_engine_standard_app_version.go +++ b/google-beta/services/appengine/resource_app_engine_standard_app_version.go @@ -1254,6 +1254,35 @@ func flattenAppEngineStandardAppVersionAutomaticScaling(v interface{}, d *schema flattenAppEngineStandardAppVersionAutomaticScalingMinPendingLatency(original["minPendingLatency"], d, config) transformed["standard_scheduler_settings"] = flattenAppEngineStandardAppVersionAutomaticScalingStandardSchedulerSettings(original["standardSchedulerSettings"], d, config) + + // begin handwritten code (all other parts of this file are forked from generated code) + // solve for the following diff when no scaling settings are configured: + // + // - automatic_scaling { + // - max_concurrent_requests = 0 -> null + // - max_idle_instances = 0 -> null + // - min_idle_instances = 0 -> null + // } + // + // this happens because the field is returned as: + // + //"automaticScaling": { + // "standardSchedulerSettings": {} + // }, + // + // this is hacky but avoids marking the field as computed, since it's in a oneof + // if any new fields are added to the block or explicit defaults start getting + // returned, it will need to be updated + if transformed["max_concurrent_requests"] == nil && // even primitives are nil at this stage if they're not returned by the API + transformed["max_idle_instances"] == nil && + transformed["max_pending_latency"] == nil && + transformed["min_idle_instances"] == nil && + transformed["min_pending_latency"] == nil && + transformed["standard_scheduler_settings"] == nil { + return nil + } + // end handwritten code + return []interface{}{transformed} } func flattenAppEngineStandardAppVersionAutomaticScalingMaxConcurrentRequests(v interface{}, d *schema.ResourceData, config *transport_tpg.Config) interface{} {