Commit 6f2a8810 authored by David Symonds's avatar David Symonds

expvar: Ensure strings are written as valid JSON.

Change-Id: I5147dbf4e85cf42cd1f32c57861e4c16d9dbd049
Reviewed-on: https://go-review.googlesource.com/21529Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
Reviewed-by: default avatarAndrew Gerrand <adg@golang.org>
parent 870d997a
...@@ -219,8 +219,10 @@ type String struct { ...@@ -219,8 +219,10 @@ type String struct {
func (v *String) String() string { func (v *String) String() string {
v.mu.RLock() v.mu.RLock()
defer v.mu.RUnlock() s := v.s
return strconv.Quote(v.s) v.mu.RUnlock()
b, _ := json.Marshal(s)
return string(b)
} }
func (v *String) Set(value string) { func (v *String) Set(value string) {
......
...@@ -142,8 +142,14 @@ func TestString(t *testing.T) { ...@@ -142,8 +142,14 @@ func TestString(t *testing.T) {
t.Errorf("name.s = %q, want \"Mike\"", name.s) t.Errorf("name.s = %q, want \"Mike\"", name.s)
} }
if s := name.String(); s != "\"Mike\"" { if s, want := name.String(), `"Mike"`; s != want {
t.Errorf("reqs.String() = %q, want \"\"Mike\"\"", s) t.Errorf("from %q, name.String() = %q, want %q", name.s, s, want)
}
// Make sure we produce safe JSON output.
name.Set(`<`)
if s, want := name.String(), "\"\\u003c\""; s != want {
t.Errorf("from %q, name.String() = %q, want %q", name.s, s, want)
} }
} }
......
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