Commit 2c987e16 authored by Emil Hessman's avatar Emil Hessman Committed by Mikio Hara

encoding/json: address go vet reports

The error message for decoding a unquoted value into a struct field with
the ,string option specified has two arguments when one is needed.
Make the error message take one argument and add a test in order to cover
the case when a unquoted value is specified.

Also add error value as the missing argument for Fatalf call in test.

Fixes the following go vet reports:

decode.go:602: wrong number of args for format in Errorf call: 1 needed but 2 args
decode_test.go:1088: missing argument for Fatalf("%v"): format reads arg 1, have only 0 args

Change-Id: Id036e10c54c4a7c1ee9952f6910858ecc2b84134
Reviewed-on: https://go-review.googlesource.com/2109Reviewed-by: default avatarMikio Hara <mikioh.mikioh@gmail.com>
parent b6e91380
...@@ -599,7 +599,7 @@ func (d *decodeState) object(v reflect.Value) { ...@@ -599,7 +599,7 @@ func (d *decodeState) object(v reflect.Value) {
case string: case string:
d.literalStore([]byte(qv), subv, true) d.literalStore([]byte(qv), subv, true)
default: default:
d.saveError(fmt.Errorf("json: invalid use of ,string struct tag, trying to unmarshal unquoted value into %v", item, v.Type())) d.saveError(fmt.Errorf("json: invalid use of ,string struct tag, trying to unmarshal unquoted value into %v", subv.Type()))
} }
} else { } else {
d.value(subv) d.value(subv)
......
...@@ -688,6 +688,7 @@ var wrongStringTests = []wrongStringTest{ ...@@ -688,6 +688,7 @@ var wrongStringTests = []wrongStringTest{
{`{"result":"x"}`, `json: invalid use of ,string struct tag, trying to unmarshal "x" into string`}, {`{"result":"x"}`, `json: invalid use of ,string struct tag, trying to unmarshal "x" into string`},
{`{"result":"foo"}`, `json: invalid use of ,string struct tag, trying to unmarshal "foo" into string`}, {`{"result":"foo"}`, `json: invalid use of ,string struct tag, trying to unmarshal "foo" into string`},
{`{"result":"123"}`, `json: invalid use of ,string struct tag, trying to unmarshal "123" into string`}, {`{"result":"123"}`, `json: invalid use of ,string struct tag, trying to unmarshal "123" into string`},
{`{"result":123}`, `json: invalid use of ,string struct tag, trying to unmarshal unquoted value into string`},
} }
// If people misuse the ,string modifier, the error message should be // If people misuse the ,string modifier, the error message should be
...@@ -1085,7 +1086,7 @@ func TestNullString(t *testing.T) { ...@@ -1085,7 +1086,7 @@ func TestNullString(t *testing.T) {
*s.C = 2 *s.C = 2
err := Unmarshal(data, &s) err := Unmarshal(data, &s)
if err != nil { if err != nil {
t.Fatalf("Unmarshal: %v") t.Fatalf("Unmarshal: %v", err)
} }
if s.B != 1 || s.C != nil { if s.B != 1 || s.C != nil {
t.Fatalf("after Unmarshal, s.B=%d, s.C=%p, want 1, nil", s.B, s.C) t.Fatalf("after Unmarshal, s.B=%d, s.C=%p, want 1, nil", s.B, s.C)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment