-
Notifications
You must be signed in to change notification settings - Fork 3
Expand file tree
/
Copy pathhashing_tests.py
More file actions
72 lines (60 loc) · 2.03 KB
/
hashing_tests.py
File metadata and controls
72 lines (60 loc) · 2.03 KB
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
67
68
69
70
71
72
import unittest
from dalpy.hashing import HashTable
class HashTableSet(unittest.TestCase):
def test_empty(self):
t = HashTable()
self.assertFalse(t.contains_key('a'))
self.assertRaises(KeyError, lambda: t.get_value('a'))
self.assertRaises(KeyError, lambda: t.delete('a'))
self.assertTrue(t.keys().is_empty())
def test_insert(self):
t = HashTable()
t.insert('a', 1)
self.assertEqual(1, t.get_value('a'))
def test_contains(self):
t = HashTable()
t.insert('a', 1)
self.assertTrue(t.contains_key('a'))
def test_many_insert(self):
t = HashTable()
keys = ['a', 'b', 'c']
for i, k in enumerate(keys):
t.insert(k, i + 1)
for i, k in enumerate(keys):
self.assertTrue(t.contains_key(k))
self.assertEqual(i + 1, t.get_value(k))
def test_delete(self):
t = HashTable()
t.insert('a', 1)
self.assertEqual(1, t.delete('a'))
self.assertRaises(KeyError, lambda: t.delete('a'))
def test_many_delete(self):
t = HashTable()
keys = ['a', 'b', 'c']
for i, k in enumerate(keys):
t.insert(k, i + 1)
for i, k in enumerate(keys):
self.assertEqual(i + 1, t.delete(k))
self.assertFalse(t.contains_key(k))
def test_duplicates(self):
t = HashTable()
t.insert('a', 1)
t.insert('a', 2)
self.assertEqual(2, t.get_value('a'))
self.assertEqual(2, t.delete('a'))
self.assertRaises(KeyError, lambda: t.delete('a'))
def test_add_none(self):
t = HashTable()
t.insert('a', None)
self.assertTrue(t.contains_key('a'))
self.assertIsNone(t.get_value('a'))
self.assertIsNone(t.delete('a'))
def test_keys(self):
t = HashTable()
t.insert('a', None)
t.insert('b', None)
keys = t.keys()
self.assertTrue('a' in keys)
self.assertTrue('b' in keys)
if __name__ == '__main__':
unittest.main()