123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182 |
- # -*- coding: utf-8 -*-
- '''
- :codeauthor: Pedro Algarvio (pedro@algarvio.me)
- tests.unit.version_test
- ~~~~~~~~~~~~~~~~~~~~~~~
- Test salt's regex git describe version parsing
- '''
- # Import python libs
- from __future__ import absolute_import
- import re
- # Import Salt Testing libs
- from tests.support.unit import TestCase
- from tests.support.mock import MagicMock, patch
- # Import Salt libs
- from salt.version import SaltStackVersion, versions_report
- import salt.version
- class VersionTestCase(TestCase):
- def test_version_parsing(self):
- strip_initial_non_numbers_regex = re.compile(r'(?:[^\d]+)?(?P<vs>.*)')
- expect = (
- ('v0.12.0-19-g767d4f9', (0, 12, 0, 0, '', 0, 19, 'g767d4f9'), None),
- ('v0.12.0-85-g2880105', (0, 12, 0, 0, '', 0, 85, 'g2880105'), None),
- ('debian/0.11.1+ds-1-3-ga0afcbd',
- (0, 11, 1, 0, '', 0, 3, 'ga0afcbd'), '0.11.1-3-ga0afcbd'),
- ('0.12.1', (0, 12, 1, 0, '', 0, 0, None), None),
- ('0.12.1', (0, 12, 1, 0, '', 0, 0, None), None),
- ('0.17.0rc1', (0, 17, 0, 0, 'rc', 1, 0, None), None),
- ('v0.17.0rc1-1-g52ebdfd', (0, 17, 0, 0, 'rc', 1, 1, 'g52ebdfd'), None),
- ('v2014.1.4.1', (2014, 1, 4, 1, '', 0, 0, None), None),
- ('v2014.1.4.1rc3-n/a-abcdefff', (2014, 1, 4, 1, 'rc', 3, -1, 'abcdefff'), None),
- ('v3.4.1.1', (3, 4, 1, 1, '', 0, 0, None), None),
- ('v3000', (3000, None, None, 0, '', 0, 0, None), '3000'),
- ('v3000rc1', (3000, None, None, 0, 'rc', 1, 0, None), '3000rc1'),
- )
- for vstr, full_info, version in expect:
- saltstack_version = SaltStackVersion.parse(vstr)
- self.assertEqual(
- saltstack_version.full_info, full_info
- )
- if version is None:
- version = strip_initial_non_numbers_regex.search(vstr).group('vs')
- self.assertEqual(saltstack_version.string, version)
- def test_version_comparison(self):
- examples = (
- ('debian/0.11.1+ds-1-3-ga0afcbd', '0.11.1+ds-2'),
- ('v0.12.0-85-g2880105', 'v0.12.0-19-g767d4f9'),
- ('v0.17.0rc1-1-g52ebdfd', '0.17.0rc1'),
- ('v0.17.0', 'v0.17.0rc1'),
- ('Hydrogen', '0.17.0'),
- ('Helium', 'Hydrogen'),
- ('v2014.1.4.1-n/a-abcdefff', 'v2014.1.4.1rc3-n/a-abcdefff'),
- ('v2014.1.4.1-1-abcdefff', 'v2014.1.4.1-n/a-abcdefff'),
- ('v2016.12.0rc1', 'v2016.12.0b1'),
- ('v2016.12.0beta1', 'v2016.12.0alpha1'),
- ('v2016.12.0alpha1', 'v2016.12.0alpha0'),
- ('v3000.1', 'v3000'),
- ('v3000rc2', 'v3000rc1'),
- ('v3001', 'v3000'),
- ('v4023rc1', 'v4022rc1'),
- ('v3000', 'v3000rc1'),
- ('v3000', 'v2019.2.1'),
- ('v3000.1', 'v2019.2.1'),
- # we created v3000.0rc1 tag on repo
- # but we should not be using this
- # version scheme in the future
- # but still adding test for it
- ('v3000', 'v3000.0rc1'),
- )
- for higher_version, lower_version in examples:
- self.assertTrue(SaltStackVersion.parse(higher_version) > lower_version)
- self.assertTrue(SaltStackVersion.parse(lower_version) < higher_version)
- assert SaltStackVersion.parse(lower_version) != higher_version
- def test_unparsable_version(self):
- with self.assertRaises(ValueError):
- SaltStackVersion.from_name('Drunk')
- with self.assertRaises(ValueError):
- SaltStackVersion.parse('Drunk')
- def test_sha(self):
- '''
- test matching sha's
- '''
- exp_ret = (
- ('d6cd1e2bd19e03a81132a23b2025920577f84e37', True),
- ('2880105', True),
- ('v3000.0.1', False),
- ('v0.12.0-85-g2880105', False)
- )
- for commit, exp in exp_ret:
- ret = SaltStackVersion.git_sha_regex.match(commit)
- if exp:
- assert ret
- else:
- assert not ret
- def test_version_report_lines(self):
- '''
- Validate padding in versions report is correct
- '''
- # Get a set of all version report name lenghts including padding
- line_lengths = set([
- len(line.split(':')[0]) for line in list(versions_report())[4:]
- if line != ' ' and line != 'System Versions:'
- ])
- # Check that they are all the same size (only one element in the set)
- assert len(line_lengths) == 1
- def test_string_new_version(self):
- '''
- Validate string property method
- using new versioning scheme
- '''
- maj_ver = '3000'
- ver = SaltStackVersion(major=maj_ver)
- assert not ver.minor
- assert not ver.bugfix
- assert maj_ver == ver.string
- def test_string_new_version_minor(self):
- '''
- Validate string property method
- using new versioning scheme alongside
- minor version
- '''
- maj_ver = 3000
- min_ver = 1
- ver = SaltStackVersion(major=maj_ver, minor=min_ver)
- assert ver.minor == min_ver
- assert not ver.bugfix
- assert ver.string == '{0}.{1}'.format(maj_ver, min_ver)
- def test_string_old_version(self):
- '''
- Validate string property method
- using old versioning scheme alongside
- minor version
- '''
- maj_ver = '2019'
- min_ver = '2'
- ver = SaltStackVersion(major=maj_ver, minor=min_ver)
- assert ver.bugfix == 0
- assert ver.string == '{0}.{1}.0'.format(maj_ver, min_ver)
- def test_discover_version(self):
- '''
- Test call to __discover_version
- when using different versions
- '''
- version = {('3000', None):
- {(b'v3000.0rc2-12-g44fe283a77\n', '3000rc2-12-g44fe283a77'),
- (b'v3000', '3000'),
- (b'1234567', '3000-n/a-1234567'), },
- (2019, 2):
- {(b'v2019.2.0rc2-12-g44fe283a77\n', '2019.2.0rc2-12-g44fe283a77'),
- (b'v2019.2.0', '2019.2.0'),
- (b'afc9830198dj', '2019.2.0-n/a-afc9830198dj'), },
- }
- for maj_min, test_v in version.items():
- for tag_ver, exp in version[maj_min]:
- salt_ver = SaltStackVersion(major=maj_min[0], minor=maj_min[1], bugfix=None)
- attrs = {'communicate.return_value': (tag_ver, b''),
- 'returncode.return_value': 0}
- proc_ret = MagicMock(**attrs)
- proc_mock = patch('subprocess.Popen', return_value=proc_ret)
- patch_os = patch('os.path.exists', return_value=True)
- with proc_mock, patch_os:
- ret = getattr(salt.version, '__discover_version')(salt_ver)
- assert ret == exp
|