diff --git a/command/jsonplan/values.go b/command/jsonplan/values.go index 498b0f6f750f..caa8babf4fbd 100644 --- a/command/jsonplan/values.go +++ b/command/jsonplan/values.go @@ -26,7 +26,7 @@ type stateValues struct { type attributeValues map[string]interface{} func marshalAttributeValues(value cty.Value, schema *configschema.Block) attributeValues { - if value == cty.NilVal { + if value == cty.NilVal || value.IsNull() { return nil } ret := make(attributeValues) diff --git a/command/jsonplan/values_test.go b/command/jsonplan/values_test.go index 6b04dba02cae..8395ee0aaf98 100644 --- a/command/jsonplan/values_test.go +++ b/command/jsonplan/values_test.go @@ -30,6 +30,18 @@ func TestMarshalAttributeValues(t *testing.T) { }, nil, }, + { + cty.NullVal(cty.String), + &configschema.Block{ + Attributes: map[string]*configschema.Attribute{ + "foo": { + Type: cty.String, + Optional: true, + }, + }, + }, + nil, + }, { cty.ObjectVal(map[string]cty.Value{ "foo": cty.StringVal("bar"), diff --git a/command/jsonstate/state.go b/command/jsonstate/state.go index 1923c646801c..2fac8fbba67d 100644 --- a/command/jsonstate/state.go +++ b/command/jsonstate/state.go @@ -101,9 +101,10 @@ type resource struct { type attributeValues map[string]interface{} func marshalAttributeValues(value cty.Value, schema *configschema.Block) attributeValues { - if value == cty.NilVal { + if value == cty.NilVal || value.IsNull() { return nil } + ret := make(attributeValues) it := value.ElementIterator() diff --git a/command/jsonstate/state_test.go b/command/jsonstate/state_test.go index f03dd2d45ae3..e40c123c661c 100644 --- a/command/jsonstate/state_test.go +++ b/command/jsonstate/state_test.go @@ -91,6 +91,18 @@ func TestMarshalAttributeValues(t *testing.T) { }, nil, }, + { + cty.NullVal(cty.String), + &configschema.Block{ + Attributes: map[string]*configschema.Attribute{ + "foo": { + Type: cty.String, + Optional: true, + }, + }, + }, + nil, + }, { cty.ObjectVal(map[string]cty.Value{ "foo": cty.StringVal("bar"),