|
|
package skiplist
import ( "math/rand" "strconv" "testing" )
const ( maxNameCount = 100 )
func String(x int) string { return strconv.Itoa(x) }
func TestNameList(t *testing.T) { list := newNameList(memStore, 7)
for i := 0; i < maxNameCount; i++ { list.WriteName(String(i)) }
counter := 0 list.ListNames("", func(name string) bool { counter++ print(name, " ") return true }) if counter != maxNameCount { t.Fail() }
// list.skipList.println()
deleteBase := 5 deleteCount := maxNameCount - 3*deleteBase
for i := deleteBase; i < deleteBase+deleteCount; i++ { list.DeleteName(String(i)) }
counter = 0 list.ListNames("", func(name string) bool { counter++ return true }) // list.skipList.println()
if counter != maxNameCount-deleteCount { t.Fail() }
// randomized deletion
list = newNameList(memStore, 7) // Delete elements at random positions in the list.
rList := rand.Perm(maxN) for _, i := range rList { list.WriteName(String(i)) } for _, i := range rList { list.DeleteName(String(i)) } counter = 0 list.ListNames("", func(name string) bool { counter++ print(name, " ") return true }) if counter != 0 { t.Fail() }
}
|