Fix docker versioning library to support new versioning scheme
Fixes: 222349174
/
Reference: https://github.com/docker/docker/pull/31075
This commit is contained in:
parent
94be8731f3
commit
67c0bf6263
2 changed files with 19 additions and 2 deletions
|
@ -4,6 +4,7 @@ from util.registry.dockerver import docker_version
|
|||
from semantic_version import Version, Spec
|
||||
|
||||
@pytest.mark.parametrize('ua_string, ver_info', [
|
||||
# Old "semantic" versioning.
|
||||
('docker/1.6.0 go/go1.4.2 git-commit/1234567 kernel/4.2.0-18-generic os/linux arch/amd64',
|
||||
Version('1.6.0')),
|
||||
('docker/1.7.1 go/go1.4.2 kernel/4.1.7-15.23.amzn1.x86_64 os/linux arch/amd64',
|
||||
|
@ -19,15 +20,24 @@ from semantic_version import Version, Spec
|
|||
('Go 1.1 package http', Version('1.5.0')),
|
||||
('curl', None),
|
||||
('docker/1.8 stuff', Version('1.8.0')),
|
||||
|
||||
# Newer date-based versioning: YY.MM.revnum
|
||||
('docker/17.03.0 my_version_sucks', Version('17.3.0')),
|
||||
('docker/17.03.0-foobar my_version_sucks', Version('17.3.0')),
|
||||
('docker/17.10.2 go/go1.4.2 git-commit/a34a1d5 kernel/3.10.0-229.20.1.el7.x86_64 os/linux arch/amd64',
|
||||
Version('17.10.2')),
|
||||
('docker/17.00.4 my_version_sucks', Version('17.0.4')),
|
||||
('docker/17.12.00 my_version_sucks', Version('17.12.0')),
|
||||
])
|
||||
def test_parsing(ua_string, ver_info):
|
||||
parsed_ver = docker_version(ua_string)
|
||||
assert parsed_ver == ver_info
|
||||
assert parsed_ver == ver_info, 'Expected %s, Found %s' % (ver_info, parsed_ver)
|
||||
|
||||
@pytest.mark.parametrize('spec, no_match_cases, match_cases', [
|
||||
(Spec('<1.6.0'), ['1.6.0', '1.6.1', '1.9.0', '100.5.2'], ['0.0.0', '1.5.99']),
|
||||
(Spec('<1.9.0'), ['1.9.0', '100.5.2'], ['0.0.0', '1.5.99', '1.6.0', '1.6.1']),
|
||||
(Spec('<1.6.0,>0.0.1'), ['1.6.0', '1.6.1', '1.9.0', '0.0.0'], ['1.5.99']),
|
||||
(Spec('>17.3.0'), ['17.3.0', '1.13.0'], ['17.4.0', '17.12.1']),
|
||||
])
|
||||
def test_specs(spec, no_match_cases, match_cases):
|
||||
for no_match_case in no_match_cases:
|
||||
|
|
Reference in a new issue