import os
import zipfile
from tqdm import tqdm
import time

import re
from typing import List, Tuple
import json

import subprocess
from pathlib import Path
import sys
from time import sleep
import shutil

# Add the parent directory to sys.path to enable imports
sys.path.append(os.path.dirname(os.path.dirname(os.path.abspath(__file__))))

from start_service import start_services, kill_service_on_port

from sandbox import create_docker_compose_file, start_docker_containers, stop_docker_containers
from utils import DBWatcher, dump_database


def copy_db(orig_db_dir, db_tmp):
    if os.path.exists(db_tmp):
        shutil.rmtree(db_tmp)          # old leftovers
    if os.path.exists(orig_db_dir):
        # Copy as fast as possible: use reflink on capable filesystems,
        # fallback to regular copy otherwise.
        try:
            subprocess.run(
                ["cp", "-a", "--reflink=auto", orig_db_dir, db_tmp],
                check=True
            )
        except subprocess.CalledProcessError:
            shutil.copytree(orig_db_dir, db_tmp)
    else:
        os.makedirs(db_tmp, exist_ok=True)  # empty cluster

logs_root = "logs_root/model-Qwen3-Coder-480B-A35B-Instruct-FP8_hist-100_iter-400_compress-0.5_val-2_sum-5_v5_add-frontend-tool"
workspace_root = "workspaces_root/model-Qwen3-Coder-480B-A35B-Instruct-FP8_hist-100_iter-400_compress-0.5_val-2_sum-5_v5_add-frontend-tool"
app_id = "000002"

app_log_path = os.path.join(logs_root, app_id)
app_workspace_path = os.path.join(workspace_root, app_id)
test_db_dir = os.path.join(app_log_path, "test_db")

orig_db_dir = os.path.join(app_log_path, "db")
db_tmp = os.path.join(app_log_path, "db_tmp")

copy_db(orig_db_dir, db_tmp)

db_watcher = DBWatcher(db_tmp)

db_config = {
    "db_host": "localhost",
    "db_port": 5434,
    "db_username": "myappuser",
    "db_password": "myapppassword",
    "db_name": "myapp"
}

kill_service_on_port(int(db_config["db_port"]))
docker_compose_path = "logs_root/model-Qwen3-Coder-480B-A35B-Instruct-FP8_hist-100_iter-400_compress-0.5_val-2_sum-5_v5_add-frontend-tool/000001/000001_docker/docker-compose.yml"
create_docker_compose_file(
    working_dir=app_workspace_path, 
    log_dir=app_log_path, 
    compose_path=docker_compose_path, 
    db_dir=db_tmp,
    db_port=int(db_config["db_port"])
)
stop_docker_containers(docker_compose_path)

print(docker_compose_path)

start_docker_containers(docker_compose_path)

db_watcher.set_ckpt()
dump = dump_database(db_config, limit=5)
print(json.dumps(dump, indent=2, default=str))

new_entries = db_watcher.get_new_entries()

print("New Entries:")
print(new_entries)
# print(json.dumps(dump, indent=2, default=str))  # default=str for e.g. Decimal/UUID