From 50d0ab84d76a0655e9373bd7b51ee13f50979798 Mon Sep 17 00:00:00 2001 From: karolgorc Date: Wed, 14 Aug 2024 20:17:48 +0200 Subject: [PATCH] Fix condition in forceNewIfNetworkIPNotUpdatableFunc (#11395) --- .../compute/resource_compute_instance.go.erb | 4 +- .../resource_compute_instance_test.go.erb | 178 ++++++++++++++++++ 2 files changed, 181 insertions(+), 1 deletion(-) diff --git a/mmv1/third_party/terraform/services/compute/resource_compute_instance.go.erb b/mmv1/third_party/terraform/services/compute/resource_compute_instance.go.erb index 694f4637ea96..ba636c3cf430 100644 --- a/mmv1/third_party/terraform/services/compute/resource_compute_instance.go.erb +++ b/mmv1/third_party/terraform/services/compute/resource_compute_instance.go.erb @@ -116,11 +116,13 @@ func forceNewIfNetworkIPNotUpdatableFunc(d tpgresource.TerraformResourceDiff) er for i := 0; i < newCount.(int); i++ { prefix := fmt.Sprintf("network_interface.%d", i) networkKey := prefix + ".network" + oldN, newN := d.GetChange(networkKey) subnetworkKey := prefix + ".subnetwork" + oldS, newS := d.GetChange(subnetworkKey) subnetworkProjectKey := prefix + ".subnetwork_project" networkIPKey := prefix + ".network_ip" if d.HasChange(networkIPKey) { - if !d.HasChange(networkKey) && !d.HasChange(subnetworkKey) && !d.HasChange(subnetworkProjectKey) { + if tpgresource.CompareSelfLinkOrResourceName("", oldS.(string), newS.(string), nil) && !d.HasChange(subnetworkProjectKey) && tpgresource.CompareSelfLinkOrResourceName("", oldN.(string), newN.(string), nil) { if err := d.ForceNew(networkIPKey); err != nil { return err } diff --git a/mmv1/third_party/terraform/services/compute/resource_compute_instance_test.go.erb b/mmv1/third_party/terraform/services/compute/resource_compute_instance_test.go.erb index c6cda7961837..a788a5166e3a 100644 --- a/mmv1/third_party/terraform/services/compute/resource_compute_instance_test.go.erb +++ b/mmv1/third_party/terraform/services/compute/resource_compute_instance_test.go.erb @@ -2699,6 +2699,46 @@ func TestAccComputeInstance_subnetworkUpdate(t *testing.T) { }) } +func TestAccComputeInstance_networkIpUpdate(t *testing.T) { + t.Parallel() + + var instance compute.Instance + instanceName := fmt.Sprintf("tf-test-%s", acctest.RandString(t, 10)) + suffix := fmt.Sprintf("%s", acctest.RandString(t, 10)) + + acctest.VcrTest(t, resource.TestCase{ + PreCheck: func() { acctest.AccTestPreCheck(t) }, + ProtoV5ProviderFactories: acctest.ProtoV5ProviderFactories(t), + CheckDestroy: testAccCheckComputeInstanceDestroyProducer(t), + Steps: []resource.TestStep{ + { + Config: testAccComputeInstance_networkIpUpdate(suffix, instanceName), + Check: resource.ComposeTestCheckFunc( + testAccCheckComputeInstanceExists(t, "google_compute_instance.foobar", &instance), + testAccCheckComputeInstanceHasNetworkIP(&instance, "10.3.0.3"), + ), + }, + computeInstanceImportStep("us-east1-d", instanceName, []string{}), + { + Config: testAccComputeInstance_networkIpUpdateByHand(suffix, instanceName), + Check: resource.ComposeTestCheckFunc( + testAccCheckComputeInstanceExists(t, "google_compute_instance.foobar", &instance), + testAccCheckComputeInstanceHasNetworkIP(&instance, "10.3.0.4"), + ), + }, + computeInstanceImportStep("us-east1-d", instanceName, []string{}), + { + Config: testAccComputeInstance_networkIpUpdateWithComputeAddress(suffix, instanceName), + Check: resource.ComposeTestCheckFunc( + testAccCheckComputeInstanceExists(t, "google_compute_instance.foobar", &instance), + testAccCheckComputeInstanceHasNetworkIP(&instance, "10.3.0.5"), + ), + }, + computeInstanceImportStep("us-east1-d", instanceName, []string{}), + }, + }) +} + func TestAccComputeInstance_queueCount(t *testing.T) { t.Parallel() instanceName := fmt.Sprintf("tf-test-%s", acctest.RandString(t, 10)) @@ -8697,6 +8737,144 @@ func testAccComputeInstance_subnetworkUpdateTwo(suffix, instance string) string `, suffix, suffix, suffix, suffix, instance) } +func testAccComputeInstance_networkIpUpdate(suffix, instance string) string { + return fmt.Sprintf(` + data "google_compute_image" "my_image" { + family = "debian-11" + project = "debian-cloud" + } + + resource "google_compute_network" "inst-test-network" { + name = "tf-test-network-%s" + auto_create_subnetworks = false + } + + resource "google_compute_subnetwork" "inst-test-subnetwork" { + name = "tf-test-compute-subnet-%s" + ip_cidr_range = "10.3.0.0/16" + region = "us-east1" + network = google_compute_network.inst-test-network.id + } + + resource "google_compute_address" "inst-test-address" { + name = "tf-test-compute-address-%s" + region = "us-east1" + subnetwork = google_compute_subnetwork.inst-test-subnetwork.id + address_type = "INTERNAL" + address = "10.3.0.5" + } + + resource "google_compute_instance" "foobar" { + name = "%s" + machine_type = "e2-medium" + zone = "us-east1-d" + + boot_disk { + initialize_params { + image = data.google_compute_image.my_image.id + } + } + + network_interface { + subnetwork = google_compute_subnetwork.inst-test-subnetwork.id + network_ip = "10.3.0.3" + } + } +`, suffix, suffix, suffix, instance) +} + +func testAccComputeInstance_networkIpUpdateByHand(suffix, instance string) string { + return fmt.Sprintf(` + data "google_compute_image" "my_image" { + family = "debian-11" + project = "debian-cloud" + } + + resource "google_compute_network" "inst-test-network" { + name = "tf-test-network-%s" + auto_create_subnetworks = false + } + + resource "google_compute_subnetwork" "inst-test-subnetwork" { + name = "tf-test-compute-subnet-%s" + ip_cidr_range = "10.3.0.0/16" + region = "us-east1" + network = google_compute_network.inst-test-network.id + } + + resource "google_compute_address" "inst-test-address" { + name = "tf-test-compute-address-%s" + region = "us-east1" + subnetwork = google_compute_subnetwork.inst-test-subnetwork.id + address_type = "INTERNAL" + address = "10.3.0.5" + } + + resource "google_compute_instance" "foobar" { + name = "%s" + machine_type = "e2-medium" + zone = "us-east1-d" + + boot_disk { + initialize_params { + image = data.google_compute_image.my_image.id + } + } + + network_interface { + subnetwork = google_compute_subnetwork.inst-test-subnetwork.id + network_ip = "10.3.0.4" + } + } +`, suffix, suffix, suffix, instance) +} + +func testAccComputeInstance_networkIpUpdateWithComputeAddress(suffix, instance string) string { + return fmt.Sprintf(` + data "google_compute_image" "my_image" { + family = "debian-11" + project = "debian-cloud" + } + + resource "google_compute_network" "inst-test-network" { + name = "tf-test-network-%s" + auto_create_subnetworks = false + } + + resource "google_compute_subnetwork" "inst-test-subnetwork" { + name = "tf-test-compute-subnet-%s" + ip_cidr_range = "10.3.0.0/16" + region = "us-east1" + network = google_compute_network.inst-test-network.id + } + + resource "google_compute_address" "inst-test-address" { + name = "tf-test-compute-address-%s" + region = "us-east1" + subnetwork = google_compute_subnetwork.inst-test-subnetwork.id + address_type = "INTERNAL" + address = "10.3.0.5" + } + + resource "google_compute_instance" "foobar" { + name = "%s" + machine_type = "e2-medium" + zone = "us-east1-d" + + boot_disk { + initialize_params { + image = data.google_compute_image.my_image.id + } + } + + network_interface { + subnetwork = google_compute_subnetwork.inst-test-subnetwork.id + network_ip = google_compute_address.inst-test-address.address + } + } +`, suffix, suffix, suffix, instance) +} + func testAccComputeInstance_queueCountSet(instance string) string { return fmt.Sprintf(` data "google_compute_image" "my_image" {