forked from jmespath/go-jmespath
-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathapi_test.go
84 lines (73 loc) · 1.91 KB
/
api_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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
package jmespath
import (
"encoding/json"
"strings"
"testing"
"github.com/kyverno/go-jmespath/internal/testify/assert"
)
func TestValidUncompiledExpressionSearches(t *testing.T) {
assert := assert.New(t)
var j = []byte(`{"foo": {"bar": {"baz": [0, 1, 2, 3, 4]}}}`)
var d interface{}
err := json.Unmarshal(j, &d)
assert.Nil(err)
result, err := Search("foo.bar.baz[2]", d)
assert.Nil(err)
assert.Equal(2.0, result)
}
func TestValidPrecompiledExpressionSearches(t *testing.T) {
assert := assert.New(t)
data := make(map[string]interface{})
data["foo"] = "bar"
precompiled, err := Compile("foo")
assert.Nil(err)
result, err := precompiled.Search(data)
assert.Nil(err)
assert.Equal("bar", result)
}
func TestInvalidPrecompileErrors(t *testing.T) {
assert := assert.New(t)
_, err := Compile("not a valid expression")
assert.NotNil(err)
}
func TestInvalidMustCompilePanics(t *testing.T) {
defer func() {
r := recover()
assert.NotNil(t, r)
}()
MustCompile("not a valid expression")
}
func TestCustomFunction(t *testing.T) {
assert := assert.New(t)
data := make(map[string]interface{})
data["foo"] = "BAR"
precompiled, err := Compile("to_lower(foo)")
fCall := NewFunctionCaller()
fCall.Register(FunctionEntry{
Name: "to_lower",
Arguments: []ArgSpec{
{Types: []JpType{JpString}},
},
Handler: func(arguments []interface{}) (interface{}, error) {
s := arguments[0].(string)
return strings.ToLower(s), nil
},
})
assert.Nil(err)
result, err := precompiled.Search(data, WithFunctionCaller(fCall))
assert.Nil(err)
assert.Equal("bar", result)
}
func TestInterpreter(t *testing.T) {
i := NewInterpreter()
var j = []byte(`{"foo": {"bar": {"baz": [0, 1, 2, 3, 4]}}}`)
var d interface{}
err := json.Unmarshal(j, &d)
assert.Nil(t, err)
p := NewParser()
ast, err := p.Parse("foo.bar.baz[2]")
assert.Nil(t, err)
result, err := i.Execute(ast, d)
assert.Nil(t, err)
assert.Equal(t, 2.0, result)
}