mirror of https://github.com/goccy/go-json.git
Merge c360573ff8
into 3e9769d637
This commit is contained in:
commit
c5e60aeec1
|
@ -274,6 +274,24 @@ func Test_Decoder_UseNumber(t *testing.T) {
|
||||||
assertEq(t, "json.Number", "json.Number", fmt.Sprintf("%T", v["a"]))
|
assertEq(t, "json.Number", "json.Number", fmt.Sprintf("%T", v["a"]))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func Test_Decoder_UnexpectedEnd(t *testing.T) {
|
||||||
|
input := []byte("\"000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe2\xe200")
|
||||||
|
|
||||||
|
dec := json.NewDecoder(bytes.NewReader(input))
|
||||||
|
|
||||||
|
for {
|
||||||
|
_, err := dec.Token()
|
||||||
|
if err != nil {
|
||||||
|
var e *json.SyntaxError
|
||||||
|
if errors.As(err, &e) {
|
||||||
|
assertEq(t, "error is not expected by test", e.Error(), "json: string unexpected end of JSON input")
|
||||||
|
break
|
||||||
|
}
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func Test_Decoder_DisallowUnknownFields(t *testing.T) {
|
func Test_Decoder_DisallowUnknownFields(t *testing.T) {
|
||||||
dec := json.NewDecoder(strings.NewReader(`{"x": 1}`))
|
dec := json.NewDecoder(strings.NewReader(`{"x": 1}`))
|
||||||
dec.DisallowUnknownFields()
|
dec.DisallowUnknownFields()
|
||||||
|
|
|
@ -270,6 +270,7 @@ func stringBytes(s *Stream) ([]byte, error) {
|
||||||
r, size := utf8.DecodeRune(s.buf[cursor:])
|
r, size := utf8.DecodeRune(s.buf[cursor:])
|
||||||
if r == utf8.RuneError {
|
if r == utf8.RuneError {
|
||||||
s.buf = append(append(append([]byte{}, s.buf[:cursor]...), runeErrBytes...), s.buf[cursor+1:]...)
|
s.buf = append(append(append([]byte{}, s.buf[:cursor]...), runeErrBytes...), s.buf[cursor+1:]...)
|
||||||
|
s.bufSize = int64(len(s.buf))
|
||||||
cursor += runeErrBytesLen
|
cursor += runeErrBytesLen
|
||||||
s.length += runeErrBytesLen
|
s.length += runeErrBytesLen
|
||||||
_, _, p = s.stat()
|
_, _, p = s.stat()
|
||||||
|
|
Loading…
Reference in New Issue