forked from tailscale/hujson
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfind_test.go
60 lines (55 loc) · 1.42 KB
/
find_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
// Copyright (c) 2021 Tailscale Inc & AUTHORS All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package hujson
import (
"testing"
"github.com/google/go-cmp/cmp"
)
func TestFind(t *testing.T) {
// Test case comes from RFC 6901, section 5.
v, err := Parse([]byte(`
{
"foo": ["bar", "baz"],
"": 0,
"a/b": 1,
"c%d": 2,
"e^f": 3,
"g|h": 4,
"i\\j": 5,
"k\"l": 6,
" ": 7,
"m~n": 8
}`))
v.Minimize()
if err != nil {
t.Fatalf("Parse error: %v", err)
}
tests := []struct {
ptr string
want *Value
}{
{"", &v},
{"/foo", &v.Value.(*Object).Members[0].Value},
{"/foo/0", &v.Value.(*Object).Members[0].Value.Value.(*Array).Elements[0]},
{"/", &v.Value.(*Object).Members[1+0].Value},
{"/a~1b", &v.Value.(*Object).Members[1+1].Value},
{"/c%d", &v.Value.(*Object).Members[1+2].Value},
{"/e^f", &v.Value.(*Object).Members[1+3].Value},
{"/g|h", &v.Value.(*Object).Members[1+4].Value},
{"/i\\j", &v.Value.(*Object).Members[1+5].Value},
{"/k\"l", &v.Value.(*Object).Members[1+6].Value},
{"/ ", &v.Value.(*Object).Members[1+7].Value},
{"/m~0n", &v.Value.(*Object).Members[1+8].Value},
{"foo", nil},
{"/foo ", nil},
{"/foo/00", nil},
{"/////", nil},
}
for _, tt := range tests {
got := v.Find(tt.ptr)
if diff := cmp.Diff(tt.want, got); diff != "" {
t.Errorf("Find(%q) mismatch (-want +got):\n%s", tt.ptr, diff)
}
}
}