"""
Test wrappers for ME methods: me_raw and scf_raw
"""
import os
import sys
import logging
import warnings
import numpy as np
from contextlib import contextmanager

# Ensure Theano does not try to auto-detect BLAS via numpy.distutils (often breaks on macOS/conda).
# This must be set BEFORE importing freqopttest/theano inside worker processes.
os.environ.setdefault("THEANO_FLAGS", "blas.ldflags=")

# Keep console quiet (no warnings / theano compilelock spam).
warnings.filterwarnings("ignore", category=FutureWarning)
warnings.filterwarnings("ignore", category=UserWarning)
logging.getLogger("theano.tensor.blas").setLevel(logging.ERROR)
logging.getLogger("theano.gof.compilelock").setLevel(logging.ERROR)


@contextmanager
def suppress_stdout_stderr():
    """Temporarily suppress stdout and stderr to hide optimization iteration output."""
    with open(os.devnull, 'w') 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_ME_raw(X, Y, seed):
    """
    ME_raw (Mean Embedding) test using freqopttest package directly.

    Note: freqopttest ME uses Gaussian internally.
    """
    try:
        from me_raw import met
        np.random.seed(seed)
        with suppress_stdout_stderr():
            result = met(X, Y, r=seed, J=10, alpha=0.05)
        # me_raw.met may return 'na' on numerical errors
        if result == 'na':
            return 'na'
        return int(result)
    except Exception:
        return 'na'

