import unittest
import numpy as np

from mbi import LinearMeasurement
from measurement_wrapper import MeasurementWrapper

class TestMeasurementWrapper(unittest.TestCase):
    def test_concatenate_and_convert(self):

        measurements = [
            LinearMeasurement(noisy_measurement=np.array([1.0, 2.0]), clique=('A',), stddev=0.5),
            LinearMeasurement(noisy_measurement=np.array([3.0]), clique=('B',), stddev=1.0),
            LinearMeasurement(noisy_measurement=np.array([4.0, 5.0, 6.0]), clique=('C',), stddev=0.2)
        ]

        wrapper = MeasurementWrapper(measurements)

        concatenated = wrapper.get_concatenated_values()
        expected_concatenated = np.array([1.0, 2.0, 3.0, 4.0, 5.0, 6.0])
        np.testing.assert_array_equal(concatenated, expected_concatenated)

        converted_measurements = wrapper.convert_vector_to_measurements(concatenated)
        self.assertEqual(len(converted_measurements), len(measurements))

        for original, converted in zip(measurements, converted_measurements):
            np.testing.assert_array_equal(original.noisy_measurement, converted.noisy_measurement)
            self.assertEqual(original.clique, converted.clique)
            self.assertEqual(original.stddev, converted.stddev)