mirror of
https://github.com/json-iterator/go.git
synced 2024-11-27 08:30:57 +02:00
197 lines
5.3 KiB
Go
197 lines
5.3 KiB
Go
package jsoniter
|
|
|
|
import (
|
|
"bytes"
|
|
"encoding/json"
|
|
"fmt"
|
|
"github.com/json-iterator/go/require"
|
|
"testing"
|
|
"unicode/utf8"
|
|
)
|
|
|
|
func Test_read_normal_string(t *testing.T) {
|
|
cases := map[string]string{
|
|
`"0123456789012345678901234567890123456789"`: `0123456789012345678901234567890123456789`,
|
|
`""`: ``,
|
|
`"hello"`: `hello`,
|
|
}
|
|
for input, output := range cases {
|
|
t.Run(fmt.Sprintf("%v:%v", input, output), func(t *testing.T) {
|
|
should := require.New(t)
|
|
iter := ParseString(ConfigDefault, input)
|
|
should.Equal(output, iter.ReadString())
|
|
})
|
|
t.Run(fmt.Sprintf("%v:%v", input, output), func(t *testing.T) {
|
|
should := require.New(t)
|
|
iter := Parse(ConfigDefault, bytes.NewBufferString(input), 2)
|
|
should.Equal(output, iter.ReadString())
|
|
})
|
|
t.Run(fmt.Sprintf("%v:%v", input, output), func(t *testing.T) {
|
|
should := require.New(t)
|
|
iter := ParseString(ConfigDefault, input)
|
|
should.Equal(output, string(iter.ReadStringAsSlice()))
|
|
})
|
|
t.Run(fmt.Sprintf("%v:%v", input, output), func(t *testing.T) {
|
|
should := require.New(t)
|
|
iter := Parse(ConfigDefault, bytes.NewBufferString(input), 2)
|
|
should.Equal(output, string(iter.ReadStringAsSlice()))
|
|
})
|
|
}
|
|
}
|
|
|
|
func Test_read_exotic_string(t *testing.T) {
|
|
cases := map[string]string{
|
|
`"hel\"lo"`: `hel"lo`,
|
|
`"hel\nlo"`: "hel\nlo",
|
|
`"\u4e2d\u6587"`: "中文",
|
|
`"\ud83d\udc4a"`: "\xf0\x9f\x91\x8a", // surrogate
|
|
}
|
|
for input, output := range cases {
|
|
t.Run(fmt.Sprintf("%v:%v", input, output), func(t *testing.T) {
|
|
should := require.New(t)
|
|
iter := ParseString(ConfigDefault, input)
|
|
should.Equal(output, iter.ReadString())
|
|
})
|
|
t.Run(fmt.Sprintf("%v:%v", input, output), func(t *testing.T) {
|
|
should := require.New(t)
|
|
iter := Parse(ConfigDefault, bytes.NewBufferString(input), 2)
|
|
should.Equal(output, iter.ReadString())
|
|
})
|
|
}
|
|
}
|
|
|
|
func Test_read_string_as_interface(t *testing.T) {
|
|
should := require.New(t)
|
|
iter := ParseString(ConfigDefault, `"hello"`)
|
|
should.Equal("hello", iter.Read())
|
|
}
|
|
|
|
func Test_read_string_as_any(t *testing.T) {
|
|
should := require.New(t)
|
|
any, err := UnmarshalAnyFromString(`"hello"`)
|
|
should.Nil(err)
|
|
should.Equal("hello", any.ToString())
|
|
should.True(any.ToBool())
|
|
any, err = UnmarshalAnyFromString(`" "`)
|
|
should.False(any.ToBool())
|
|
any, err = UnmarshalAnyFromString(`"false"`)
|
|
should.False(any.ToBool())
|
|
any, err = UnmarshalAnyFromString(`"123"`)
|
|
should.Equal(123, any.ToInt())
|
|
}
|
|
|
|
func Test_wrap_string(t *testing.T) {
|
|
should := require.New(t)
|
|
any := WrapString("123")
|
|
should.Equal(123, any.ToInt())
|
|
}
|
|
|
|
func Test_write_string(t *testing.T) {
|
|
should := require.New(t)
|
|
str, err := MarshalToString("hello")
|
|
should.Equal(`"hello"`, str)
|
|
should.Nil(err)
|
|
str, err = MarshalToString(`hel"lo`)
|
|
should.Equal(`"hel\"lo"`, str)
|
|
should.Nil(err)
|
|
}
|
|
|
|
func Test_write_val_string(t *testing.T) {
|
|
should := require.New(t)
|
|
buf := &bytes.Buffer{}
|
|
stream := NewStream(ConfigDefault, buf, 4096)
|
|
stream.WriteVal("hello")
|
|
stream.Flush()
|
|
should.Nil(stream.Error)
|
|
should.Equal(`"hello"`, buf.String())
|
|
}
|
|
|
|
func Test_decode_slash(t *testing.T) {
|
|
should := require.New(t)
|
|
var obj interface{}
|
|
should.NotNil(json.Unmarshal([]byte("\\"), &obj))
|
|
should.NotNil(UnmarshalFromString("\\", &obj))
|
|
}
|
|
|
|
func Test_html_escape(t *testing.T) {
|
|
should := require.New(t)
|
|
output, err := json.Marshal(`>`)
|
|
should.Nil(err)
|
|
should.Equal(`"\u003e"`, string(output))
|
|
output, err = ConfigCompatibleWithStandardLibrary.Marshal(`>`)
|
|
should.Nil(err)
|
|
should.Equal(`"\u003e"`, string(output))
|
|
}
|
|
|
|
func Test_string_encode_with_std(t *testing.T) {
|
|
should := require.New(t)
|
|
for i := 0; i < utf8.RuneSelf; i++ {
|
|
input := string([]byte{byte(i)})
|
|
stdOutputBytes, err := json.Marshal(input)
|
|
should.Nil(err)
|
|
stdOutput := string(stdOutputBytes)
|
|
jsoniterOutputBytes, err := ConfigCompatibleWithStandardLibrary.Marshal(input)
|
|
should.Nil(err)
|
|
jsoniterOutput := string(jsoniterOutputBytes)
|
|
should.Equal(stdOutput, jsoniterOutput)
|
|
}
|
|
}
|
|
|
|
func Test_string_encode_with_std_without_html_escape(t *testing.T) {
|
|
should := require.New(t)
|
|
for i := 0; i < utf8.RuneSelf; i++ {
|
|
input := string([]byte{byte(i)})
|
|
buf := &bytes.Buffer{}
|
|
encoder := json.NewEncoder(buf)
|
|
encoder.SetEscapeHTML(false)
|
|
err := encoder.Encode(input)
|
|
should.Nil(err)
|
|
stdOutput := buf.String()
|
|
stdOutput = stdOutput[:len(stdOutput)-1]
|
|
jsoniterOutputBytes, err := Marshal(input)
|
|
should.Nil(err)
|
|
jsoniterOutput := string(jsoniterOutputBytes)
|
|
should.Equal(stdOutput, jsoniterOutput)
|
|
}
|
|
}
|
|
|
|
func Benchmark_jsoniter_unicode(b *testing.B) {
|
|
for n := 0; n < b.N; n++ {
|
|
iter := ParseString(ConfigDefault, `"\ud83d\udc4a"`)
|
|
iter.ReadString()
|
|
}
|
|
}
|
|
|
|
func Benchmark_jsoniter_ascii(b *testing.B) {
|
|
iter := NewIterator(ConfigDefault)
|
|
input := []byte(`"hello, world! hello, world!"`)
|
|
b.ResetTimer()
|
|
for n := 0; n < b.N; n++ {
|
|
iter.ResetBytes(input)
|
|
iter.ReadString()
|
|
}
|
|
}
|
|
|
|
func Benchmark_jsoniter_string_as_bytes(b *testing.B) {
|
|
iter := ParseString(ConfigDefault, `"hello, world!"`)
|
|
b.ResetTimer()
|
|
for n := 0; n < b.N; n++ {
|
|
iter.ResetBytes(iter.buf)
|
|
iter.ReadStringAsSlice()
|
|
}
|
|
}
|
|
|
|
func Benchmark_json_unicode(b *testing.B) {
|
|
for n := 0; n < b.N; n++ {
|
|
result := ""
|
|
json.Unmarshal([]byte(`"\ud83d\udc4a"`), &result)
|
|
}
|
|
}
|
|
|
|
func Benchmark_json_ascii(b *testing.B) {
|
|
for n := 0; n < b.N; n++ {
|
|
result := ""
|
|
json.Unmarshal([]byte(`"hello"`), &result)
|
|
}
|
|
}
|