From 7eb72e7a124760ab1a8fe6ddddf2c08005891786 Mon Sep 17 00:00:00 2001 From: Paul Hinze Date: Mon, 3 Aug 2015 15:52:04 -0500 Subject: [PATCH] helper/schema: record schema version when destroy fails This was just a missed exit from the resource.Apply function - subsequent refreshes would add the SchemaVersion back into the state, but having the state recorded once without the meta information can cause problems with Atlas's remote state checksumming. --- helper/schema/resource.go | 2 +- helper/schema/resource_test.go | 6 +++++- 2 files changed, 6 insertions(+), 2 deletions(-) diff --git a/helper/schema/resource.go b/helper/schema/resource.go index cc759e0d6c..571fe18a60 100644 --- a/helper/schema/resource.go +++ b/helper/schema/resource.go @@ -119,7 +119,7 @@ func (r *Resource) Apply( if s.ID != "" { // Destroy the resource since it is created if err := r.Delete(data, meta); err != nil { - return data.State(), err + return r.recordCurrentSchemaVersion(data.State()), err } // Make sure the ID is gone. diff --git a/helper/schema/resource_test.go b/helper/schema/resource_test.go index b27bd193a2..e35979eb2f 100644 --- a/helper/schema/resource_test.go +++ b/helper/schema/resource_test.go @@ -180,6 +180,7 @@ func TestResourceApply_destroyPartial(t *testing.T) { Optional: true, }, }, + SchemaVersion: 3, } r.Delete = func(d *ResourceData, m interface{}) error { @@ -209,10 +210,13 @@ func TestResourceApply_destroyPartial(t *testing.T) { "id": "bar", "foo": "42", }, + Meta: map[string]string{ + "schema_version": "3", + }, } if !reflect.DeepEqual(actual, expected) { - t.Fatalf("bad: %#v", actual) + t.Fatalf("expected:\n%#v\n\ngot:\n%#v", expected, actual) } }