From 0707eb4d81de2a746ab685c43f939a99bfa249c3 Mon Sep 17 00:00:00 2001 From: Clint Date: Wed, 14 Jun 2017 16:31:40 -0500 Subject: [PATCH] Compute and Disk fixes (#1) * compute_disk: update image in test * disk_image: add default type, make size computed * compute_dis: wait on disk size operations to complete before moving on * update docks on the image --- google/resource_compute_disk.go | 8 +++++++- google/resource_compute_disk_test.go | 2 +- website/docs/r/compute_disk.html.markdown | 8 +++----- 3 files changed, 11 insertions(+), 7 deletions(-) diff --git a/google/resource_compute_disk.go b/google/resource_compute_disk.go index c577ad298c3..7b7d564372f 100644 --- a/google/resource_compute_disk.go +++ b/google/resource_compute_disk.go @@ -69,6 +69,7 @@ func resourceComputeDisk() *schema.Resource { "size": &schema.Schema{ Type: schema.TypeInt, Optional: true, + Computed: true, }, "self_link": &schema.Schema{ @@ -85,6 +86,7 @@ func resourceComputeDisk() *schema.Resource { "type": &schema.Schema{ Type: schema.TypeString, Optional: true, + Default: "pd-standard", ForceNew: true, }, "users": &schema.Schema{ @@ -197,11 +199,15 @@ func resourceComputeDiskUpdate(d *schema.ResourceData, meta interface{}) error { rb := &compute.DisksResizeRequest{ SizeGb: int64(d.Get("size").(int)), } - _, err := config.clientCompute.Disks.Resize( + op, err := config.clientCompute.Disks.Resize( project, d.Get("zone").(string), d.Id(), rb).Do() if err != nil { return fmt.Errorf("Error resizing disk: %s", err) } + err = computeOperationWaitZone(config, op, project, d.Get("zone").(string), "Resizing Disk") + if err != nil { + return err + } } return resourceComputeDiskRead(d, meta) diff --git a/google/resource_compute_disk_test.go b/google/resource_compute_disk_test.go index 2583c8e9667..8591a7ea453 100644 --- a/google/resource_compute_disk_test.go +++ b/google/resource_compute_disk_test.go @@ -292,7 +292,7 @@ func testAccComputeDisk_deleteDetach(instanceName, diskName string) string { return fmt.Sprintf(` resource "google_compute_disk" "foo" { name = "%s" - image = "debian-8" + image = "debian-8-jessie-v20170523" size = 50 type = "pd-ssd" zone = "us-central1-a" diff --git a/website/docs/r/compute_disk.html.markdown b/website/docs/r/compute_disk.html.markdown index 879393fa926..8315559c16f 100644 --- a/website/docs/r/compute_disk.html.markdown +++ b/website/docs/r/compute_disk.html.markdown @@ -20,7 +20,7 @@ resource "google_compute_disk" "default" { name = "test-disk" type = "pd-ssd" zone = "us-central1-a" - image = "debian-cloud/debian-8" + image = "debian-8-jessie-v20170523" } ``` @@ -41,10 +41,8 @@ The following arguments are supported: to encrypt this disk. * `image` - (Optional) The image from which to initialize this disk. This can be - one of: the image's `self_link`, `projects/{project}/global/images/{image}`, - `projects/{project}/global/images/family/{family}`, `global/images/{image}`, - `global/images/family/{family}`, `family/{family}`, `{project}/{family}`, - `{project}/{image}`, `{family}`, or `{image}`. + one of: the image's `self_link`, of a full name and version, e.g. + `debian-8-jessie-v20170523` * `project` - (Optional) The project in which the resource belongs. If it is not provided, the provider project is used.