import subprocess
import re
import time
import os

from webtester_utils import kill_service_on_port

result_message = kill_service_on_port(3000)
print(result_message)

result_message = kill_service_on_port(3001)
print(result_message)
        
log_file = "webtester/service.log"
log = open(log_file, "w")

cmd = "npm run dev"
cwd = "workspaces_root/model-deepseek-chat_hist-100_iter-200_compress-0.25_preserve-db/000001"

process = subprocess.Popen(
    cmd,
    shell=True,
    cwd=cwd,
    stdout=log,
    stderr=subprocess.STDOUT,
    stdin=subprocess.DEVNULL,
    start_new_session=True
)

def wait_for_url_in_log(timeout=30):
    """Wait for a URL to appear in the service log and extract the port."""
    print("Waiting for URL to appear in log...")
    url_pattern = re.compile(
        r"http://(?:localhost|(?:\d{1,3}\.){3}\d{1,3}):\d+/?"
    )
    deadline = time.time() + timeout
    url = None

    while time.time() < deadline:
        if os.path.exists(log_file):
            with open(log_file, "r", encoding="utf-8", errors="ignore") as f:
                content = f.read()
                print(content)
                match = url_pattern.search(content)
                if match:
                    url = match.group(0)
                    print(f"Found service URL: {url}")
                    # Extract port from URL
                    port_match = re.search(r":(\d+)", url)
                    if port_match:
                        detected_port = port_match.group(1)
                        print(f"Detected port: {detected_port}")
                    return url
        time.sleep(1)

    raise TimeoutError("Timed out waiting for service URL in log.")

url = wait_for_url_in_log()
print(f"Service is running at: {url}")