-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathil_test.go
66 lines (52 loc) · 1.17 KB
/
il_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
package il
import "testing"
func TestILEqual(t *testing.T) {
if !NewILBlock(ILList).Equal(NewILBlock(ILList)) {
t.Error("Failed equate two blank ILLists")
}
chainAdd := func(b *ILBlock) {
b1 := NewILBlock(ILList)
b2 := NewILBlock(ILList)
b3 := NewILBlock(ILList)
add1 := NewILBlock(ILDataAdd)
add2 := NewILBlock(ILDataAdd)
add3 := NewILBlock(ILDataAdd)
add4 := NewILBlock(ILDataAdd)
add5 := NewILBlock(ILDataAdd)
add2.param = 1
add3.param = 2
add4.param = 100
add5.param = 3000
b.Append(b1)
b.Append(b2)
b2.Append(b3)
b.Append(add1)
b1.Append(add2)
b1.Append(add3)
b2.Append(add4)
b3.Append(add5)
}
il1 := NewILBlock(ILList)
il2 := NewILBlock(ILList)
chainAdd(il1)
chainAdd(il1)
chainAdd(il2)
chainAdd(il2)
if !il1.Equal(il2) {
t.Error("Failed equate two multi-level trees")
}
il1 = NewILBlock(ILList)
il2 = NewILBlock(ILList)
chainAdd(il1)
if il1.Equal(il2) {
t.Error("Failed to detect differences between two trees")
}
}
func TestILPrune(t *testing.T) {
il := NewILBlock(ILList)
il.Append(NewILBlock(ILDataAdd))
il.Prune()
if !il.Equal(NewILBlock(ILList)) {
t.Error("Failed to prune a list with one 0 data add")
}
}