* ansible-galaxy - fix fallback for AH searches (#70957)
(cherry picked from commit b1cb2553af
)
* Fix tests after backport
This commit is contained in:
parent
8389f4df0b
commit
a8217f1bd4
3 changed files with 30 additions and 5 deletions
2
changelogs/fragments/galaxy-collection-fallback.yml
Normal file
2
changelogs/fragments/galaxy-collection-fallback.yml
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
bugfixes:
|
||||||
|
- ansible-galaxy collection install - fix fallback mechanism if the AH server did not have the collection requested - https://github.com/ansible/ansible/issues/70940
|
|
@ -525,11 +525,17 @@ class CollectionRequirement:
|
||||||
else:
|
else:
|
||||||
versions = api.get_collection_versions(namespace, name)
|
versions = api.get_collection_versions(namespace, name)
|
||||||
except GalaxyError as err:
|
except GalaxyError as err:
|
||||||
if err.http_code == 404:
|
if err.http_code != 404:
|
||||||
display.vvv("Collection '%s' is not available from server %s %s"
|
raise
|
||||||
% (collection, api.name, api.api_server))
|
|
||||||
continue
|
versions = []
|
||||||
raise
|
|
||||||
|
# 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:
|
||||||
|
display.vvv("Collection '%s' is not available from server %s %s" % (collection, api.name,
|
||||||
|
api.api_server))
|
||||||
|
continue
|
||||||
|
|
||||||
display.vvv("Collection '%s' obtained from server %s %s" % (collection, api.name, api.api_server))
|
display.vvv("Collection '%s' obtained from server %s %s" % (collection, api.name, api.api_server))
|
||||||
break
|
break
|
||||||
|
|
|
@ -154,5 +154,22 @@
|
||||||
- name: automation_hub
|
- name: automation_hub
|
||||||
server: '{{ fallaxy_ah_server }}'
|
server: '{{ fallaxy_ah_server }}'
|
||||||
|
|
||||||
|
# fake.fake does not exist but we check the output to ensure it checked all 3
|
||||||
|
# servers defined in the config. We hardcode to -vvv as that's what level the
|
||||||
|
# message is shown
|
||||||
|
- name: test install fallback on server list
|
||||||
|
command: ansible-galaxy collection install fake.fake -vvv
|
||||||
|
ignore_errors: yes
|
||||||
|
environment:
|
||||||
|
ANSIBLE_CONFIG: '{{ galaxy_dir }}/ansible.cfg'
|
||||||
|
register: missing_fallback
|
||||||
|
|
||||||
|
- name: assert test install fallback on server list
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- missing_fallback.rc == 1
|
||||||
|
- '"Collection ''fake.fake'' is not available from server galaxy" in missing_fallback.stdout'
|
||||||
|
- '"Collection ''fake.fake'' is not available from server automation_hub" in missing_fallback.stdout'
|
||||||
|
|
||||||
- name: run ansible-galaxy collection download tests
|
- name: run ansible-galaxy collection download tests
|
||||||
include_tasks: download.yml
|
include_tasks: download.yml
|
||||||
|
|
Loading…
Reference in a new issue