import re
from typing import TYPE_CHECKING

from swebench.harness.constants import TestStatus

if TYPE_CHECKING:
    from swebench.harness.test_spec.test_spec import TestSpec


def parse_log_gotest(log: str, test_spec: "TestSpec") -> dict[str, str]:
    """
    Parser for test logs generated with 'go test'

    Args:
        log (str): log content
        test_spec (TestSpec): test spec (unused)
    Returns:
        dict: test case to test status mapping
    """
    test_status_map = {}

    # Pattern to match test result lines
    pattern = r"^--- (PASS|FAIL|SKIP): (.+) \((.+)\)$"

    for line in log.split("\n"):
        match = re.match(pattern, line.strip())
        if match:
            status, test_name, _duration = match.groups()
            if status == "PASS":
                test_status_map[test_name] = TestStatus.PASSED.value
            elif status == "FAIL":
                test_status_map[test_name] = TestStatus.FAILED.value
            elif status == "SKIP":
                test_status_map[test_name] = TestStatus.SKIPPED.value

    return test_status_map


MAP_REPO_TO_PARSER_GO = {
    "caddyserver/caddy": parse_log_gotest,
    "hashicorp/terraform": parse_log_gotest,
    "prometheus/prometheus": parse_log_gotest,
    "gohugoio/hugo": parse_log_gotest,
    "gin-gonic/gin": parse_log_gotest,
}
