from lambench.metrics.visualization import ResultsFetcher
from lambench.models.dp_models import DPModel
import logging
import numpy as np


def test_aggregate_ood_results_for_one_model(
    mock_direct_predict_query, valid_model_data, caplog
):
    model = DPModel(**valid_model_data)
    model.model_name = "test_dp"
    model.show_direct_task = True
    model.show_finetune_task = False
    model.show_calculator_task = False
    aggregator = ResultsFetcher()
    result = aggregator.aggregate_ood_results_for_one_model(model=model)
    np.testing.assert_almost_equal(result["Molecules"], desired=0.22748765, decimal=5)
    np.testing.assert_almost_equal(result["Inorganic Materials"], 0.2972349, decimal=5)
    assert result["Catalysis"] is None
    with caplog.at_level(logging.WARNING):
        assert (
            "Expect one record for test_dp and Cu_MgO_catalysts, but got 0"
            in caplog.text
        )
