Skip to content

Commit

Permalink
Change update method for boot_disk.auto_delete on `google_compute_i…
Browse files Browse the repository at this point in the history
…nstance` (#11742) (#20580)

[upstream:7ce8ed7654523056e56701a7dcfb1cc54a58a445]

Signed-off-by: Modular Magician <[email protected]>
  • Loading branch information
modular-magician authored Dec 4, 2024
1 parent a9e30d3 commit a6bcc04
Show file tree
Hide file tree
Showing 3 changed files with 96 additions and 13 deletions.
3 changes: 3 additions & 0 deletions .changelog/11742.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
```release-note:enhancement
compute: `google_compute_instance` is no longer recreated when changing `boot_disk.auto_delete`
```
13 changes: 12 additions & 1 deletion google/services/compute/resource_compute_instance.go
Original file line number Diff line number Diff line change
Expand Up @@ -212,7 +212,6 @@ func ResourceComputeInstance() *schema.Resource {
Optional: true,
AtLeastOneOf: bootDiskKeys,
Default: true,
ForceNew: true,
Description: `Whether the disk will be auto-deleted when the instance is deleted.`,
},

Expand Down Expand Up @@ -2338,6 +2337,18 @@ func resourceComputeInstanceUpdate(d *schema.ResourceData, meta interface{}) err
}
}

// if any other boot_disk fields will be added here this should be wrapped in if d.HasChange("boot_disk")
if d.HasChange("boot_disk.0.auto_delete") {
op, err := config.NewComputeClient(userAgent).Instances.SetDiskAutoDelete(project, zone, instance.Name, d.Get("boot_disk.0.auto_delete").(bool), d.Get("boot_disk.0.device_name").(string)).Do()
if err != nil {
return fmt.Errorf("Error changing auto_delete: %s", err)
}
opErr := ComputeOperationWaitTime(config, op, project, "changing auto_delete", userAgent, d.Timeout(schema.TimeoutUpdate))
if opErr != nil {
return opErr
}
}

// d.HasChange("service_account") is oversensitive: see https://github.com/hashicorp/terraform/issues/17411
// Until that's fixed, manually check whether there is a change.
o, n := d.GetChange("service_account")
Expand Down
93 changes: 81 additions & 12 deletions google/services/compute/resource_compute_instance_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -3469,6 +3469,49 @@ func TestAccComputeInstance_proactiveAttributionLabel(t *testing.T) {
})
}

func TestAccComputeInstance_autoDeleteUpdate(t *testing.T) {
t.Parallel()

var instance compute.Instance
context_1 := map[string]interface{}{
"instance_name": fmt.Sprintf("tf-test-%s", acctest.RandString(t, 10)),
"auto_delete": "true",
}
context_2 := map[string]interface{}{
"instance_name": context_1["instance_name"],
"auto_delete": "false",
}

acctest.VcrTest(t, resource.TestCase{
PreCheck: func() { acctest.AccTestPreCheck(t) },
ProtoV5ProviderFactories: acctest.ProtoV5ProviderFactories(t),
CheckDestroy: testAccCheckComputeInstanceDestroyProducer(t),
Steps: []resource.TestStep{
{
Config: testAccComputeInstance_autoDeleteUpdate(context_1),
Check: resource.ComposeTestCheckFunc(
testAccCheckComputeInstanceExists(t, "google_compute_instance.foobar", &instance),
resource.TestCheckResourceAttr("google_compute_instance.foobar", "boot_disk.0.auto_delete", "true"),
),
},
{
Config: testAccComputeInstance_autoDeleteUpdate(context_2),
Check: resource.ComposeTestCheckFunc(
testAccCheckComputeInstanceExists(t, "google_compute_instance.foobar", &instance),
resource.TestCheckResourceAttr("google_compute_instance.foobar", "boot_disk.0.auto_delete", "false"),
),
},
{
Config: testAccComputeInstance_autoDeleteUpdate(context_1),
Check: resource.ComposeTestCheckFunc(
testAccCheckComputeInstanceExists(t, "google_compute_instance.foobar", &instance),
resource.TestCheckResourceAttr("google_compute_instance.foobar", "boot_disk.0.auto_delete", "true"),
),
},
},
})
}

func TestAccComputeInstance_keyRevocationActionType(t *testing.T) {
t.Parallel()

Expand Down Expand Up @@ -9355,29 +9398,55 @@ resource "google_compute_instance" "foobar" {
`, diskName, instanceName, machineType, zone, bootDiskInterface, allowStoppingForUpdate)
}

func testAccComputeInstance_autoDeleteUpdate(context map[string]interface{}) string {
return acctest.Nprintf(`
data "google_compute_image" "my_image" {
family = "debian-11"
project = "debian-cloud"
}
resource "google_compute_instance" "foobar" {
name = "%{instance_name}"
machine_type = "n1-standard-1"
zone = "us-central1-a"
boot_disk {
auto_delete = %{auto_delete}
initialize_params {
image = data.google_compute_image.my_image.self_link
}
}
network_interface {
network = "default"
}
}
`, context)
}

func testAccComputeInstance_keyRevocationActionType(context map[string]interface{}) string {
return acctest.Nprintf(`
data "google_compute_image" "my_image" {
family = "debian-11"
project = "debian-cloud"
family = "debian-11"
project = "debian-cloud"
}
resource "google_compute_instance" "foobar" {
name = "%{instance_name}"
machine_type = "e2-medium"
zone = "us-central1-a"
name = "%{instance_name}"
machine_type = "e2-medium"
zone = "us-central1-a"
boot_disk {
boot_disk {
initialize_params {
image = data.google_compute_image.my_image.self_link
image = data.google_compute_image.my_image.self_link
}
}
}
network_interface {
network = "default"
}
network_interface {
network = "default"
}
key_revocation_action_type = %{key_revocation_action_type}
key_revocation_action_type = %{key_revocation_action_type}
}
`, context)
}

0 comments on commit a6bcc04

Please sign in to comment.