yq/pkg/yqlib/operator_recursive_descent_test.go

101 lines
2.5 KiB
Go
Raw Normal View History

2020-11-03 23:48:43 +00:00
package yqlib
2020-10-18 00:31:36 +00:00
import (
"testing"
)
var recursiveDescentOperatorScenarios = []expressionScenario{
{
2020-11-14 23:58:47 +00:00
skipDoc: true,
2020-10-18 00:31:36 +00:00
document: `cat`,
expression: `..`,
expected: []string{
"D0, P[], (!!str)::cat\n",
},
2020-10-27 05:45:16 +00:00
},
{
2020-11-14 23:58:47 +00:00
skipDoc: true,
2020-10-18 00:31:36 +00:00
document: `{a: frog}`,
expression: `..`,
expected: []string{
"D0, P[], (!!map)::{a: frog}\n",
"D0, P[a], (!!str)::frog\n",
},
2020-10-27 05:45:16 +00:00
},
{
2020-11-14 23:58:47 +00:00
description: "Map",
document: `{a: {b: apple}}`,
expression: `..`,
2020-10-18 00:31:36 +00:00
expected: []string{
"D0, P[], (!!map)::{a: {b: apple}}\n",
"D0, P[a], (!!map)::{b: apple}\n",
"D0, P[a b], (!!str)::apple\n",
},
2020-10-27 05:45:16 +00:00
},
{
2020-11-14 23:58:47 +00:00
description: "Array",
document: `[1,2,3]`,
expression: `..`,
2020-10-18 00:31:36 +00:00
expected: []string{
"D0, P[], (!!seq)::[1, 2, 3]\n",
"D0, P[0], (!!int)::1\n",
"D0, P[1], (!!int)::2\n",
"D0, P[2], (!!int)::3\n",
},
2020-10-27 05:45:16 +00:00
},
{
2020-11-14 23:58:47 +00:00
description: "Array of maps",
document: `[{a: cat},2,true]`,
expression: `..`,
2020-10-18 00:31:36 +00:00
expected: []string{
"D0, P[], (!!seq)::[{a: cat}, 2, true]\n",
"D0, P[0], (!!map)::{a: cat}\n",
"D0, P[0 a], (!!str)::cat\n",
"D0, P[1], (!!int)::2\n",
"D0, P[2], (!!bool)::true\n",
},
},
2020-10-29 23:56:45 +00:00
{
2020-11-14 23:58:47 +00:00
description: "Aliases are not traversed",
document: `{a: &cat {c: frog}, b: *cat}`,
expression: `..`,
2020-10-29 23:56:45 +00:00
expected: []string{
"D0, P[], (!!map)::{a: &cat {c: frog}, b: *cat}\n",
"D0, P[a], (!!map)::&cat {c: frog}\n",
"D0, P[a c], (!!str)::frog\n",
"D0, P[b], (alias)::*cat\n",
},
},
2020-10-30 01:40:44 +00:00
{
2020-11-14 23:58:47 +00:00
description: "Merge docs are not traversed",
document: mergeDocSample,
expression: `.foobar | ..`,
2020-10-30 01:40:44 +00:00
expected: []string{
"D0, P[foobar], (!!map)::c: foobar_c\n!!merge <<: *foo\nthing: foobar_thing\n",
"D0, P[foobar c], (!!str)::foobar_c\n",
"D0, P[foobar <<], (alias)::*foo\n",
"D0, P[foobar thing], (!!str)::foobar_thing\n",
},
},
{
2020-11-14 23:58:47 +00:00
skipDoc: true,
2020-10-30 01:40:44 +00:00
document: mergeDocSample,
expression: `.foobarList | ..`,
expected: []string{
"D0, P[foobarList], (!!map)::b: foobarList_b\n!!merge <<: [*foo, *bar]\nc: foobarList_c\n",
"D0, P[foobarList b], (!!str)::foobarList_b\n",
"D0, P[foobarList <<], (!!seq)::[*foo, *bar]\n",
"D0, P[foobarList << 0], (alias)::*foo\n",
"D0, P[foobarList << 1], (alias)::*bar\n",
"D0, P[foobarList c], (!!str)::foobarList_c\n",
},
},
2020-10-18 00:31:36 +00:00
}
func TestRecursiveDescentOperatorScenarios(t *testing.T) {
for _, tt := range recursiveDescentOperatorScenarios {
testScenario(t, &tt)
}
2020-11-14 23:58:47 +00:00
documentScenarios(t, "Recursive Descent Operator", recursiveDescentOperatorScenarios)
2020-10-18 00:31:36 +00:00
}