forked from zulip/zulip
-
Notifications
You must be signed in to change notification settings - Fork 0
/
test-run-dev
executable file
·60 lines (50 loc) · 1.66 KB
/
test-run-dev
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
#!/usr/bin/env python3
import itertools
import os
import signal
import subprocess
import sys
import types
from typing import Tuple
from lib import sanity_check
sanity_check.check_venv(__file__)
TOOLS_DIR = os.path.dirname(os.path.abspath(__file__))
def start_server(run_dev: subprocess.Popen) -> Tuple[bool, str]:
failure = False
i = 0
def on_timer(signum: int, frame: types.FrameType) -> None:
nonlocal failure, i
print("{}. Polling run-dev...".format(i))
i += 1
if i == 200:
failure = True
run_dev.send_signal(signal.SIGINT)
signal.setitimer(signal.ITIMER_REAL, 0, 0)
key = "Quit the server with CTRL-C.\n"
old_handler = signal.signal(signal.SIGALRM, on_timer)
signal.setitimer(signal.ITIMER_REAL, 0.5, 0.5)
log1, log2 = itertools.tee(run_dev.stdout)
if key not in log1:
failure = True
elif not failure:
run_dev.send_signal(signal.SIGINT)
signal.setitimer(signal.ITIMER_REAL, 0, 0)
signal.signal(signal.SIGALRM, old_handler)
return failure, ''.join(log2)
if __name__ == '__main__':
print("Testing development server start!")
with subprocess.Popen(
[os.path.join(TOOLS_DIR, "run-dev.py")],
bufsize=1, # line buffered
stdout=subprocess.PIPE, stderr=subprocess.STDOUT,
universal_newlines=True) as run_dev:
failure, log = start_server(run_dev)
if 'Traceback' in log:
failure = True
if failure:
print("Development server is not working properly:")
print(log)
sys.exit(1)
else:
print("Development server is working properly.")
sys.exit(0)