-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathtests.py
More file actions
executable file
·100 lines (83 loc) · 2.82 KB
/
tests.py
File metadata and controls
executable file
·100 lines (83 loc) · 2.82 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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
#!/usr/bin/env python
"""
multiqueue.tests
~~~~~~~~~~~~~~~~~~~~
:copyright: (c) 2012 by Leonardo Diez.
:license: BSD, see LICENSE for more details.
"""
from multiqueue import MultiQueue, InvalidQueue
import Queue, time
import unittest
class TestMultiQueue(unittest.TestCase):
def setUp(self):
pass
def test_normal(self):
q = MultiQueue()
q.put((1,2))
self.assertEqual(q.get(),(1,2))
q.put((2,4))
self.assertEqual(q.get(),(2,4))
q.put((1,1))
self.assertEqual(q.get(),(1,1))
def test_noresize(self):
q = MultiQueue(num_queues=5)
self.assertRaises(InvalidQueue, q.put, (6, 1))
def test_order(self):
q = MultiQueue(weights=[1,5,3])
for i in xrange(10):
q.put((0,i))
for i in xrange(10):
q.put((1,i))
for i in xrange(10):
q.put((2,i))
# check first in, first out
self.assertEqual(q.get(),(0,0))
self.assertEqual(q.get(),(1,0))
self.assertEqual(q.get(),(2,0))
# now weights start to affect results
self.assertEqual(q.get(),(1,1))
self.assertEqual(q.get(),(1,2))
self.assertEqual(q.get(),(1,3))
self.assertEqual(q.get(),(2,1))
self.assertEqual(q.get(),(1,4))
self.assertEqual(q.get(),(0,1))
self.assertEqual(q.get(),(1,5))
self.assertEqual(q.get(),(1,6))
self.assertEqual(q.get(),(2,2))
self.assertEqual(q.get(),(1,7))
self.assertEqual(q.get(),(1,8))
self.assertEqual(q.get(),(1,9))
# no more items from queue 1
self.assertEqual(q.get(),(2,3))
self.assertEqual(q.get(),(0,2))
self.assertEqual(q.get(),(2,4))
self.assertEqual(q.get(),(0,3))
self.assertEqual(q.get(),(2,5))
self.assertEqual(q.get(),(2,6))
self.assertEqual(q.get(),(0,4))
self.assertEqual(q.get(),(2,7))
self.assertEqual(q.get(),(2,8))
self.assertEqual(q.get(),(0,5))
self.assertEqual(q.get(),(2,9))
# no more items from queue 2
self.assertEqual(q.get(),(0,6))
self.assertEqual(q.get(),(0,7))
self.assertEqual(q.get(),(0,8))
self.assertEqual(q.get(),(0,9))
def test_auto_recycle(self):
# very small value for auto_recycle, don't do this in real code
q = MultiQueue(weights=[1,10], auto_recycle=100)
# fill queues with some data
q.put((0,1))
q.put((1,1))
# forces cycle to grow over auto_recycle value
for i in xrange(20):
q.put((0,1))
q.put((1,1))
q.get()
q.get()
# extract rest of items
while not q.empty():
q.get()
if __name__ == '__main__':
unittest.main()