diff --git a/changelogs/fragments/sudoers.yml b/changelogs/fragments/sudoers.yml new file mode 100644 index 0000000000..f16a007de9 --- /dev/null +++ b/changelogs/fragments/sudoers.yml @@ -0,0 +1,3 @@ +--- +bugfixes: + - sudoers - display stdout and stderr raised while failed validation (https://github.com/ansible-collections/community.general/issues/9674, https://github.com/ansible-collections/community.general/pull/9871). diff --git a/plugins/modules/sudoers.py b/plugins/modules/sudoers.py index 54a52faad4..ac1ff91ff5 100644 --- a/plugins/modules/sudoers.py +++ b/plugins/modules/sudoers.py @@ -246,7 +246,7 @@ class Sudoers(object): rc, stdout, stderr = self.module.run_command(check_command, data=self.content()) if rc != 0: - raise Exception('Failed to validate sudoers rule:\n{stdout}'.format(stdout=stdout)) + self.module.fail_json(msg='Failed to validate sudoers rule:\n{stdout}'.format(stdout=stdout or stderr), stdout=stdout, stderr=stderr) def run(self): if self.state == 'absent': diff --git a/tests/integration/targets/sudoers/tasks/main.yml b/tests/integration/targets/sudoers/tasks/main.yml index 36397f41ad..fa03b71dac 100644 --- a/tests/integration/targets/sudoers/tasks/main.yml +++ b/tests/integration/targets/sudoers/tasks/main.yml @@ -229,7 +229,7 @@ ignore_errors: true when: ansible_os_family != 'Darwin' register: edge_case_3 - + - name: Revoke non-existing rule community.general.sudoers: name: non-existing-rule @@ -278,12 +278,14 @@ that: - not revoke_rule_1_stat.stat.exists - not revoke_non_existing_rule_stat.stat.exists - + - name: Check edge case responses ansible.builtin.assert: that: - edge_case_1 is failed - "'Failed to validate sudoers rule' in edge_case_1.msg" + - edge_case_1.stdout is defined + - edge_case_1.stderr is defined - edge_case_2 is not failed - name: Check missing validation edge case