test xleaves

selection
Jordan Orelli 5 years ago
parent 31fa2eb711
commit 00ba88a520

@ -25,15 +25,14 @@ func (test *selectionTest) Run(t *testing.T) {
} }
XWanted.report(t) XWanted.report(t)
// XLeavesWanted := wantStrings("leaf xnode labels", test.xleaves...) XLeavesWanted := wantStrings("leaf xnode labels", test.xleaves...)
// for _, X := range test.selection.xnodes() { for _, X := range test.selection.xnodes() {
// leaves := X.leaves() leaves := X.leaves()
// for _, leaf := range leaves { for _, leaf := range leaves {
// XLeavesWanted. XLeavesWanted.add(leaf.label())
}
// } }
XLeavesWanted.report(t)
// }
} }
func TestSelections(t *testing.T) { func TestSelections(t *testing.T) {
@ -43,18 +42,21 @@ func TestSelections(t *testing.T) {
selection: NewSelection(A), selection: NewSelection(A),
lnodes: []string{"A"}, lnodes: []string{"A"},
xnodes: []string{"A.0"}, xnodes: []string{"A.0"},
xleaves: []string{"A.0"},
}, },
{ {
label: "root with one child", label: "root with one child",
selection: NewSelection(A).Child(B), selection: NewSelection(A).Child(B),
lnodes: []string{"B"}, lnodes: []string{"B"},
xnodes: []string{"B.0.A"}, xnodes: []string{"B.0.A"},
xleaves: []string{"B.0.A"},
}, },
{ {
label: "two selected roots", label: "two selected roots",
selection: NewSelection(A).And(NewSelection(B)), selection: NewSelection(A).And(NewSelection(B)),
lnodes: []string{"A", "B"}, lnodes: []string{"A", "B"},
xnodes: []string{"A.0", "B.0"}, xnodes: []string{"A.0", "B.0"},
xleaves: []string{"A.0", "B.0"},
}, },
} }
@ -68,6 +70,7 @@ func TestSelections(t *testing.T) {
selection: root.And(b), selection: root.And(b),
lnodes: []string{"A", "B"}, lnodes: []string{"A", "B"},
xnodes: []string{"A.0", "B.0.A"}, xnodes: []string{"A.0", "B.0.A"},
xleaves: []string{"B.0.A"},
} }
}) })
@ -79,6 +82,7 @@ func TestSelections(t *testing.T) {
selection: root.And(b).Child(C), selection: root.And(b).Child(C),
lnodes: []string{"C"}, lnodes: []string{"C"},
xnodes: []string{"C.0.A", "C.1.B"}, xnodes: []string{"C.0.A", "C.1.B"},
xleaves: []string{"C.0.A", "C.1.B"},
} }
}) })
@ -92,6 +96,7 @@ func TestSelections(t *testing.T) {
selection: b.And(c), selection: b.And(c),
lnodes: []string{"B", "C"}, lnodes: []string{"B", "C"},
xnodes: []string{"B.0.A", "C.0.A"}, xnodes: []string{"B.0.A", "C.0.A"},
xleaves: []string{"B.0.A", "C.0.A"},
} }
}) })
@ -104,6 +109,7 @@ func TestSelections(t *testing.T) {
selection: b.And(c).Child(D), selection: b.And(c).Child(D),
lnodes: []string{"D"}, lnodes: []string{"D"},
xnodes: []string{"D.0.B", "D.1.C"}, xnodes: []string{"D.0.B", "D.1.C"},
xleaves: []string{"D.0.B", "D.1.C"},
} }
}) })
@ -117,6 +123,7 @@ func TestSelections(t *testing.T) {
selection: d.Child(E), selection: d.Child(E),
lnodes: []string{"E"}, lnodes: []string{"E"},
xnodes: []string{"E.0.D", "E.1.D"}, xnodes: []string{"E.0.D", "E.1.D"},
xleaves: []string{"E.0.D", "E.1.D"},
} }
}) })
@ -131,6 +138,53 @@ func TestSelections(t *testing.T) {
selection: root, selection: root,
lnodes: []string{"A"}, lnodes: []string{"A"},
xnodes: []string{"A.0"}, xnodes: []string{"A.0"},
xleaves: []string{"E.0.D", "E.1.D"},
}
})
// A
// / \
// / \
// B C
// / \ / \
// / \ / \
// D E F
// / \ / \
// / \ / \
// G H I
// | | |
// | | |
// J K L
// | \ /
// | \ /
// M N
//
add(func() selectionTest {
root := NewSelection(A)
b := root.Child(B)
c := root.Child(C)
b.Child(D)
e := b.And(c).Child(E)
f := c.Child(F)
e.Child(G).Child(J).Child(M)
h := e.And(f).Child(H)
l := f.Child(I).Child(L)
k := h.Child(K)
k.And(l).Child(N)
return selectionTest{
label: "criss-crossing",
selection: root,
lnodes: []string{"A"},
xnodes: []string{"A.0"},
xleaves: []string{
"D.0.B", // A B D
"M.0.J", // A B E G J M
"M.1.J", // A C E G J M
"N.0.K", // A B E H K N
"N.1.K", // A C E H K N
"N.2.K", // A C F H K N
"N.3.L", // A C F I L N
},
} }
}) })

Loading…
Cancel
Save