From 043a283120dfd4155551cbfc35531aa608718920 Mon Sep 17 00:00:00 2001 From: Scott Suarez Date: Wed, 1 Sep 2021 17:45:14 -0700 Subject: [PATCH] handle scenarios where the dcl resource can't be found on READ --- tpgtools/handwritten/tpgtools_utils.go | 21 +++++++++++++++++++++ tpgtools/templates/resource.go.tmpl | 5 ++--- 2 files changed, 23 insertions(+), 3 deletions(-) diff --git a/tpgtools/handwritten/tpgtools_utils.go b/tpgtools/handwritten/tpgtools_utils.go index 261c679524d8..cdcb287d27b1 100644 --- a/tpgtools/handwritten/tpgtools_utils.go +++ b/tpgtools/handwritten/tpgtools_utils.go @@ -1,5 +1,26 @@ package google +import ( + "fmt" + "log" + + dcl "github.com/GoogleCloudPlatform/declarative-resource-client-library/dcl" + "github.com/hashicorp/errwrap" + "github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema" +) + func oldValue(old, new interface{}) interface{} { return old } + +func handleNotFoundDCLError(err error, d *schema.ResourceData, resourceName string) error { + if dcl.IsNotFound(err) { + log.Printf("[WARN] Removing %s because it's gone", resourceName) + // The resource doesn't exist anymore + d.SetId("") + return nil + } + + return errwrap.Wrapf( + fmt.Sprintf("Error when reading or editing %s: {{err}}", resourceName), err) +} diff --git a/tpgtools/templates/resource.go.tmpl b/tpgtools/templates/resource.go.tmpl index 3464fb271055..44c10adf0e3b 100644 --- a/tpgtools/templates/resource.go.tmpl +++ b/tpgtools/templates/resource.go.tmpl @@ -327,9 +327,8 @@ func resource{{$.PathType}}Read(d *schema.ResourceData, meta interface{}) error client := NewDCL{{$.ProductType}}Client(config, userAgent, billingProject) res, err := client.Get{{$.Type}}(context.Background(), obj) if err != nil { - // Resource not found - d.SetId("") - return err + resourceName := fmt.Sprintf("{{$.PathType}} %q", d.Id()) + return handleNotFoundDCLError(err, d, resourceName) } {{ range $v := .Properties -}}