dnf: don't return fail_json['msg'] as list (#65302)

Although it's not enforced that fail_json['msg'] should be a string
[1], I think it is pretty strongly implied.

In this case the failure_response['msg'] is sent through as the
fail_json['msg'], and the trailing commas here turn it into a tuple.
It's not clear if this is a typo or intended, but it does cause
problems for callbacks that expect this as a string (e.g. [2]).

Since there seems no point to having these values as a tuple, remove
the trailing commas so they return a string as per everywhere else.

[1] 4c589661c2/lib/ansible/module_utils/basic.py (L2078)
[2] https://review.opendev.org/#/c/696081
This commit is contained in:
Ian Wienand 2019-12-05 07:28:10 +11:00 committed by ansibot
parent 770430fd07
commit fc54ae9227
2 changed files with 5 additions and 2 deletions

View file

@ -0,0 +1,3 @@
bugfixes:
- dnf module - Ensure the modules exit_json['msg'] response is
always string, not sometimes a tuple.

View file

@ -1165,7 +1165,7 @@ class DnfModule(YumDnf):
else: else:
response['changed'] = True response['changed'] = True
if failure_response['failures']: if failure_response['failures']:
failure_response['msg'] = 'Failed to install some of the specified packages', failure_response['msg'] = 'Failed to install some of the specified packages'
self.module.fail_json(**failure_response) self.module.fail_json(**failure_response)
if self.module.check_mode: if self.module.check_mode:
response['msg'] = "Check mode: No changes made, but would have if not in check mode" response['msg'] = "Check mode: No changes made, but would have if not in check mode"
@ -1195,7 +1195,7 @@ class DnfModule(YumDnf):
response['results'].append("Removed: {0}".format(package)) response['results'].append("Removed: {0}".format(package))
if failure_response['failures']: if failure_response['failures']:
failure_response['msg'] = 'Failed to install some of the specified packages', failure_response['msg'] = 'Failed to install some of the specified packages'
self.module.exit_json(**response) self.module.exit_json(**response)
self.module.exit_json(**response) self.module.exit_json(**response)
except dnf.exceptions.DepsolveError as e: except dnf.exceptions.DepsolveError as e: