Files

324 lines
7.2 KiB
Go
Raw Permalink Normal View History

2016-12-20 17:49:43 +03:00
package tests
import (
"math"
2016-12-20 17:49:43 +03:00
"testing"
"github.com/mailru/easyjson/jlexer"
)
2017-01-11 03:18:07 +03:00
func TestMultipleErrorsInt(t *testing.T) {
2016-12-20 17:49:43 +03:00
for i, test := range []struct {
2017-01-11 03:18:07 +03:00
Data []byte
Offsets []int
2016-12-20 17:49:43 +03:00
}{
{
2017-01-11 03:18:07 +03:00
Data: []byte(`[1, 2, 3, "4", "5"]`),
Offsets: []int{10, 15},
2016-12-20 17:49:43 +03:00
},
{
2017-01-11 03:18:07 +03:00
Data: []byte(`[1, {"2":"3"}, 3, "4"]`),
Offsets: []int{4, 18},
2016-12-20 17:49:43 +03:00
},
{
2017-01-11 03:18:07 +03:00
Data: []byte(`[1, "2", "3", "4", "5", "6"]`),
Offsets: []int{4, 9, 14, 19, 24},
2016-12-20 17:49:43 +03:00
},
{
2017-01-11 03:18:07 +03:00
Data: []byte(`[1, 2, 3, 4, "5"]`),
Offsets: []int{13},
2016-12-20 17:49:43 +03:00
},
2017-01-08 17:47:01 +03:00
{
2017-01-11 03:18:07 +03:00
Data: []byte(`[{"1": "2"}]`),
Offsets: []int{1},
2017-01-08 17:47:01 +03:00
},
2016-12-20 17:49:43 +03:00
} {
2017-01-08 17:47:01 +03:00
l := jlexer.Lexer{
Data: test.Data,
UseMultipleErrors: true,
}
2016-12-20 17:49:43 +03:00
var v ErrorIntSlice
v.UnmarshalEasyJSON(&l)
2017-01-12 16:34:28 +03:00
errors := l.GetNonFatalErrors()
2017-01-11 03:18:07 +03:00
if len(errors) != len(test.Offsets) {
t.Errorf("[%d] TestMultipleErrorsInt(): errornum: want: %d, got %d", i, len(test.Offsets), len(errors))
2017-01-11 19:46:47 +03:00
return
2017-01-11 03:18:07 +03:00
}
for ii, e := range errors {
if e.Offset != test.Offsets[ii] {
t.Errorf("[%d] TestMultipleErrorsInt(): offset[%d]: want %d, got %d", i, ii, test.Offsets[ii], e.Offset)
}
2016-12-20 17:49:43 +03:00
}
}
}
2016-12-20 18:04:55 +03:00
2017-01-11 03:18:07 +03:00
func TestMultipleErrorsBool(t *testing.T) {
2016-12-20 18:04:55 +03:00
for i, test := range []struct {
2017-01-11 03:18:07 +03:00
Data []byte
Offsets []int
2016-12-20 18:04:55 +03:00
}{
{
Data: []byte(`[true, false, true, false]`),
},
{
2017-01-11 03:18:07 +03:00
Data: []byte(`["test", "value", "lol", "1"]`),
Offsets: []int{1, 9, 18, 25},
2016-12-20 18:04:55 +03:00
},
{
2017-01-11 03:18:07 +03:00
Data: []byte(`[true, 42, {"a":"b", "c":"d"}, false]`),
Offsets: []int{7, 11},
2016-12-20 18:04:55 +03:00
},
} {
2017-01-08 17:47:01 +03:00
l := jlexer.Lexer{
Data: test.Data,
UseMultipleErrors: true,
}
2016-12-20 18:04:55 +03:00
var v ErrorBoolSlice
v.UnmarshalEasyJSON(&l)
2017-01-12 16:34:28 +03:00
errors := l.GetNonFatalErrors()
2017-01-11 03:18:07 +03:00
if len(errors) != len(test.Offsets) {
t.Errorf("[%d] TestMultipleErrorsBool(): errornum: want: %d, got %d", i, len(test.Offsets), len(errors))
2017-01-11 19:46:47 +03:00
return
2017-01-11 03:18:07 +03:00
}
for ii, e := range errors {
if e.Offset != test.Offsets[ii] {
t.Errorf("[%d] TestMultipleErrorsBool(): offset[%d]: want %d, got %d", i, ii, test.Offsets[ii], e.Offset)
}
2016-12-20 18:04:55 +03:00
}
}
}
2017-01-11 03:18:07 +03:00
func TestMultipleErrorsUint(t *testing.T) {
2016-12-20 18:04:55 +03:00
for i, test := range []struct {
2017-01-11 03:18:07 +03:00
Data []byte
Offsets []int
2016-12-20 18:04:55 +03:00
}{
{
Data: []byte(`[42, 42, 42]`),
},
{
2017-01-11 03:18:07 +03:00
Data: []byte(`[17, "42", 32]`),
Offsets: []int{5},
2016-12-20 18:04:55 +03:00
},
{
2017-01-11 03:18:07 +03:00
Data: []byte(`["zz", "zz"]`),
Offsets: []int{1, 7},
2016-12-20 18:04:55 +03:00
},
2017-01-08 17:47:01 +03:00
{
2017-01-11 03:18:07 +03:00
Data: []byte(`[{}, 42]`),
Offsets: []int{1},
2017-01-08 17:47:01 +03:00
},
2016-12-20 18:04:55 +03:00
} {
2017-01-08 17:47:01 +03:00
l := jlexer.Lexer{
Data: test.Data,
UseMultipleErrors: true,
}
2016-12-20 18:04:55 +03:00
var v ErrorUintSlice
v.UnmarshalEasyJSON(&l)
2017-01-12 16:34:28 +03:00
errors := l.GetNonFatalErrors()
2017-01-11 03:18:07 +03:00
if len(errors) != len(test.Offsets) {
t.Errorf("[%d] TestMultipleErrorsUint(): errornum: want: %d, got %d", i, len(test.Offsets), len(errors))
2017-01-11 19:46:47 +03:00
return
2017-01-11 03:18:07 +03:00
}
for ii, e := range errors {
if e.Offset != test.Offsets[ii] {
t.Errorf("[%d] TestMultipleErrorsUint(): offset[%d]: want %d, got %d", i, ii, test.Offsets[ii], e.Offset)
}
2017-01-08 17:47:01 +03:00
}
}
}
2017-01-11 03:18:07 +03:00
func TestMultipleErrorsStruct(t *testing.T) {
2017-01-08 17:47:01 +03:00
for i, test := range []struct {
2017-01-11 03:18:07 +03:00
Data []byte
Offsets []int
2017-01-08 17:47:01 +03:00
}{
{
Data: []byte(`{"string": "test", "slice":[42, 42, 42], "int_slice":[1, 2, 3]}`),
},
{
2017-01-11 03:18:07 +03:00
Data: []byte(`{"string": {"test": "test"}, "slice":[42, 42, 42], "int_slice":["1", 2, 3]}`),
Offsets: []int{11, 64},
2017-01-08 17:47:01 +03:00
},
{
2017-01-11 03:18:07 +03:00
Data: []byte(`{"slice": [42, 42], "string": {"test": "test"}, "int_slice":["1", "2", 3]}`),
Offsets: []int{30, 61, 66},
2017-01-08 17:47:01 +03:00
},
{
2017-01-11 03:18:07 +03:00
Data: []byte(`{"string": "test", "slice": {}}`),
Offsets: []int{28},
2017-01-08 17:47:01 +03:00
},
{
2017-01-11 03:18:07 +03:00
Data: []byte(`{"slice":5, "string" : "test"}`),
Offsets: []int{9},
2017-01-08 17:47:01 +03:00
},
{
2017-01-11 03:18:07 +03:00
Data: []byte(`{"slice" : "test", "string" : "test"}`),
Offsets: []int{11},
2017-01-08 17:47:01 +03:00
},
{
2017-01-11 03:18:07 +03:00
Data: []byte(`{"slice": "", "string" : {}, "int":{}}`),
Offsets: []int{10, 25, 35},
2017-01-08 17:47:01 +03:00
},
} {
l := jlexer.Lexer{
Data: test.Data,
UseMultipleErrors: true,
}
var v ErrorStruct
v.UnmarshalEasyJSON(&l)
2017-01-12 16:34:28 +03:00
errors := l.GetNonFatalErrors()
2017-01-11 03:18:07 +03:00
if len(errors) != len(test.Offsets) {
t.Errorf("[%d] TestMultipleErrorsStruct(): errornum: want: %d, got %d", i, len(test.Offsets), len(errors))
2017-01-11 19:46:47 +03:00
return
2017-01-11 03:18:07 +03:00
}
for ii, e := range errors {
if e.Offset != test.Offsets[ii] {
t.Errorf("[%d] TestMultipleErrorsStruct(): offset[%d]: want %d, got %d", i, ii, test.Offsets[ii], e.Offset)
}
2017-01-08 17:47:01 +03:00
}
}
}
2017-01-11 03:18:07 +03:00
func TestMultipleErrorsNestedStruct(t *testing.T) {
2017-01-08 17:47:01 +03:00
for i, test := range []struct {
2017-01-11 03:18:07 +03:00
Data []byte
Offsets []int
2017-01-08 17:47:01 +03:00
}{
{
Data: []byte(`{"error_struct":{}}`),
},
{
2017-01-11 03:18:07 +03:00
Data: []byte(`{"error_struct":5}`),
Offsets: []int{16},
2017-01-08 17:47:01 +03:00
},
{
2017-01-11 03:18:07 +03:00
Data: []byte(`{"error_struct":[]}`),
Offsets: []int{16},
2017-01-08 17:47:01 +03:00
},
{
2017-01-11 03:18:07 +03:00
Data: []byte(`{"error_struct":{"int":{}}}`),
Offsets: []int{23},
2017-01-08 17:47:01 +03:00
},
{
2017-01-11 03:18:07 +03:00
Data: []byte(`{"error_struct":{"int_slice":{}}, "int":4}`),
Offsets: []int{29},
2017-01-08 17:47:01 +03:00
},
{
2017-01-11 03:18:07 +03:00
Data: []byte(`{"error_struct":{"int_slice":["1", 2, "3"]}, "int":[]}`),
Offsets: []int{30, 38, 51},
2017-01-08 17:47:01 +03:00
},
} {
l := jlexer.Lexer{
Data: test.Data,
UseMultipleErrors: true,
}
var v ErrorNestedStruct
v.UnmarshalEasyJSON(&l)
2017-01-12 16:34:28 +03:00
errors := l.GetNonFatalErrors()
2017-01-11 03:18:07 +03:00
if len(errors) != len(test.Offsets) {
t.Errorf("[%d] TestMultipleErrorsNestedStruct(): errornum: want: %d, got %d", i, len(test.Offsets), len(errors))
2017-01-11 19:46:47 +03:00
return
2017-01-11 03:18:07 +03:00
}
for ii, e := range errors {
if e.Offset != test.Offsets[ii] {
t.Errorf("[%d] TestMultipleErrorsNestedStruct(): offset[%d]: want %d, got %d", i, ii, test.Offsets[ii], e.Offset)
}
2016-12-20 18:04:55 +03:00
}
}
}
2017-10-19 19:07:55 -07:00
func TestMultipleErrorsIntMap(t *testing.T) {
for i, test := range []struct {
Data []byte
Offsets []int
}{
{
Data: []byte(`{"a":"NumErr"}`),
Offsets: []int{1},
},
{
Data: []byte(`{"":"ErrSyntax"}`),
Offsets: []int{1},
},
{
Data: []byte(`{"a":"NumErr","33147483647":"ErrRange","-1":"ErrRange"}`),
Offsets: []int{1, 14, 39},
},
} {
l := jlexer.Lexer{
Data: test.Data,
UseMultipleErrors: true,
}
var v ErrorIntMap
v.UnmarshalEasyJSON(&l)
errors := l.GetNonFatalErrors()
if len(errors) != len(test.Offsets) {
t.Errorf("[%d] TestMultipleErrorsInt(): errornum: want: %d, got %d", i, len(test.Offsets), len(errors))
return
}
for ii, e := range errors {
if e.Offset != test.Offsets[ii] {
t.Errorf("[%d] TestMultipleErrorsInt(): offset[%d]: want %d, got %d", i, ii, test.Offsets[ii], e.Offset)
}
}
}
}
func TestUnsupportedFloatValues(t *testing.T) {
for i, test := range []struct {
Value ErrorFloatTypes
ExpectedErr string
}{
{
Value: ErrorFloatTypes{Float64: math.NaN()},
ExpectedErr: "json: unsupported value: NaN",
},
{
Value: ErrorFloatTypes{Float64: math.Inf(1)},
ExpectedErr: "json: unsupported value: +Inf",
},
{
Value: ErrorFloatTypes{Float64: math.Inf(-1)},
ExpectedErr: "json: unsupported value: -Inf",
},
{
Value: ErrorFloatTypes{Float32: float32(math.NaN())},
ExpectedErr: "json: unsupported value: NaN",
},
{
Value: ErrorFloatTypes{Float32: float32(math.Inf(1))},
ExpectedErr: "json: unsupported value: +Inf",
},
{
Value: ErrorFloatTypes{Float32: float32(math.Inf(-1))},
ExpectedErr: "json: unsupported value: -Inf",
},
} {
_, err := test.Value.MarshalJSON()
if err == nil || err.Error() != test.ExpectedErr {
t.Errorf("[%d] TestUnsupportedFloatValues(): error: want %s, got %v", i, test.ExpectedErr, err)
}
}
}