2019-11-23 03:52:29 +00:00
|
|
|
package yqlib
|
2015-10-03 05:10:29 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
2019-12-01 20:10:42 +00:00
|
|
|
|
2019-12-09 02:44:53 +00:00
|
|
|
"github.com/mikefarah/yq/v3/test"
|
2015-10-03 05:10:29 +00:00
|
|
|
)
|
|
|
|
|
2020-01-08 21:17:56 +00:00
|
|
|
var parser = NewPathParser()
|
|
|
|
|
2015-10-03 05:10:29 +00:00
|
|
|
var parsePathsTests = []struct {
|
|
|
|
path string
|
|
|
|
expectedPaths []string
|
|
|
|
}{
|
|
|
|
{"a.b", []string{"a", "b"}},
|
2020-01-08 21:17:56 +00:00
|
|
|
{"a.b.**", []string{"a", "b", "**"}},
|
|
|
|
{"a.b.*", []string{"a", "b", "*"}},
|
2015-10-03 05:10:29 +00:00
|
|
|
{"a.b[0]", []string{"a", "b", "0"}},
|
2017-09-24 00:21:16 +00:00
|
|
|
{"a.b.d[+]", []string{"a", "b", "d", "+"}},
|
2019-12-01 19:44:44 +00:00
|
|
|
{"a", []string{"a"}},
|
|
|
|
{"a.b.c", []string{"a", "b", "c"}},
|
|
|
|
{"\"a.b\".c", []string{"a.b", "c"}},
|
|
|
|
{"a.\"b.c\".d", []string{"a", "b.c", "d"}},
|
|
|
|
{"[1].a.d", []string{"1", "a", "d"}},
|
|
|
|
{"a[0].c", []string{"a", "0", "c"}},
|
|
|
|
{"[0]", []string{"0"}},
|
2015-10-03 05:10:29 +00:00
|
|
|
}
|
|
|
|
|
2020-01-08 21:17:56 +00:00
|
|
|
func TestPathParserParsePath(t *testing.T) {
|
2015-10-03 05:10:29 +00:00
|
|
|
for _, tt := range parsePathsTests {
|
2020-01-08 21:17:56 +00:00
|
|
|
test.AssertResultComplex(t, tt.expectedPaths, parser.ParsePath(tt.path))
|
2015-10-03 05:10:29 +00:00
|
|
|
}
|
2019-12-01 20:10:42 +00:00
|
|
|
}
|
2020-01-08 21:17:56 +00:00
|
|
|
|
|
|
|
func TestPathParserMatchesNextPathElementSplat(t *testing.T) {
|
|
|
|
var node = NodeContext{Head: "*"}
|
|
|
|
test.AssertResult(t, true, parser.MatchesNextPathElement(node, ""))
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestPathParserMatchesNextPathElementDeepSplat(t *testing.T) {
|
|
|
|
var node = NodeContext{Head: "**"}
|
|
|
|
test.AssertResult(t, true, parser.MatchesNextPathElement(node, ""))
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestPathParserMatchesNextPathElementAppendArrayValid(t *testing.T) {
|
|
|
|
var node = NodeContext{Head: "+"}
|
|
|
|
test.AssertResult(t, true, parser.MatchesNextPathElement(node, "3"))
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestPathParserMatchesNextPathElementAppendArrayInvalid(t *testing.T) {
|
|
|
|
var node = NodeContext{Head: "+"}
|
|
|
|
test.AssertResult(t, false, parser.MatchesNextPathElement(node, "cat"))
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestPathParserMatchesNextPathElementPrefixMatchesWhole(t *testing.T) {
|
|
|
|
var node = NodeContext{Head: "cat*"}
|
|
|
|
test.AssertResult(t, true, parser.MatchesNextPathElement(node, "cat"))
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestPathParserMatchesNextPathElementPrefixMatchesStart(t *testing.T) {
|
|
|
|
var node = NodeContext{Head: "cat*"}
|
|
|
|
test.AssertResult(t, true, parser.MatchesNextPathElement(node, "caterpillar"))
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestPathParserMatchesNextPathElementPrefixMismatch(t *testing.T) {
|
|
|
|
var node = NodeContext{Head: "cat*"}
|
|
|
|
test.AssertResult(t, false, parser.MatchesNextPathElement(node, "dog"))
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestPathParserMatchesNextPathElementExactMatch(t *testing.T) {
|
|
|
|
var node = NodeContext{Head: "farahtek"}
|
|
|
|
test.AssertResult(t, true, parser.MatchesNextPathElement(node, "farahtek"))
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestPathParserMatchesNextPathElementExactMismatch(t *testing.T) {
|
|
|
|
var node = NodeContext{Head: "farahtek"}
|
|
|
|
test.AssertResult(t, false, parser.MatchesNextPathElement(node, "othertek"))
|
|
|
|
}
|