mirror of
https://github.com/opentofu/opentofu.git
synced 2025-01-20 21:52:57 -06:00
helper/schema: Resource.Data should set latest schema version
This commit is contained in:
parent
84fa3e5c9e
commit
b728e55861
@ -295,6 +295,11 @@ func (r *Resource) Data(s *terraform.InstanceState) *ResourceData {
|
||||
panic(err)
|
||||
}
|
||||
|
||||
// Set the schema version to latest by default
|
||||
result.meta = map[string]string{
|
||||
"schema_version": strconv.Itoa(r.SchemaVersion),
|
||||
}
|
||||
|
||||
return result
|
||||
}
|
||||
|
||||
|
@ -22,6 +22,7 @@ type ResourceData struct {
|
||||
config *terraform.ResourceConfig
|
||||
state *terraform.InstanceState
|
||||
diff *terraform.InstanceDiff
|
||||
meta map[string]string
|
||||
|
||||
// Don't set
|
||||
multiReader *MultiLevelFieldReader
|
||||
@ -233,6 +234,7 @@ func (d *ResourceData) SetType(t string) {
|
||||
func (d *ResourceData) State() *terraform.InstanceState {
|
||||
var result terraform.InstanceState
|
||||
result.ID = d.Id()
|
||||
result.Meta = d.meta
|
||||
|
||||
// If we have no ID, then this resource doesn't exist and we just
|
||||
// return nil.
|
||||
|
@ -873,6 +873,16 @@ func TestResourceData(t *testing.T) {
|
||||
if v := data.Get("foo"); v != 42 {
|
||||
t.Fatalf("bad: %#v", v)
|
||||
}
|
||||
|
||||
// Set expectations
|
||||
state.Meta = map[string]string{
|
||||
"schema_version": "2",
|
||||
}
|
||||
|
||||
result := data.State()
|
||||
if !reflect.DeepEqual(result, state) {
|
||||
t.Fatalf("bad: %#v", result)
|
||||
}
|
||||
}
|
||||
|
||||
func TestResourceData_blank(t *testing.T) {
|
||||
|
Loading…
Reference in New Issue
Block a user