init_test.py 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. import pytest
  2. from freesurfer_volume_reader import (
  3. __version__,
  4. parse_version_string,
  5. remove_group_names_from_regex,
  6. VolumeFile,
  7. SubfieldVolumeFile,
  8. )
  9. def test_module_version():
  10. assert len(__version__) >= len("0.1.0")
  11. @pytest.mark.parametrize(
  12. ("version_string", "expected_tuple"),
  13. [
  14. ("0.24.2", (0, 24, 2)),
  15. ("0.21.0", (0, 21, 0)),
  16. ("0.2.2.dev28+g526f05c.d20190504", (0, 2, 2, "dev28+g526f05c", "d20190504")),
  17. ],
  18. )
  19. def test_parse_version_string(version_string, expected_tuple):
  20. assert expected_tuple == parse_version_string(version_string)
  21. def test_parse_version_string_comparison():
  22. assert parse_version_string("0.24.2") == (0, 24, 2)
  23. assert parse_version_string("0.24.2") < (0, 25)
  24. assert parse_version_string("0.24.2") < (0, 24, 3)
  25. assert parse_version_string("0.24.2") <= (0, 24, 2)
  26. assert parse_version_string("0.24.2") >= (0, 24, 2)
  27. assert parse_version_string("0.24.2") > (0, 24, 1)
  28. assert parse_version_string("0.24.2") > (0, 24)
  29. assert parse_version_string("0.2.2.dev28+g526f05c.d20190504") > (0, 2, 2)
  30. assert parse_version_string("0.2.2.dev28+g526f05c.d20190504") < (0, 2, 3)
  31. @pytest.mark.parametrize(
  32. ("source_pattern", "expected_pattern"),
  33. [
  34. (r"^(?P<h>[lr])h\.hippoSfVolumes", r"^([lr])h\.hippoSfVolumes"),
  35. (r"(?P<a>a(?P<b>b))", r"(a(b))"),
  36. ],
  37. )
  38. def test_remove_group_names_from_regex(source_pattern, expected_pattern):
  39. assert expected_pattern == remove_group_names_from_regex(
  40. regex_pattern=source_pattern
  41. )
  42. class DummyVolumeFile(VolumeFile):
  43. # pylint: disable=useless-super-delegation
  44. @property
  45. def absolute_path(self):
  46. return super().absolute_path
  47. def test_volume_file_abstractmethod():
  48. volume_file = DummyVolumeFile()
  49. with pytest.raises(NotImplementedError):
  50. assert volume_file.absolute_path
  51. class DummySubfieldVolumeFile(SubfieldVolumeFile):
  52. # pylint: disable=useless-super-delegation
  53. @property
  54. def absolute_path(self):
  55. return super().absolute_path
  56. def read_volumes_mm3(self):
  57. return super().read_volumes_mm3()
  58. def read_volumes_dataframe(self):
  59. return super().read_volumes_dataframe()
  60. def test_subfield_volume_file_abstractmethod():
  61. volume_file = DummySubfieldVolumeFile()
  62. with pytest.raises(NotImplementedError):
  63. assert volume_file.absolute_path
  64. with pytest.raises(NotImplementedError):
  65. volume_file.read_volumes_mm3()
  66. with pytest.raises(NotImplementedError):
  67. volume_file.read_volumes_dataframe()