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
|
from logilab.common.testlib import TestCase, unittest_main
from logilab.common.tasksqueue import *
class TaskTC(TestCase):
def test_eq(self):
self.failIf(Task('t1') == Task('t2'))
self.failUnless(Task('t1') == Task('t1'))
def test_cmp(self):
self.failUnless(Task('t1', LOW) < Task('t2', MEDIUM))
self.failIf(Task('t1', LOW) > Task('t2', MEDIUM))
self.failUnless(Task('t1', HIGH) > Task('t2', MEDIUM))
self.failIf(Task('t1', HIGH) < Task('t2', MEDIUM))
class PrioritizedTasksQueueTC(TestCase):
def test_priority(self):
queue = PrioritizedTasksQueue()
queue.put(Task('t1'))
queue.put(Task('t2', MEDIUM))
queue.put(Task('t3', HIGH))
queue.put(Task('t4', LOW))
self.assertEquals(queue.get().id, 't3')
self.assertEquals(queue.get().id, 't2')
self.assertEquals(queue.get().id, 't1')
self.assertEquals(queue.get().id, 't4')
def test_remove_equivalent(self):
queue = PrioritizedTasksQueue()
queue.put(Task('t1'))
queue.put(Task('t2', MEDIUM))
queue.put(Task('t1', HIGH))
queue.put(Task('t3', MEDIUM))
queue.put(Task('t2', MEDIUM))
self.assertEquals(queue.qsize(), 3)
self.assertEquals(queue.get().id, 't1')
self.assertEquals(queue.get().id, 't2')
self.assertEquals(queue.get().id, 't3')
self.assertEquals(queue.qsize(), 0)
def test_remove(self):
queue = PrioritizedTasksQueue()
queue.put(Task('t1'))
queue.put(Task('t2'))
queue.put(Task('t3'))
queue.remove('t2')
self.assertEquals([t.id for t in queue], ['t3', 't1'])
self.assertRaises(ValueError, queue.remove, 't4')
if __name__ == '__main__':
unittest_main()
|