nim-presto/tests/testbtrees.nim

64 lines
2.2 KiB
Nim

import std/[random, tables, unittest]
import ../presto/btrees
when defined(nimHasUsed): {.used.}
suite "B-Tree test suite":
test "B-Tree original standard library test":
proc main() =
var st = initBTree[string, string]()
st.add("www.cs.princeton.edu", "abc")
st.add("www.princeton.edu", "128.112.128.15")
st.add("www.yale.edu", "130.132.143.21")
st.add("www.simpsons.com", "209.052.165.60")
st.add("www.apple.com", "17.112.152.32")
st.add("www.amazon.com", "207.171.182.16")
st.add("www.ebay.com", "66.135.192.87")
st.add("www.cnn.com", "64.236.16.20")
st.add("www.google.com", "216.239.41.99")
st.add("www.nytimes.com", "199.239.136.200")
st.add("www.microsoft.com", "207.126.99.140")
st.add("www.dell.com", "143.166.224.230")
st.add("www.slashdot.org", "66.35.250.151")
st.add("www.espn.com", "199.181.135.201")
st.add("www.weather.com", "63.111.66.11")
st.add("www.yahoo.com", "216.109.118.65")
check:
st.getOrDefault("www.cs.princeton.edu") == "abc"
st.getOrDefault("www.harvardsucks.com") == ""
st.getOrDefault("www.simpsons.com") == "209.052.165.60"
st.getOrDefault("www.apple.com") == "17.112.152.32"
st.getOrDefault("www.ebay.com") == "66.135.192.87"
st.getOrDefault("www.dell.com") == "143.166.224.230"
st.entries == 16
when false:
var b2 = initBTree[string, string]()
const iters = 10_000
for i in 1..iters:
b2.add($i, $(iters - i))
for i in 1..iters:
let x = b2.getOrDefault($i)
if x != $(iters - i):
echo "got ", x, ", but expected ", iters - i
echo b2.entries
when true:
var b2 = initBTree[int, string]()
var t2 = initTable[int, string]()
const iters = 100_000
for i in 1..iters:
let x = rand(high(int))
if not t2.hasKey(x):
check b2.getOrDefault(x).len == 0
t2[x] = $x
b2.add(x, $x)
check b2.entries == t2.len
for k, v in t2:
check $k == v
check b2.getOrDefault(k) == $k
main()