package jsoniter import ( "github.com/json-iterator/go/require" "testing" "unsafe" "encoding/json" ) func Test_write_array_of_interface(t *testing.T) { should := require.New(t) array := []interface{}{"hello"} str, err := MarshalToString(array) should.Nil(err) should.Equal(`["hello"]`, str) } func Test_write_map_of_interface(t *testing.T) { should := require.New(t) val := map[string]interface{}{"hello": "world"} str, err := MarshalToString(val) should.Nil(err) should.Equal(`{"hello":"world"}`, str) } func Test_write_map_of_interface_in_struct(t *testing.T) { type TestObject struct { Field map[string]interface{} } should := require.New(t) val := TestObject{map[string]interface{}{"hello": "world"}} str, err := MarshalToString(val) should.Nil(err) should.Equal(`{"Field":{"hello":"world"}}`, str) } func Test_write_map_of_interface_in_struct_with_two_fields(t *testing.T) { type TestObject struct { Field map[string]interface{} Field2 string } should := require.New(t) val := TestObject{map[string]interface{}{"hello": "world"}, ""} str, err := MarshalToString(val) should.Nil(err) should.Contains(str, `"Field":{"hello":"world"}`) } type MyInterface interface { Hello() string } type MyString string func (ms MyString) Hello() string { return string(ms) } func Test_write_map_of_custom_interface(t *testing.T) { should := require.New(t) myStr := MyString("world") should.Equal("world", myStr.Hello()) val := map[string]MyInterface{"hello": myStr} str, err := MarshalToString(val) should.Nil(err) should.Equal(`{"hello":"world"}`, str) } func Test_write_interface(t *testing.T) { should := require.New(t) var val interface{} val = "hello" str, err := MarshalToString(val) should.Nil(err) should.Equal(`"hello"`, str) } func Test_read_interface(t *testing.T) { should := require.New(t) var val interface{} err := UnmarshalFromString(`"hello"`, &val) should.Nil(err) should.Equal("hello", val) } func Test_read_custom_interface(t *testing.T) { should := require.New(t) var val MyInterface RegisterTypeDecoder("jsoniter.MyInterface", func(ptr unsafe.Pointer, iter *Iterator) { *((*MyInterface)(ptr)) = MyString(iter.ReadString()) }) err := UnmarshalFromString(`"hello"`, &val) should.Nil(err) should.Equal("hello", val.Hello()) } func Test_decode_object_contain_empty_interface(t *testing.T) { type TestObject struct { Field interface{} } should := require.New(t) obj := TestObject{} obj.Field = 1024 should.Nil(UnmarshalFromString(`{"Field": "hello"}`, &obj)) should.Equal("hello", obj.Field) } func Test_decode_object_contain_non_empty_interface(t *testing.T) { type TestObject struct { Field MyInterface } should := require.New(t) obj := TestObject{} obj.Field = MyString("abc") should.Nil(UnmarshalFromString(`{"Field": "hello"}`, &obj)) should.Equal(MyString("hello"), obj.Field) } func Test_encode_object_contain_empty_interface(t *testing.T) { type TestObject struct { Field interface{} } should := require.New(t) obj := TestObject{} obj.Field = 1024 str, err := MarshalToString(obj) should.Nil(err) should.Equal(`{"Field":1024}`, str) } func Test_encode_object_contain_non_empty_interface(t *testing.T) { type TestObject struct { Field MyInterface } should := require.New(t) obj := TestObject{} obj.Field = MyString("hello") str, err := MarshalToString(obj) should.Nil(err) should.Equal(`{"Field":"hello"}`, str) } func Test_nil_non_empty_interface(t *testing.T) { CleanEncoders() CleanDecoders() type TestObject struct { Field []MyInterface } should := require.New(t) obj := TestObject{} b := []byte(`{"Field":["AAA"]}`) should.NotNil(json.Unmarshal(b, &obj)) should.NotNil(Unmarshal(b, &obj)) }