test_size.py 1.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. import pytest
  2. import numpy as np
  3. from . import util
  4. class TestSizeSumExample(util.F2PyTest):
  5. sources = [util.getpath("tests", "src", "size", "foo.f90")]
  6. @pytest.mark.slow
  7. def test_all(self):
  8. r = self.module.foo([[]])
  9. assert r == [0]
  10. r = self.module.foo([[1, 2]])
  11. assert r == [3]
  12. r = self.module.foo([[1, 2], [3, 4]])
  13. assert np.allclose(r, [3, 7])
  14. r = self.module.foo([[1, 2], [3, 4], [5, 6]])
  15. assert np.allclose(r, [3, 7, 11])
  16. @pytest.mark.slow
  17. def test_transpose(self):
  18. r = self.module.trans([[]])
  19. assert np.allclose(r.T, np.array([[]]))
  20. r = self.module.trans([[1, 2]])
  21. assert np.allclose(r, [[1.], [2.]])
  22. r = self.module.trans([[1, 2, 3], [4, 5, 6]])
  23. assert np.allclose(r, [[1, 4], [2, 5], [3, 6]])
  24. @pytest.mark.slow
  25. def test_flatten(self):
  26. r = self.module.flatten([[]])
  27. assert np.allclose(r, [])
  28. r = self.module.flatten([[1, 2]])
  29. assert np.allclose(r, [1, 2])
  30. r = self.module.flatten([[1, 2, 3], [4, 5, 6]])
  31. assert np.allclose(r, [1, 2, 3, 4, 5, 6])