import os
import pytest
import importlib
import subprocess
import time
import shutil

mod = importlib.import_module("install-mpsd-software-environment")


def test_os_chdir(tmp_path):
    # create a temporary directory for testing
    temp_dir = tmp_path / "test_os_chdir"
    temp_dir.mkdir()

    # initial current working directory
    initial_cwd = os.getcwd()

    # change to the temporary directory using os_chdir
    with mod.os_chdir(str(temp_dir)):
        assert os.getcwd() == str(temp_dir)

    # current working directory should be back to initial directory
    assert os.getcwd() == initial_cwd


def test_prepare_env(tmp_path):
    # simulate running ./install-software-environment.py --release dev-23a --target-directory /tmp/test_prepare_env
    # prepare_env is run when cmd is not specified, we can test cmd='prepare'  and cmd=None to check both cases

    # check that the test directory does not exist
    assert not (tmp_path / "test_prepare_env").exists()

    run = mod.builder(
        release="dev-23a",
        cmd="prepare",
        target_dir=str(tmp_path / "test_prepare_env"),
        skip_build_cache=False,
    )
    run.run()
    # wait for 20 seconds for the git clone to finish
    # time.sleep(20)
    # check if the directory now is created
    assert (tmp_path / "test_prepare_env").exists()
    # check for spack-environments directory
    assert os.listdir(str(tmp_path / "test_prepare_env")) == ["spack-environments"]
    # check if the git branch is correctl checked out
    assert (
        subprocess.run(
            f"cd {str(tmp_path / 'test_prepare_env/spack-environments')} && git branch",
            shell=True,
            capture_output=True,
        )
        .stdout.decode("utf-8")
        .split("\n")[0]
        == "* dev-23a"
    )
    # make sure running the command again raises ValueError
    with pytest.raises(ValueError):
        run = mod.builder(
            release="dev-23a",
            cmd=None,
            target_dir=str(tmp_path / "test_prepare_env"),
            skip_build_cache=False,
        )
        run.run()

    # check that ValueError is not raised if skip_dir_check is True
    run = mod.builder(
        release="dev-23a",
        cmd=None,
        target_dir=str(tmp_path / "test_prepare_env"),
        skip_build_cache=False,
    )
    run.skip_dir_check = True
    run.run()
    # clean up the temporary directory
    shutil.rmtree(str(tmp_path / "test_prepare_env"))


def test_setup_log_cmd(tmp_path):
    # check that logs/install-software-environment.log is updated when the module is run
    log_file = "logs/install-software-environment.log"
    if os.path.exists(log_file):
        initial_bytes = os.path.getsize(log_file)
    else:
        initial_bytes = 0

    # run the prepare_env functionality
    mod.prepare_env(toolchain_base_dir=str(tmp_path), mpsd_spack_ver='dev-23a', skip_dir_check=False, shared_var=shared_var)

    # check that logs/install-software-environment.log is updated
    assert os.path.exists("logs/install-software-environment.log")
    assert os.path.getsize("logs/install-software-environment.log") > initial_bytes