2021-08-23 01:19:26 +00:00
|
|
|
package bptree
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestAddRemove(t *testing.T) {
|
2021-09-18 08:29:47 +00:00
|
|
|
tree := NewBpTree(5)
|
2021-08-23 01:19:26 +00:00
|
|
|
PersistFn = func(node *BpNode) error {
|
|
|
|
println("saving", node.protoNodeId)
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
DestroyFn = func(node *BpNode) error {
|
|
|
|
println("delete", node.protoNodeId)
|
|
|
|
return nil
|
|
|
|
}
|
2021-09-18 21:04:30 +00:00
|
|
|
for i:=0;i<32;i++{
|
2021-08-23 01:19:26 +00:00
|
|
|
println("++++++++++", i)
|
2021-09-18 21:04:30 +00:00
|
|
|
tree.Add(String(fmt.Sprintf("%02d", i)), nil)
|
2021-08-23 01:19:26 +00:00
|
|
|
printTree(tree.root, "")
|
|
|
|
}
|
2021-09-18 21:04:30 +00:00
|
|
|
|
|
|
|
if !tree.Has(String("30")) {
|
|
|
|
t.Errorf("lookup error")
|
|
|
|
}
|
|
|
|
tree.RemoveWhere(String("30"), func(value ItemValue) bool {
|
|
|
|
return true
|
|
|
|
})
|
|
|
|
if tree.Has(String("30")) {
|
|
|
|
t.Errorf("remove error")
|
|
|
|
}
|
2021-08-23 01:19:26 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func printTree(node *BpNode, prefix string) {
|
|
|
|
fmt.Printf("%sNode %d\n", prefix, node.protoNodeId)
|
2021-09-18 08:29:47 +00:00
|
|
|
prefix += " "
|
2021-08-23 01:19:26 +00:00
|
|
|
for i:=0;i<len(node.keys);i++{
|
2021-09-18 08:29:47 +00:00
|
|
|
fmt.Printf("%skey %v\n", prefix, node.keys[i])
|
2021-08-23 01:19:26 +00:00
|
|
|
if i < len(node.pointers) && node.pointers[i] != nil {
|
2021-09-18 08:29:47 +00:00
|
|
|
printTree(node.pointers[i], prefix+" ")
|
2021-08-23 01:19:26 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|