mirror of https://github.com/zulip/zulip.git
60 lines
1.5 KiB
Python
Executable File
60 lines
1.5 KiB
Python
Executable File
#!/usr/bin/env python3
|
|
import os
|
|
import signal
|
|
import subprocess
|
|
import sys
|
|
import tempfile
|
|
import time
|
|
from typing import Tuple
|
|
|
|
sys.path.insert(0, os.path.join(os.path.dirname(__file__), ".."))
|
|
|
|
from tools.lib import sanity_check
|
|
|
|
sanity_check.check_venv(__file__)
|
|
|
|
TOOLS_DIR = os.path.dirname(os.path.abspath(__file__))
|
|
|
|
|
|
def start_server(logfile_name: str) -> Tuple[bool, str]:
|
|
failure = True
|
|
key = "Quit the server with CONTROL-C."
|
|
datalog = []
|
|
with open(logfile_name, "rb", buffering=0) as logfile:
|
|
for i in range(200):
|
|
time.sleep(0.5)
|
|
print(f"{i}. Polling run-dev...")
|
|
new_data = logfile.read().decode()
|
|
if new_data:
|
|
datalog.append(new_data)
|
|
|
|
if key in "".join(datalog):
|
|
failure = False
|
|
break
|
|
|
|
return failure, "".join(datalog)
|
|
|
|
|
|
if __name__ == "__main__":
|
|
print("Testing development server start!")
|
|
|
|
with tempfile.NamedTemporaryFile(buffering=0) as logfile:
|
|
run_dev = subprocess.Popen(
|
|
[os.path.join(TOOLS_DIR, "run-dev")], stdout=logfile, stderr=subprocess.STDOUT
|
|
)
|
|
failure, log = start_server(logfile.name)
|
|
|
|
run_dev.send_signal(signal.SIGINT)
|
|
run_dev.wait()
|
|
|
|
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)
|