import unittest

import numpy as np
import math

from kernel import GaussianKernel

class TestGaussianKernel(unittest.TestCase):
    def test_one_vector_of_size_2(self):
        x = np.array([1, 2])
        y = np.array([1, 6])
        kern = GaussianKernel()
        expected_value = math.exp(-4**2/2)
        G = kern.calculate([x], [y])
        actual_value = G
        msg = 'GaussianKernel fails when receiving two vectors of length 2'
        self.assertEqual(expected_value, actual_value, msg)


if __name__ == '__main__':
    unittest.main()