"""
test_internal.py

Runs the following scripts in order (from the project root):
  1) inference/benchmark_test.py
  2) inference/search_embeddings_test_internal.py
  3) inference/calculate_baseline.py INTERNAL
  4) inference/calculate_final_integrals.py INTERNAL
  5) inference/final_inference_combination.py INTERNAL
  6) inference/inference_test.py INTERNAL
  7) inference/plot_combination_confidence_curves.py INTERNAL

Loads config/config.py if present by ensuring the project root is on PYTHONPATH
for all child processes.
"""

from __future__ import annotations

import os
import sys
import subprocess
from pathlib import Path
from typing import Optional


def find_project_root(start: Optional[Path] = None) -> Path:
    """Find the repo root by looking for 'inference', 'config', etc."""
    here = (start or Path(__file__).resolve()).parent
    for p in [here] + list(here.parents):
        if (p / "inference").is_dir() or (p / "config").is_dir():
            return p
    return Path(__file__).resolve().parents[1]


project_root = find_project_root()
if str(project_root) not in sys.path:
    sys.path.insert(0, str(project_root))


def run_script(script_path: Path, *args: str) -> None:
    if not script_path.exists():
        print(f"[ERROR] Script not found: {script_path}", file=sys.stderr)
        sys.exit(1)

    rel = script_path.relative_to(project_root) if script_path.is_absolute() else script_path
    print(f"[INFO] Running {rel} {' '.join(args)} ...")

    env = dict(os.environ)
    env["PYTHONPATH"] = (
        f"{str(project_root)}{os.pathsep}{env.get('PYTHONPATH', '')}".rstrip(os.pathsep)
    )

    result = subprocess.run(
        [sys.executable, str(script_path), *args],
        cwd=str(project_root),
        env=env,
        check=False,
    )

    if result.returncode != 0:
        print(f"[ERROR] {script_path.name} failed with code {result.returncode}", file=sys.stderr)
        sys.exit(result.returncode)

    print(f"[INFO] Finished {script_path.name}")


try:
    import config.config  # noqa: F401
    print("[INFO] Loaded config/config.py")
except Exception as e:
    print(f"[WARN] Could not import config/config.py ({e}). Continuing without it.")


SCRIPTS = [
    (project_root / "inference" / "benchmark_test_internal.py", []),
    (project_root / "inference" / "search_embeddings_test_internal.py", []),
    (project_root / "inference" / "calculate_baseline.py", ["INTERNAL"]),
    (project_root / "inference" / "inference_test.py", ["INTERNAL"]),
    (project_root / "inference" / "calculate_final_integrals.py", ["INTERNAL"]),
    (project_root / "inference" / "final_inference_combination.py", ["INTERNAL"]),
    (project_root / "inference" / "plot_combination_confidence_curves.py", ["INTERNAL"]),
    (project_root / "inference" / "calculate_combinations_acc_coverage.py", ["INTERNAL"]),
    (project_root / "inference" / "calculate_combination_subset_integrals.py", ["INTERNAL"]),
    (project_root / "inference" / "plot_best.py", ["INTERNAL"]),
]


def main() -> None:
    for script, args in SCRIPTS:
        run_script(script, *args)
    print("[INFO] All scripts completed successfully.")


if __name__ == "__main__":
    main()