zulip/tools/test-run-dev

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.py")], 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)