import os
import sys
import warnings
import numpy as np
from contextlib import contextmanager

warnings.filterwarnings("ignore", category=FutureWarning)
warnings.filterwarnings("ignore", category=UserWarning)
warnings.filterwarnings("ignore", category=RuntimeWarning)


@contextmanager
def suppress_stdout_stderr():
    devnull_path = 'nul' if sys.platform == 'win32' else os.devnull
    with open(devnull_path, 'w', encoding='utf-8') as devnull:
        old_stdout = sys.stdout
        old_stderr = sys.stderr
        try:
            sys.stdout = devnull
            sys.stderr = devnull
            yield
        finally:
            sys.stdout = old_stdout
            sys.stderr = old_stderr


def test_AGGINC_raw(X, Y, seed):
    m, n = X.shape[0], Y.shape[0]
    if m > 0 and n > 0:
        ratio_check = min(m, n) / max(m, n)
        if ratio_check < 0.15:
            return 'na'
    try:
        from agginc_raw import agginc_mmd
        np.random.seed(seed)
        with suppress_stdout_stderr():
            result = agginc_mmd(X, Y, r=seed)
        if result == 'na':
            return 'na'
        return int(result)
    except Exception:
        return 'na'


def test_MMDAGG_raw(X, Y, seed):
    m, n = X.shape[0], Y.shape[0]
    if m > 0 and n > 0:
        ratio_check = min(m, n) / max(m, n)
        if ratio_check < 0.15:
            return 'na'
    try:
        from mmdagg_raw import mmdagg_test
        np.random.seed(seed)
        with suppress_stdout_stderr():
            result = mmdagg_test(X, Y, r=seed)
        if result == 'na':
            return 'na'
        return int(result)
    except Exception:
        return 'na'
