pull/85758/merge
ksaegusa 23 hours ago committed by GitHub
commit bec3da00e4
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

@ -0,0 +1,2 @@
minor_changes:
- default callback - add ``display_included_hosts`` option to control the ``included:`` banner lines for ``include_tasks``/``include_role``.

@ -293,6 +293,9 @@ class CallbackModule(CallbackBase):
self._display.display(msg, color=C.COLOR_SKIP) self._display.display(msg, color=C.COLOR_SKIP)
def v2_playbook_on_include(self, included_file): def v2_playbook_on_include(self, included_file):
if not self.get_option("display_included_hosts"):
return
msg = 'included: %s for %s' % (included_file._filename, ", ".join([h.name for h in included_file._hosts])) msg = 'included: %s for %s' % (included_file._filename, ", ".join([h.name for h in included_file._hosts]))
label = self._get_item_label(included_file._vars) label = self._get_item_label(included_file._vars)
if label: if label:

@ -44,6 +44,17 @@ class ModuleDocFragment(object):
- key: display_failed_stderr - key: display_failed_stderr
section: defaults section: defaults
version_added: '2.7' version_added: '2.7'
display_included_hosts:
name: Show included hosts
description: "Toggle to control displaying included task/host results in a task."
type: bool
default: yes
env:
- name: ANSIBLE_DISPLAY_INCLUDED_HOSTS
ini:
- key: display_included_hosts
section: defaults
version_added: '2.20'
show_custom_stats: show_custom_stats:
name: Show custom stats name: Show custom stats
description: 'This adds the custom stats set via the set_stats plugin to the play recap.' description: 'This adds the custom stats set via the set_stats plugin to the play recap.'

@ -0,0 +1,2 @@
+ ansible-playbook -i inventory test.yml
++ set +x

@ -0,0 +1,130 @@
PLAY [testhost] ****************************************************************
TASK [Changed task] ************************************************************
changed: [testhost]
TASK [Ok task] *****************************************************************
ok: [testhost]
TASK [Failed task] *************************************************************
[ERROR]: Task failed: Action failed: no reason
Origin: TEST_PATH/test.yml:16:7
14 changed_when: false
15
16 - name: Failed task
^ column 7
fatal: [testhost]: FAILED! => {"changed": false, "msg": "no reason"}
...ignoring
TASK [Skipped task] ************************************************************
skipping: [testhost]
TASK [Task with var in name (foo bar)] *****************************************
changed: [testhost]
TASK [Loop task] ***************************************************************
changed: [testhost] => (item=foo-1)
changed: [testhost] => (item=foo-2)
changed: [testhost] => (item=foo-3)
TASK [debug loop] **************************************************************
changed: [testhost] => (item=debug-1) => {
"msg": "debug-1"
}
[ERROR]: Task failed: Action failed: debug-2
Origin: TEST_PATH/test.yml:38:7
36
37 # detect "changed" debug tasks being hidden with display_ok_tasks=false
38 - name: debug loop
^ column 7
failed: [testhost] (item=debug-2) => {
"msg": "debug-2"
}
ok: [testhost] => (item=debug-3) => {
"msg": "debug-3"
}
skipping: [testhost] => (item=debug-4)
fatal: [testhost]: FAILED! => {"msg": "One or more items failed"}
...ignoring
TASK [EXPECTED FAILURE Failed task to be rescued] ******************************
[ERROR]: Task failed: Action failed: Failed as requested from task
Origin: TEST_PATH/test.yml:54:11
52
53 - block:
54 - name: EXPECTED FAILURE Failed task to be rescued
^ column 11
fatal: [testhost]: FAILED! => {"changed": false, "msg": "Failed as requested from task"}
TASK [Rescue task] *************************************************************
changed: [testhost]
TASK [include_tasks] ***********************************************************
TASK [debug] *******************************************************************
ok: [testhost] => {
"item": 1
}
TASK [copy] ********************************************************************
changed: [testhost]
TASK [replace] *****************************************************************
--- before: .../test_diff.txt
+++ after: .../test_diff.txt
@@ -1 +1 @@
-foo
\ No newline at end of file
+bar
\ No newline at end of file
changed: [testhost]
TASK [replace] *****************************************************************
ok: [testhost]
TASK [debug] *******************************************************************
skipping: [testhost]
TASK [debug] *******************************************************************
skipping: [testhost]
TASK [debug] *******************************************************************
skipping: [testhost] => (item=1)
skipping: [testhost] => (item=2)
skipping: [testhost]
RUNNING HANDLER [Test handler 1] ***********************************************
changed: [testhost]
RUNNING HANDLER [Test handler 2] ***********************************************
ok: [testhost]
RUNNING HANDLER [Test handler 3] ***********************************************
changed: [testhost]
PLAY [testhost] ****************************************************************
TASK [First free task] *********************************************************
changed: [testhost]
TASK [Second free task] ********************************************************
changed: [testhost]
TASK [Include some tasks] ******************************************************
TASK [debug] *******************************************************************
ok: [testhost] => {
"item": 1
}
PLAY RECAP *********************************************************************
testhost : ok=19 changed=11 unreachable=0 failed=0 skipped=4 rescued=1 ignored=2

@ -0,0 +1,93 @@
PLAY [testhost] ****************************************************************
TASK [Changed task] ************************************************************
changed: [testhost]
TASK [Failed task] *************************************************************
[ERROR]: Task failed: Action failed: no reason
Origin: TEST_PATH/test.yml:16:7
14 changed_when: false
15
16 - name: Failed task
^ column 7
fatal: [testhost]: FAILED! => {"changed": false, "msg": "no reason"}
...ignoring
TASK [Task with var in name (foo bar)] *****************************************
changed: [testhost]
TASK [Loop task] ***************************************************************
changed: [testhost] => (item=foo-1)
changed: [testhost] => (item=foo-2)
changed: [testhost] => (item=foo-3)
TASK [debug loop] **************************************************************
changed: [testhost] => (item=debug-1) => {
"msg": "debug-1"
}
[ERROR]: Task failed: Action failed: debug-2
Origin: TEST_PATH/test.yml:38:7
36
37 # detect "changed" debug tasks being hidden with display_ok_tasks=false
38 - name: debug loop
^ column 7
failed: [testhost] (item=debug-2) => {
"msg": "debug-2"
}
fatal: [testhost]: FAILED! => {"msg": "One or more items failed"}
...ignoring
TASK [EXPECTED FAILURE Failed task to be rescued] ******************************
[ERROR]: Task failed: Action failed: Failed as requested from task
Origin: TEST_PATH/test.yml:54:11
52
53 - block:
54 - name: EXPECTED FAILURE Failed task to be rescued
^ column 11
fatal: [testhost]: FAILED! => {"changed": false, "msg": "Failed as requested from task"}
TASK [Rescue task] *************************************************************
changed: [testhost]
TASK [include_tasks] ***********************************************************
TASK [copy] ********************************************************************
changed: [testhost]
TASK [replace] *****************************************************************
--- before: .../test_diff.txt
+++ after: .../test_diff.txt
@@ -1 +1 @@
-foo
\ No newline at end of file
+bar
\ No newline at end of file
changed: [testhost]
RUNNING HANDLER [Test handler 1] ***********************************************
changed: [testhost]
RUNNING HANDLER [Test handler 3] ***********************************************
changed: [testhost]
PLAY [testhost] ****************************************************************
TASK [First free task] *********************************************************
changed: [testhost]
TASK [Second free task] ********************************************************
changed: [testhost]
TASK [Include some tasks] ******************************************************
PLAY RECAP *********************************************************************
testhost : ok=19 changed=11 unreachable=0 failed=0 skipped=4 rescued=1 ignored=2

@ -170,6 +170,27 @@ export ANSIBLE_DISPLAY_OK_HOSTS=0
run_test hide_ok test.yml run_test hide_ok test.yml
# Hide include
export ANSIBLE_DISPLAY_SKIPPED_HOSTS=1
export ANSIBLE_DISPLAY_OK_HOSTS=1
export ANSIBLE_DISPLAY_INCLUDED_HOSTS=0
run_test hide_included test.yml
# Hide skipped/ok/included
export ANSIBLE_DISPLAY_SKIPPED_HOSTS=0
export ANSIBLE_DISPLAY_OK_HOSTS=0
export ANSIBLE_DISPLAY_INCLUDED_HOSTS=0
run_test hide_skipped_ok_included test.yml
# Hide ok
export ANSIBLE_DISPLAY_SKIPPED_HOSTS=1
export ANSIBLE_DISPLAY_OK_HOSTS=0
export ANSIBLE_DISPLAY_INCLUDED_HOSTS=1
run_test hide_ok test.yml
# Failed to stderr # Failed to stderr
export ANSIBLE_DISPLAY_SKIPPED_HOSTS=1 export ANSIBLE_DISPLAY_SKIPPED_HOSTS=1
export ANSIBLE_DISPLAY_OK_HOSTS=1 export ANSIBLE_DISPLAY_OK_HOSTS=1

Loading…
Cancel
Save