#!/usr/bin/env python3
import os
import signal
import subprocess
import sys
import tempfile
import time

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)
