-
Notifications
You must be signed in to change notification settings - Fork 22
/
Copy pathtest_linkedlist.py
95 lines (80 loc) · 2.56 KB
/
test_linkedlist.py
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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
#!python
from linkedlist import LinkedList, Node
import unittest
class NodeTest(unittest.TestCase):
def test_init(self):
data = 'ABC'
node = Node(data)
assert node.data is data
assert node.next is None
class LinkedListTest(unittest.TestCase):
def test_init(self):
ll = LinkedList()
assert ll.head is None
assert ll.tail is None
assert ll.as_list() == []
assert ll.is_empty() is True
def test_init_with_list(self):
ll = LinkedList(['A', 'B', 'C'])
assert ll.head.data == 'A'
assert ll.tail.data == 'C'
assert ll.as_list() == ['A', 'B', 'C']
assert ll.is_empty() is False
def test_length(self):
ll = LinkedList()
assert ll.length() == 0
ll.append('A')
assert ll.length() == 1
ll.append('B')
assert ll.length() == 2
ll.append('C')
assert ll.length() == 3
def test_append(self):
ll = LinkedList()
ll.append('A')
assert ll.head.data == 'A'
assert ll.tail.data == 'A'
assert ll.as_list() == ['A']
ll.append('B')
assert ll.head.data == 'A'
assert ll.tail.data == 'B'
assert ll.as_list() == ['A', 'B']
ll.append('C')
assert ll.head.data == 'A'
assert ll.tail.data == 'C'
assert ll.as_list() == ['A', 'B', 'C']
def test_prepend(self):
ll = LinkedList()
ll.prepend('C')
assert ll.head.data == 'C'
assert ll.tail.data == 'C'
assert ll.as_list() == ['C']
ll.prepend('B')
assert ll.head.data == 'B'
assert ll.tail.data == 'C'
assert ll.as_list() == ['B', 'C']
ll.prepend('A')
assert ll.head.data == 'A'
assert ll.tail.data == 'C'
assert ll.as_list() == ['A', 'B', 'C']
def test_delete(self):
ll = LinkedList(['A', 'B', 'C'])
ll.delete('A')
assert ll.head.data == 'B'
assert ll.tail.data == 'C'
ll.delete('C')
assert ll.head.data == 'B'
assert ll.tail.data == 'B'
ll.delete('B')
assert ll.head is None
assert ll.tail is None
with self.assertRaises(ValueError):
ll.delete('D')
def test_find(self):
ll = LinkedList(['A', 'B', 'C'])
assert ll.find(lambda item: item == 'B') == 'B'
assert ll.find(lambda item: item < 'B') == 'A'
assert ll.find(lambda item: item > 'B') == 'C'
assert ll.find(lambda item: item == 'D') is None
if __name__ == '__main__':
unittest.main()