Galaxy - make versions list consistent across versions (#72932)

* Galaxy - make versions list consistent across versions

* Fix up unit tests
This commit is contained in:
Jordan Borean 2021-01-21 06:19:29 +10:00 committed by GitHub
parent 51e00c5e86
commit bc60d8ccda
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 40 additions and 28 deletions

View file

@ -0,0 +1,4 @@
minor_changes:
- >-
ansible-galaxy - Ensure ``get_collection_versions`` returns an empty list when a collection does
not exist for consistency across API versions.

View file

@ -751,9 +751,15 @@ class GalaxyAPI:
server_cache = self._cache.setdefault(get_cache_id(versions_url), {}) server_cache = self._cache.setdefault(get_cache_id(versions_url), {})
modified_cache = server_cache.setdefault('modified', {}) modified_cache = server_cache.setdefault('modified', {})
modified_date = self.get_collection_metadata(namespace, name).modified_str try:
cached_modified_date = modified_cache.get('%s.%s' % (namespace, name), None) modified_date = self.get_collection_metadata(namespace, name).modified_str
except GalaxyError as err:
if err.http_code != 404:
raise
# No collection found, return an empty list to keep things consistent with the various APIs
return []
cached_modified_date = modified_cache.get('%s.%s' % (namespace, name), None)
if cached_modified_date != modified_date: if cached_modified_date != modified_date:
modified_cache['%s.%s' % (namespace, name)] = modified_date modified_cache['%s.%s' % (namespace, name)] = modified_date
if versions_url_info.path in server_cache: if versions_url_info.path in server_cache:
@ -763,7 +769,14 @@ class GalaxyAPI:
error_context_msg = 'Error when getting available collection versions for %s.%s from %s (%s)' \ error_context_msg = 'Error when getting available collection versions for %s.%s from %s (%s)' \
% (namespace, name, self.name, self.api_server) % (namespace, name, self.name, self.api_server)
data = self._call_galaxy(versions_url, error_context_msg=error_context_msg, cache=True)
try:
data = self._call_galaxy(versions_url, error_context_msg=error_context_msg, cache=True)
except GalaxyError as err:
if err.http_code != 404:
raise
# v3 doesn't raise a 404 so we need to mimick the empty response from APIs that do.
return []
if 'data' in data: if 'data' in data:
# v3 automation-hub is the only known API that uses `data` # v3 automation-hub is the only known API that uses `data`

View file

@ -511,29 +511,26 @@ class CollectionRequirement:
galaxy_meta = None galaxy_meta = None
for api in apis: for api in apis:
try: if not (requirement == '*' or requirement.startswith('<') or requirement.startswith('>') or
if not (requirement == '*' or requirement.startswith('<') or requirement.startswith('>') or requirement.startswith('!=')):
requirement.startswith('!=')): # Exact requirement
# Exact requirement allow_pre_release = True
allow_pre_release = True
if requirement.startswith('='): if requirement.startswith('='):
requirement = requirement.lstrip('=') requirement = requirement.lstrip('=')
try:
resp = api.get_collection_version_metadata(namespace, name, requirement) resp = api.get_collection_version_metadata(namespace, name, requirement)
except GalaxyError as err:
if err.http_code != 404:
raise
versions = []
else:
galaxy_meta = resp galaxy_meta = resp
versions = [resp.version] versions = [resp.version]
else: else:
versions = api.get_collection_versions(namespace, name) versions = api.get_collection_versions(namespace, name)
except GalaxyError as err:
if err.http_code != 404:
raise
versions = []
# Automation Hub doesn't return a 404 but an empty version list so we check that to align both AH and
# Galaxy when the collection is not available on that server.
if not versions: if not versions:
display.vvv("Collection '%s' is not available from server %s %s" % (collection, api.name, display.vvv("Collection '%s' is not available from server %s %s" % (collection, api.name,
api.api_server)) api.api_server))

View file

@ -403,10 +403,9 @@ def test_build_requirement_from_name_second_server(galaxy_server, monkeypatch):
broken_server = copy.copy(galaxy_server) broken_server = copy.copy(galaxy_server)
broken_server.api_server = 'https://broken.com/' broken_server.api_server = 'https://broken.com/'
mock_404 = MagicMock() mock_version_list = MagicMock()
mock_404.side_effect = api.GalaxyError(urllib_error.HTTPError('https://galaxy.server.com', 404, 'msg', {}, mock_version_list.return_value = []
StringIO()), "custom msg") monkeypatch.setattr(broken_server, 'get_collection_versions', mock_version_list)
monkeypatch.setattr(broken_server, 'get_collection_versions', mock_404)
actual = collection.CollectionRequirement.from_name('namespace.collection', [broken_server, galaxy_server], actual = collection.CollectionRequirement.from_name('namespace.collection', [broken_server, galaxy_server],
'>1.0.1', False, True) '>1.0.1', False, True)
@ -420,8 +419,8 @@ def test_build_requirement_from_name_second_server(galaxy_server, monkeypatch):
assert actual.latest_version == u'1.0.3' assert actual.latest_version == u'1.0.3'
assert actual.dependencies == {} assert actual.dependencies == {}
assert mock_404.call_count == 1 assert mock_version_list.call_count == 1
assert mock_404.mock_calls[0][1] == ('namespace', 'collection') assert mock_version_list.mock_calls[0][1] == ('namespace', 'collection')
assert mock_get_versions.call_count == 1 assert mock_get_versions.call_count == 1
assert mock_get_versions.mock_calls[0][1] == ('namespace', 'collection') assert mock_get_versions.mock_calls[0][1] == ('namespace', 'collection')
@ -429,8 +428,7 @@ def test_build_requirement_from_name_second_server(galaxy_server, monkeypatch):
def test_build_requirement_from_name_missing(galaxy_server, monkeypatch): def test_build_requirement_from_name_missing(galaxy_server, monkeypatch):
mock_open = MagicMock() mock_open = MagicMock()
mock_open.side_effect = api.GalaxyError(urllib_error.HTTPError('https://galaxy.server.com', 404, 'msg', {}, mock_open.return_value = []
StringIO()), "")
monkeypatch.setattr(galaxy_server, 'get_collection_versions', mock_open) monkeypatch.setattr(galaxy_server, 'get_collection_versions', mock_open)