diff --git a/google-beta/resource_spanner_database.go b/google-beta/resource_spanner_database.go index 05f36be47a..3488363725 100644 --- a/google-beta/resource_spanner_database.go +++ b/google-beta/resource_spanner_database.go @@ -119,6 +119,20 @@ func resourceSpannerDatabaseCreate(d *schema.ResourceData, meta interface{}) err } d.SetId(id) + project, err := getProject(d, config) + if err != nil { + return err + } + waitErr := spannerOperationWaitTime( + config, res, project, "Creating Database", + int(d.Timeout(schema.TimeoutCreate).Minutes())) + + if waitErr != nil { + // The resource didn't actually create + d.SetId("") + return fmt.Errorf("Error waiting to create Database: %s", waitErr) + } + log.Printf("[DEBUG] Finished creating Database %q: %#v", d.Id(), res) return resourceSpannerDatabaseRead(d, meta) @@ -178,6 +192,19 @@ func resourceSpannerDatabaseDelete(d *schema.ResourceData, meta interface{}) err return handleNotFoundError(err, d, "Database") } + project, err := getProject(d, config) + if err != nil { + return err + } + + err = spannerOperationWaitTime( + config, res, project, "Deleting Database", + int(d.Timeout(schema.TimeoutDelete).Minutes())) + + if err != nil { + return err + } + log.Printf("[DEBUG] Finished deleting Database %q: %#v", d.Id(), res) return nil } diff --git a/google-beta/resource_spanner_instance.go b/google-beta/resource_spanner_instance.go index 5895429c4e..753fd36239 100644 --- a/google-beta/resource_spanner_instance.go +++ b/google-beta/resource_spanner_instance.go @@ -25,6 +25,7 @@ import ( "github.com/hashicorp/terraform/helper/resource" "github.com/hashicorp/terraform/helper/schema" + "google.golang.org/api/spanner/v1" ) func resourceSpannerInstance() *schema.Resource { @@ -265,9 +266,14 @@ func resourceSpannerInstanceUpdate(d *schema.ResourceData, meta interface{}) err if err != nil { return err } + op := &spanner.Operation{} + err = Convert(res, op) + if err != nil { + return err + } err = spannerOperationWaitTime( - config, res, project, "Updating Instance", + config.clientSpanner, op, project, "Updating Instance", int(d.Timeout(schema.TimeoutUpdate).Minutes())) if err != nil { @@ -296,9 +302,14 @@ func resourceSpannerInstanceDelete(d *schema.ResourceData, meta interface{}) err if err != nil { return err } + op := &spanner.Operation{} + err = Convert(res, op) + if err != nil { + return err + } err = spannerOperationWaitTime( - config, res, project, "Deleting Instance", + config.clientSpanner, op, project, "Deleting Instance", int(d.Timeout(schema.TimeoutDelete).Minutes())) if err != nil {