opentofu/states/resource_test.go
Martin Atkins 2b5d9506b1 states: Fix TestResourceInstanceDeposeCurrentObject
This was missed when changing the signature of deposeCurrentObject in an
earlier commit.
2018-10-16 19:14:11 -07:00

57 lines
1.6 KiB
Go

package states
import (
"testing"
)
func TestResourceInstanceDeposeCurrentObject(t *testing.T) {
obj := &ResourceInstanceObjectSrc{
// Empty for the sake of this test, because we're just going to
// compare by pointer below anyway.
}
is := NewResourceInstance()
is.Current = obj
var dk DeposedKey
t.Run("first depose", func(t *testing.T) {
dk = is.deposeCurrentObject(NotDeposed) // dk is randomly-generated but should be eight characters long
t.Logf("deposedKey is %q", dk)
if got := is.Current; got != nil {
t.Errorf("current is %#v; want nil", got)
}
if got, want := is.Deposed[dk], obj; got != want {
t.Errorf("deposed object pointer is %#v; want %#v", got, want)
}
if got, want := len(is.Deposed), 1; got != want {
t.Errorf("wrong len(is.Deposed) %d; want %d", got, want)
}
if got, want := len(dk), 8; got != want {
t.Errorf("wrong len(deposedkey) %d; want %d", got, want)
}
})
t.Run("second depose", func(t *testing.T) {
notDK := is.deposeCurrentObject(NotDeposed)
if notDK != NotDeposed {
t.Errorf("got deposedKey %q; want NotDeposed", notDK)
}
// Make sure we really did abort early, and haven't corrupted the
// state somehow.
if got := is.Current; got != nil {
t.Errorf("current is %#v; want nil", got)
}
if got, want := is.Deposed[dk], obj; got != want {
t.Errorf("deposed object pointer is %#v; want %#v", got, want)
}
if got, want := len(is.Deposed), 1; got != want {
t.Errorf("wrong len(is.Deposed) %d; want %d", got, want)
}
if got, want := len(dk), 8; got != want {
t.Errorf("wrong len(deposedkey) %d; want %d", got, want)
}
})
}