Add new UTs
continuous-integration/drone/push Build is failing
Details
continuous-integration/drone/push Build is failing
Details
parent
4e7267762d
commit
2c038f5a7a
|
@ -10,6 +10,7 @@ func TestDecomposeTree(t *testing.T) {
|
||||||
smallTree := getSmallTree()
|
smallTree := getSmallTree()
|
||||||
singleNodeTree := getSingleNodeTree()
|
singleNodeTree := getSingleNodeTree()
|
||||||
deepTree := getDeepTree()
|
deepTree := getDeepTree()
|
||||||
|
wideTree := getWideTree()
|
||||||
assimmetricTree := getAssimmetricTree()
|
assimmetricTree := getAssimmetricTree()
|
||||||
for name, tt := range map[string]struct {
|
for name, tt := range map[string]struct {
|
||||||
inputTree map[string]*WeightedNode
|
inputTree map[string]*WeightedNode
|
||||||
|
@ -37,6 +38,11 @@ func TestDecomposeTree(t *testing.T) {
|
||||||
inputThreshold: deepTree.Threshold,
|
inputThreshold: deepTree.Threshold,
|
||||||
outputParts: deepTree.Parts,
|
outputParts: deepTree.Parts,
|
||||||
},
|
},
|
||||||
|
"Wide tree": {
|
||||||
|
inputTree: wideTree.TreeWeighted,
|
||||||
|
inputThreshold: wideTree.Threshold,
|
||||||
|
outputParts: wideTree.Parts,
|
||||||
|
},
|
||||||
"Asymmetric tree": {
|
"Asymmetric tree": {
|
||||||
inputTree: assimmetricTree.TreeWeighted,
|
inputTree: assimmetricTree.TreeWeighted,
|
||||||
inputThreshold: assimmetricTree.Threshold,
|
inputThreshold: assimmetricTree.Threshold,
|
||||||
|
|
|
@ -561,7 +561,7 @@ func getDeepTree() testDecomposingData {
|
||||||
Threshold: 200,
|
Threshold: 200,
|
||||||
Parts: []SubTree{
|
Parts: []SubTree{
|
||||||
{
|
{
|
||||||
path: "/folder1/folder2/folder3/folder4/folder5/folder6/folder7/folder8",
|
path: "/folder2/folder3/folder4/folder5/folder6/folder7/folder8",
|
||||||
tree: &Node{
|
tree: &Node{
|
||||||
ID: "1.2.3.4.5.6.7.8.9",
|
ID: "1.2.3.4.5.6.7.8.9",
|
||||||
Name: "folder9",
|
Name: "folder9",
|
||||||
|
@ -581,7 +581,7 @@ func getDeepTree() testDecomposingData {
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
path: "/folder1/folder2/folder3/folder4/folder5",
|
path: "/folder2/folder3/folder4/folder5",
|
||||||
tree: &Node{
|
tree: &Node{
|
||||||
ID: "1.2.3.4.5.6",
|
ID: "1.2.3.4.5.6",
|
||||||
Name: "folder6",
|
Name: "folder6",
|
||||||
|
@ -638,6 +638,174 @@ func getDeepTree() testDecomposingData {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func getWideTree() testDecomposingData {
|
||||||
|
newTree := &Node{
|
||||||
|
ID: "0",
|
||||||
|
Name: "/",
|
||||||
|
Children: []*Node{
|
||||||
|
{
|
||||||
|
ID: "0.1",
|
||||||
|
Name: "folder01",
|
||||||
|
Children: []*Node{
|
||||||
|
{
|
||||||
|
ID: "0.1.1",
|
||||||
|
Name: "folder011",
|
||||||
|
Children: []*Node{
|
||||||
|
{
|
||||||
|
ID: "0.1.1.1",
|
||||||
|
Name: "folder0111",
|
||||||
|
Children: []*Node{},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
ID: "0.1.1.2",
|
||||||
|
Name: "folder0112",
|
||||||
|
Children: []*Node{},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
ID: "0.1.1.3",
|
||||||
|
Name: "folder0113",
|
||||||
|
Children: []*Node{},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
ID: "0.1.1.4",
|
||||||
|
Name: "folder0114",
|
||||||
|
Children: []*Node{},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
ID: "0.1.1.5",
|
||||||
|
Name: "folder0115",
|
||||||
|
Children: []*Node{},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
ID: "0.1.1.6",
|
||||||
|
Name: "folder0116",
|
||||||
|
Children: []*Node{},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
ID: "0.1.1.7",
|
||||||
|
Name: "folder0117",
|
||||||
|
Children: []*Node{},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
ID: "0.1.1.8",
|
||||||
|
Name: "folder0118",
|
||||||
|
Children: []*Node{},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
ID: "0.1.1.9",
|
||||||
|
Name: "folder0119",
|
||||||
|
Children: []*Node{},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
return testDecomposingData{
|
||||||
|
TreeWeighted: newTree.WeightingTreeWithStack(),
|
||||||
|
Threshold: 60,
|
||||||
|
Parts: []SubTree{
|
||||||
|
{
|
||||||
|
path: "/folder01/folder011",
|
||||||
|
tree: &Node{
|
||||||
|
ID: "0.1.1.1",
|
||||||
|
Name: "folder0111",
|
||||||
|
Children: []*Node{},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: "/folder01/folder011",
|
||||||
|
tree: &Node{
|
||||||
|
ID: "0.1.1.2",
|
||||||
|
Name: "folder0112",
|
||||||
|
Children: []*Node{},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: "/folder01/folder011",
|
||||||
|
tree: &Node{
|
||||||
|
ID: "0.1.1.3",
|
||||||
|
Name: "folder0113",
|
||||||
|
Children: []*Node{},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: "/folder01/folder011",
|
||||||
|
tree: &Node{
|
||||||
|
ID: "0.1.1.4",
|
||||||
|
Name: "folder0114",
|
||||||
|
Children: []*Node{},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: "/folder01/folder011",
|
||||||
|
tree: &Node{
|
||||||
|
ID: "0.1.1.5",
|
||||||
|
Name: "folder0115",
|
||||||
|
Children: []*Node{},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: "/folder01/folder011",
|
||||||
|
tree: &Node{
|
||||||
|
ID: "0.1.1.6",
|
||||||
|
Name: "folder0116",
|
||||||
|
Children: []*Node{},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: "/folder01/folder011",
|
||||||
|
tree: &Node{
|
||||||
|
ID: "0.1.1.7",
|
||||||
|
Name: "folder0117",
|
||||||
|
Children: []*Node{},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: "/folder01/folder011",
|
||||||
|
tree: &Node{
|
||||||
|
ID: "0.1.1.8",
|
||||||
|
Name: "folder0118",
|
||||||
|
Children: []*Node{},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: "/folder01/folder011",
|
||||||
|
tree: &Node{
|
||||||
|
ID: "0.1.1.9",
|
||||||
|
Name: "folder0119",
|
||||||
|
Children: []*Node{},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: "/folder01",
|
||||||
|
tree: &Node{
|
||||||
|
ID: "0.1.1",
|
||||||
|
Name: "folder011",
|
||||||
|
Children: []*Node{},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: "/",
|
||||||
|
tree: &Node{
|
||||||
|
ID: "0.1",
|
||||||
|
Name: "folder01",
|
||||||
|
Children: []*Node{},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: "/",
|
||||||
|
tree: &Node{
|
||||||
|
ID: "0",
|
||||||
|
Name: "/",
|
||||||
|
Children: []*Node{},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func getAssimmetricTree() testDecomposingData {
|
func getAssimmetricTree() testDecomposingData {
|
||||||
newTree := &Node{
|
newTree := &Node{
|
||||||
ID: "1.0.0.0",
|
ID: "1.0.0.0",
|
||||||
|
@ -659,8 +827,59 @@ func getAssimmetricTree() testDecomposingData {
|
||||||
{
|
{
|
||||||
ID: "1.1.1.2",
|
ID: "1.1.1.2",
|
||||||
Name: "folder2",
|
Name: "folder2",
|
||||||
|
Children: []*Node{
|
||||||
|
{
|
||||||
|
ID: "1.1.1.1.1",
|
||||||
|
Name: "folder1.1.1.1.1",
|
||||||
|
Children: []*Node{
|
||||||
|
{
|
||||||
|
ID: "1.1.1.1.1.1",
|
||||||
|
Name: "folder1.1.1.1.1.1",
|
||||||
Children: []*Node{},
|
Children: []*Node{},
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
ID: "1.1.1.1.1.2",
|
||||||
|
Name: "folder1.1.1.1.1.2",
|
||||||
|
Children: []*Node{
|
||||||
|
{
|
||||||
|
ID: "1.1.1.1.1.2.1",
|
||||||
|
Name: "folder1.1.1.1.1.2.1",
|
||||||
|
Children: []*Node{},
|
||||||
|
}, {
|
||||||
|
ID: "1.1.1.1.1.2.2",
|
||||||
|
Name: "folder1.1.1.1.1.2.2",
|
||||||
|
Children: []*Node{},
|
||||||
|
}, {
|
||||||
|
ID: "1.1.1.1.1.2.3",
|
||||||
|
Name: "folder1.1.1.1.1.2.3",
|
||||||
|
Children: []*Node{},
|
||||||
|
}, {
|
||||||
|
ID: "1.1.1.1.1.2.4",
|
||||||
|
Name: "folder1.1.1.1.1.2.4",
|
||||||
|
Children: []*Node{{
|
||||||
|
ID: "1.1.1.1.1.2.4.1",
|
||||||
|
Name: "folder1.1.1.1.1.2.4.1",
|
||||||
|
Children: []*Node{{
|
||||||
|
ID: "1.1.1.1.1.2.4.1.1",
|
||||||
|
Name: "folder1.1.1.1.1.2.4.1.1",
|
||||||
|
Children: []*Node{},
|
||||||
|
}, {
|
||||||
|
ID: "1.1.1.1.1.2.4.1.2",
|
||||||
|
Name: "folder1.1.1.1.1.2.4.1.2",
|
||||||
|
Children: []*Node{},
|
||||||
|
}},
|
||||||
|
}},
|
||||||
|
}, {
|
||||||
|
ID: "1.1.1.1.1.2.5",
|
||||||
|
Name: "folder1.1.1.1.1.2.5",
|
||||||
|
Children: []*Node{},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
{
|
{
|
||||||
ID: "1.1.1.3",
|
ID: "1.1.1.3",
|
||||||
Name: "folder3",
|
Name: "folder3",
|
||||||
|
@ -689,165 +908,6 @@ func getAssimmetricTree() testDecomposingData {
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
{
|
|
||||||
ID: "1.1.3.0",
|
|
||||||
Name: "folder3",
|
|
||||||
Children: []*Node{
|
|
||||||
{
|
|
||||||
ID: "1.1.3.1",
|
|
||||||
Name: "folder1",
|
|
||||||
Children: []*Node{},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
ID: "1.1.3.2",
|
|
||||||
Name: "folder2",
|
|
||||||
Children: []*Node{},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
ID: "1.1.3.3",
|
|
||||||
Name: "folder3",
|
|
||||||
Children: []*Node{},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
ID: "1.2.0.0",
|
|
||||||
Name: "folder2",
|
|
||||||
Children: []*Node{
|
|
||||||
{
|
|
||||||
ID: "1.2.1.0",
|
|
||||||
Name: "folder1",
|
|
||||||
Children: []*Node{
|
|
||||||
{
|
|
||||||
ID: "1.2.1.1",
|
|
||||||
Name: "folder1",
|
|
||||||
Children: []*Node{},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
ID: "1.2.1.2",
|
|
||||||
Name: "folder2",
|
|
||||||
Children: []*Node{},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
ID: "1.2.1.3",
|
|
||||||
Name: "folder3",
|
|
||||||
Children: []*Node{},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
ID: "1.2.2.0",
|
|
||||||
Name: "folder2",
|
|
||||||
Children: []*Node{
|
|
||||||
{
|
|
||||||
ID: "1.2.2.1",
|
|
||||||
Name: "folder1",
|
|
||||||
Children: []*Node{},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
ID: "1.2.2.2",
|
|
||||||
Name: "folder2",
|
|
||||||
Children: []*Node{},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
ID: "1.2.2.3",
|
|
||||||
Name: "folder3",
|
|
||||||
Children: []*Node{},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
ID: "1.2.3.0",
|
|
||||||
Name: "folder3",
|
|
||||||
Children: []*Node{
|
|
||||||
{
|
|
||||||
ID: "1.2.3.1",
|
|
||||||
Name: "folder1",
|
|
||||||
Children: []*Node{},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
ID: "1.2.3.2",
|
|
||||||
Name: "folder2",
|
|
||||||
Children: []*Node{},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
ID: "1.2.3.3",
|
|
||||||
Name: "folder3",
|
|
||||||
Children: []*Node{},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
ID: "1.3.0.0",
|
|
||||||
Name: "folder3",
|
|
||||||
Children: []*Node{
|
|
||||||
{
|
|
||||||
ID: "1.3.1.0",
|
|
||||||
Name: "folder1",
|
|
||||||
Children: []*Node{
|
|
||||||
{
|
|
||||||
ID: "1.3.1.1",
|
|
||||||
Name: "folder1",
|
|
||||||
Children: []*Node{},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
ID: "1.3.1.2",
|
|
||||||
Name: "folder2",
|
|
||||||
Children: []*Node{},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
ID: "1.3.1.3",
|
|
||||||
Name: "folder3",
|
|
||||||
Children: []*Node{},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
ID: "1.3.2.0",
|
|
||||||
Name: "folder2",
|
|
||||||
Children: []*Node{
|
|
||||||
{
|
|
||||||
ID: "1.3.2.1",
|
|
||||||
Name: "folder1",
|
|
||||||
Children: []*Node{},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
ID: "1.3.2.2",
|
|
||||||
Name: "folder2",
|
|
||||||
Children: []*Node{},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
ID: "1.3.2.3",
|
|
||||||
Name: "folder3",
|
|
||||||
Children: []*Node{},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
ID: "1.3.3.0",
|
|
||||||
Name: "folder3",
|
|
||||||
Children: []*Node{
|
|
||||||
{
|
|
||||||
ID: "1.3.3.1",
|
|
||||||
Name: "folder1",
|
|
||||||
Children: []*Node{},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
ID: "1.3.3.2",
|
|
||||||
Name: "folder2",
|
|
||||||
Children: []*Node{},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
ID: "1.3.3.3",
|
|
||||||
Name: "folder3",
|
|
||||||
Children: []*Node{},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
Loading…
Reference in New Issue