summary refs log tree commit diff stats
path: root/tests/compiler/tbrees.nim
diff options
context:
space:
mode:
authorflywind <43030857+xflywind@users.noreply.github.com>2020-11-25 14:48:27 +0800
committerGitHub <noreply@github.com>2020-11-25 07:48:27 +0100
commit57bd64582ceee697dc4f079baf6a4e6137ff45b4 (patch)
tree77adcc362cb3cd2c0939f291bacb999673b8b922 /tests/compiler/tbrees.nim
parentb7809cc9921421ea0e8326a24d66861748e3136b (diff)
downloadNim-57bd64582ceee697dc4f079baf6a4e6137ff45b4.tar.gz
move tests under the compiler directory to testament (#16096)
Diffstat (limited to 'tests/compiler/tbrees.nim')
-rw-r--r--tests/compiler/tbrees.nim84
1 files changed, 84 insertions, 0 deletions
diff --git a/tests/compiler/tbrees.nim b/tests/compiler/tbrees.nim
new file mode 100644
index 000000000..364b51b22
--- /dev/null
+++ b/tests/compiler/tbrees.nim
@@ -0,0 +1,84 @@
+discard """
+  output: '''
+www.amazon.com: 207.171.182.16
+www.apple.com: 17.112.152.32
+www.cnn.com: 64.236.16.20
+www.cs.princeton.edu: abc
+www.dell.com: 143.166.224.230
+www.ebay.com: 66.135.192.87
+www.espn.com: 199.181.135.201
+www.google.com: 216.239.41.99
+www.microsoft.com: 207.126.99.140
+www.nytimes.com: 199.239.136.200
+www.princeton.edu: 128.112.128.15
+www.simpsons.com: 209.052.165.60
+www.slashdot.org: 66.35.250.151
+www.weather.com: 63.111.66.11
+www.yahoo.com: 216.109.118.65
+www.yale.edu: 130.132.143.21
+'''
+"""
+
+import compiler/btrees
+
+import random, tables
+
+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")
+
+  assert st.getOrDefault("www.cs.princeton.edu") == "abc"
+  assert st.getOrDefault("www.harvardsucks.com") == ""
+
+  assert st.getOrDefault("www.simpsons.com") == "209.052.165.60"
+  assert st.getOrDefault("www.apple.com") == "17.112.152.32"
+  assert st.getOrDefault("www.ebay.com") == "66.135.192.87"
+  assert st.getOrDefault("www.dell.com") == "143.166.224.230"
+  assert(st.len == 16)
+
+  for k, v in st:
+    echo k, ": ", v
+
+  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.len
+
+  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):
+        doAssert b2.getOrDefault(x).len == 0, " what, tree has this element " & $x
+        t2[x] = $x
+        b2.add(x, $x)
+
+    doAssert(b2.len == t2.len, "unique entries " & $b2.len)
+    for k, v in t2:
+      doAssert $k == v
+      doAssert b2.getOrDefault(k) == $k
+
+main()