-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathtest_qless.py
More file actions
80 lines (62 loc) · 2.31 KB
/
test_qless.py
File metadata and controls
80 lines (62 loc) · 2.31 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
import sys,time,subprocess
import logging
import qless
import utils
logger = logging.getLogger(__name__)
if hasattr(qless,'client'):
# Pre V0.10 used client
qless_client = qless.client
elif hasattr(qless,'Client'):
# V0.10 change to Client
qless_client = qless.Client
class QlessTester(utils.QueueTester):
server_process = None
def start_server(self):
self.server_process = subprocess.Popen([
'./servers/redis-server',
'--save','',
'--loglevel','warning',
])
timeout = time.time() + 10
while time.time() < timeout:
try:
qless_cx = qless_client(url='redis://localhost')
qless_cx.queues.counts
return
except Exception as error:
logger.warn("Error connecting to redis: %s", error)
time.sleep(1)
self.server_process.kill()
raise OSError("Redis not answering after 10 seconds")
def stop_server(self):
if not self.server_process: return
self.server_process.terminate()
status = self.server_process.wait()
if status != -15:
logger.warn("redis exited with %d", status)
def connect(self,queues_to_watch=None):
self.qless_cx = qless_client(url='redis://localhost')
self.qless_queues_to_watch = queues_to_watch
self.qless_queues = dict([ (_,self.qless_cx.queues[_]) for _ in queues_to_watch ])
def send(self, queue, message):
input_queue = self.qless_cx.queues[queue]
input_queue.put('test.Stuff', dict(msg=message))
class Job(object):
def __init__(self, job):
self.job = job
@property
def queue(self): return self.job.queue_name
@property
def body(self): return self.job.data['msg']
def done(self): self.job.complete()
# It turns out that calling redis once to create a new job and another to finish the first job
# is about the same speed as moving a job from Q1 to Q2.
def move(self, queue): self.job.complete(queue)
def recv(self, timeout=0):
for queue_name,queue in self.qless_queues.items():
job = queue.pop()
if job:
return self.Job(job)
return None
if __name__ == '__main__':
QlessTester.main()