123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 |
- import pytest
- from freesurfer_volume_reader import \
- __version__, parse_version_string, remove_group_names_from_regex, \
- VolumeFile, SubfieldVolumeFile
- def test_module_version():
- assert len(__version__) >= len('0.1.0')
- @pytest.mark.parametrize(('version_string', 'expected_tuple'), [
- ('0.24.2', (0, 24, 2)),
- ('0.21.0', (0, 21, 0)),
- ('0.2.2.dev28+g526f05c.d20190504', (0, 2, 2, 'dev28+g526f05c', 'd20190504')),
- ])
- def test_parse_version_string(version_string, expected_tuple):
- assert expected_tuple == parse_version_string(version_string)
- def test_parse_version_string_comparison():
- assert parse_version_string('0.24.2') == (0, 24, 2)
- assert parse_version_string('0.24.2') < (0, 25)
- assert parse_version_string('0.24.2') < (0, 24, 3)
- assert parse_version_string('0.24.2') <= (0, 24, 2)
- assert parse_version_string('0.24.2') >= (0, 24, 2)
- assert parse_version_string('0.24.2') > (0, 24, 1)
- assert parse_version_string('0.24.2') > (0, 24)
- assert parse_version_string('0.2.2.dev28+g526f05c.d20190504') > (0, 2, 2)
- assert parse_version_string('0.2.2.dev28+g526f05c.d20190504') < (0, 2, 3)
- @pytest.mark.parametrize(('source_pattern', 'expected_pattern'), [
- (r'^(?P<h>[lr])h\.hippoSfVolumes', r'^([lr])h\.hippoSfVolumes'),
- (r'(?P<a>a(?P<b>b))', r'(a(b))'),
- ])
- def test_remove_group_names_from_regex(source_pattern, expected_pattern):
- assert expected_pattern == remove_group_names_from_regex(regex_pattern=source_pattern)
- class DummyVolumeFile(VolumeFile):
- # pylint: disable=useless-super-delegation
- @property
- def absolute_path(self):
- return super().absolute_path
- def test_volume_file_abstractmethod():
- volume_file = DummyVolumeFile()
- with pytest.raises(NotImplementedError):
- assert volume_file.absolute_path
- class DummySubfieldVolumeFile(SubfieldVolumeFile):
- # pylint: disable=useless-super-delegation
- @property
- def absolute_path(self):
- return super().absolute_path
- def read_volumes_mm3(self):
- return super().read_volumes_mm3()
- def read_volumes_dataframe(self):
- return super().read_volumes_dataframe()
- def test_subfield_volume_file_abstractmethod():
- volume_file = DummySubfieldVolumeFile()
- with pytest.raises(NotImplementedError):
- assert volume_file.absolute_path
- with pytest.raises(NotImplementedError):
- volume_file.read_volumes_mm3()
- with pytest.raises(NotImplementedError):
- volume_file.read_volumes_dataframe()
|