import json

import requests


def run_tests(code: str, test_list: list, run_tests_separately: bool = False, timeout: int = 5) -> dict:
    """
    Send code and tests to the Docker API and return results.

    Args:
        code (str): Python code containing function/class definition
        test_list (list): List of assertion tests as strings
        run_tests_separately (bool, optional): Whether to run tests separately or as one unit. Defaults to False.

    Returns:
        dict: API response containing test results
    """
    url = "http://localhost:1337/execute"

    payload = {
        "code": code,
        "test_list": test_list,
        "run_tests_separately": run_tests_separately,
        "timeout": timeout
    }

    try:
        response = requests.post(url, json=payload)
        response.raise_for_status()  # Raise exception for bad status codes
        response_json = response.json()
        if 'summary' not in response_json:
            print(response_json)
            raise Exception("Test runner returned no summary")
        return response_json

    except requests.exceptions.RequestException as e:
        # Print warning about server unresponsiveness
        print(f"\033[93mWarning: Test runner server is not responsive: {str(e)}\033[0m")
        # Return the same structure as successful responses
        return {
            "errors": [{
                "type": "api_error",
                "message": f"API request failed: {str(e)}"
            }],
            "passed_tests": [],
            "failed_tests": test_list,  # Mark all tests as failed when API is unreachable
            "execution_status": {
                "timed_out": False,
                "timeout_during": "none",
                "execution_time": 0
            },
            "summary": {
                "total_tests": len(test_list),
                "passed_tests": 0,
                "failed_tests": len(test_list),
                "success_rate": 0.0,
                "execution_time": 0,
                "timed_out": False,
                "timeout_during": "none"
            }
        }


def io_run_tests(code: str, test_list: list, run_tests_separately: bool = True, timeout: int = 1) -> dict:
    """
    Send code with input/output test cases to the Docker API and return results.

    Args:
        code (str): Python code to execute
        test_list (list): List of dictionaries containing input/output pairs
                         Each dict should have 'input' and 'output' keys
        run_tests_separately (bool, optional): Whether to run each test in isolation. Defaults to True.
        timeout (int, optional): Maximum execution time in seconds. Defaults to 5.

    Returns:
        dict: API response containing test results and execution status
    """
    url = "http://localhost:1337/ioexecute"

    payload = {
        "code": code,
        "test_list": test_list,
        "run_tests_separately": run_tests_separately,
        "timeout": timeout
    }

    try:
        response = requests.post(url, json=payload)
        response.raise_for_status()  # Raise exception for bad status codes
        response_json = response.json()
        if 'summary' not in response_json:
            print(response_json)
            raise Exception("Test runner returned no summary")
        return response_json

    except requests.exceptions.RequestException as e:
        # Print warning about server unresponsiveness
        print(f"\033[93mWarning: Test runner server is not responsive: {str(e)}\033[0m")
        # Return the same structure as successful responses
        return {
            "errors": [{
                "type": "api_error",
                "message": f"API request failed: {str(e)}"
            }],
            "passed_tests": [],
            "failed_tests": [
                {
                    "input": test["input"],
                    "expected_output": test["output"],
                    "error": str(e)
                }
                for test in test_list
            ],
            "execution_status": {
                "timed_out": False,
                "timeout_during": "none",
                "execution_time": 0
            },
            "summary": {
                "total_tests": len(test_list),
                "passed_tests": 0,
                "failed_tests": len(test_list),
                "success_rate": 0.0,
                "execution_time": 0,
                "timed_out": False,
                "timeout_during": "none"
            }
        }


# Example usage
if __name__ == "__main__":
    # Example 1: Regular assertion tests
    code1 = """
def sum_numbers(a, b):
    return a + b
"""

    test_list = [
        "assert sum_numbers(2, 2) == 4",
        "assert sum_numbers(5, 3) == 8",
        "assert sum_numbers(1, 1) == 3"  # This test will fail
    ]

    print("Running assertion tests:")
    results = run_tests(code1, test_list)
    print(json.dumps(results, indent=2))
