ansible-playbook [core 2.17.14] config file = None configured module search path = ['/root/.ansible/plugins/modules', '/usr/share/ansible/plugins/modules'] ansible python module location = /usr/local/lib/python3.12/site-packages/ansible ansible collection location = /tmp/collections-hfN executable location = /usr/local/bin/ansible-playbook python version = 3.12.12 (main, Jan 16 2026, 00:00:00) [GCC 14.3.1 20251022 (Red Hat 14.3.1-4)] (/usr/bin/python3.12) jinja version = 3.1.6 libyaml = True No config file found; using defaults running playbook inside collection fedora.linux_system_roles Skipping callback 'debug', as we already have a stdout callback. Skipping callback 'json', as we already have a stdout callback. Skipping callback 'jsonl', as we already have a stdout callback. Skipping callback 'default', as we already have a stdout callback. Skipping callback 'minimal', as we already have a stdout callback. Skipping callback 'oneline', as we already have a stdout callback. PLAYBOOK: tests_precedence.yml ************************************************* 1 plays in /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tests_precedence.yml PLAY [Test options precedence when mixing ssh dict and ssh_* variables] ******** TASK [Gathering Facts] ********************************************************* task path: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tests_precedence.yml:2 Thursday 19 March 2026 19:46:17 -0400 (0:00:00.017) 0:00:00.017 ******** [WARNING]: Platform linux on host managed-node1 is using the discovered Python interpreter at /usr/bin/python3.12, but future installation of another Python interpreter could change the meaning of that path. See https://docs.ansible.com/ansible- core/2.17/reference_appendices/interpreter_discovery.html for more information. ok: [managed-node1] TASK [Backup configuration files] ********************************************** task path: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tests_precedence.yml:10 Thursday 19 March 2026 19:46:18 -0400 (0:00:01.280) 0:00:01.298 ******** included: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/backup.yml for managed-node1 TASK [Setup] ******************************************************************* task path: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/backup.yml:2 Thursday 19 March 2026 19:46:18 -0400 (0:00:00.030) 0:00:01.328 ******** included: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/setup.yml for managed-node1 TASK [Ensure facts used by test] *********************************************** task path: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/setup.yml:2 Thursday 19 March 2026 19:46:18 -0400 (0:00:00.016) 0:00:01.345 ******** skipping: [managed-node1] => { "changed": false, "false_condition": "'os_family' not in ansible_facts", "skip_reason": "Conditional result was False" } TASK [Check if system is ostree] *********************************************** task path: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/setup.yml:10 Thursday 19 March 2026 19:46:18 -0400 (0:00:00.012) 0:00:01.357 ******** ok: [managed-node1] => { "changed": false, "stat": { "exists": false } } TASK [Set flag to indicate system is ostree] *********************************** task path: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/setup.yml:15 Thursday 19 March 2026 19:46:19 -0400 (0:00:00.522) 0:00:01.880 ******** ok: [managed-node1] => { "ansible_facts": { "__ssh_is_ostree": false }, "changed": false } TASK [Make sure openssh is installed before creating backup] ******************* task path: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/setup.yml:19 Thursday 19 March 2026 19:46:19 -0400 (0:00:00.028) 0:00:01.908 ******** ok: [managed-node1] => { "changed": false, "rc": 0, "results": [] } MSG: Nothing to do TASK [Define common variables] ************************************************* task path: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/setup.yml:31 Thursday 19 March 2026 19:46:20 -0400 (0:00:00.877) 0:00:02.786 ******** ok: [managed-node1] => { "ansible_facts": { "main_ssh_config": "/etc/ssh/ssh_config", "main_ssh_config_name": "ssh_config", "main_ssh_config_path": "/etc/ssh/" }, "changed": false } TASK [Define specific variables] *********************************************** task path: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/setup.yml:37 Thursday 19 March 2026 19:46:20 -0400 (0:00:00.016) 0:00:02.803 ******** ok: [managed-node1] => { "ansible_facts": { "main_ssh_config": "/etc/ssh/ssh_config.d/00-ansible.conf", "main_ssh_config_name": "00-ansible.conf", "main_ssh_config_path": "/etc/ssh/ssh_config.d/" }, "changed": false } TASK [Create a temporary directory for backup files] *************************** task path: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/backup.yml:5 Thursday 19 March 2026 19:46:20 -0400 (0:00:00.032) 0:00:02.836 ******** ok: [managed-node1] => { "changed": false, "gid": 0, "group": "root", "mode": "0700", "owner": "root", "path": "/tmp/ansible._7qdqzdl", "secontext": "unconfined_u:object_r:user_tmp_t:s0", "size": 6, "state": "directory", "uid": 0 } TASK [Backup files] ************************************************************ task path: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/backup.yml:13 Thursday 19 March 2026 19:46:20 -0400 (0:00:00.459) 0:00:03.295 ******** ok: [managed-node1] => (item=/etc/ssh/ssh_config.d/00-ansible.conf) => { "ansible_loop_var": "item", "changed": false, "cmd": "if test -f /etc/ssh/ssh_config.d/00-ansible.conf; then\n mkdir -p /tmp/ansible._7qdqzdl/$(dirname /etc/ssh/ssh_config.d/00-ansible.conf);\n cp -a /etc/ssh/ssh_config.d/00-ansible.conf /tmp/ansible._7qdqzdl/$(dirname /etc/ssh/ssh_config.d/00-ansible.conf)\nfi\n", "delta": "0:00:00.007408", "end": "2026-03-19 19:46:21.229002", "item": "/etc/ssh/ssh_config.d/00-ansible.conf", "rc": 0, "start": "2026-03-19 19:46:21.221594" } ok: [managed-node1] => (item=/etc/ssh/ssh_config) => { "ansible_loop_var": "item", "changed": false, "cmd": "if test -f /etc/ssh/ssh_config; then\n mkdir -p /tmp/ansible._7qdqzdl/$(dirname /etc/ssh/ssh_config);\n cp -a /etc/ssh/ssh_config /tmp/ansible._7qdqzdl/$(dirname /etc/ssh/ssh_config)\nfi\n", "delta": "0:00:00.007602", "end": "2026-03-19 19:46:21.616846", "item": "/etc/ssh/ssh_config", "rc": 0, "start": "2026-03-19 19:46:21.609244" } TASK [Run role] **************************************************************** task path: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tests_precedence.yml:13 Thursday 19 March 2026 19:46:21 -0400 (0:00:00.866) 0:00:04.162 ******** included: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/run_role_with_clear_facts.yml for managed-node1 TASK [Clear facts] ************************************************************* task path: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/run_role_with_clear_facts.yml:8 Thursday 19 March 2026 19:46:21 -0400 (0:00:00.018) 0:00:04.180 ******** META: facts cleared TASK [Run the role] ************************************************************ task path: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/run_role_with_clear_facts.yml:22 Thursday 19 March 2026 19:46:21 -0400 (0:00:00.001) 0:00:04.181 ******** skipping: [managed-node1] => { "changed": false, "false_condition": "__sr_failed_when is defined", "skip_reason": "Conditional result was False" } TASK [Run the role normally] *************************************************** task path: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/run_role_with_clear_facts.yml:32 Thursday 19 March 2026 19:46:21 -0400 (0:00:00.019) 0:00:04.201 ******** included: fedora.linux_system_roles.ssh for managed-node1 TASK [fedora.linux_system_roles.ssh : Set platform/version specific variables] *** task path: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:2 Thursday 19 March 2026 19:46:21 -0400 (0:00:00.113) 0:00:04.314 ******** included: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/set_vars.yml for managed-node1 TASK [fedora.linux_system_roles.ssh : Ensure ansible_facts used by role] ******* task path: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/set_vars.yml:2 Thursday 19 March 2026 19:46:21 -0400 (0:00:00.034) 0:00:04.349 ******** ok: [managed-node1] TASK [fedora.linux_system_roles.ssh : Check if system is ostree] *************** task path: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/set_vars.yml:10 Thursday 19 March 2026 19:46:22 -0400 (0:00:00.599) 0:00:04.949 ******** skipping: [managed-node1] => { "changed": false, "false_condition": "not __ssh_is_ostree is defined", "skip_reason": "Conditional result was False" } TASK [fedora.linux_system_roles.ssh : Set flag to indicate system is ostree] *** task path: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/set_vars.yml:15 Thursday 19 March 2026 19:46:22 -0400 (0:00:00.016) 0:00:04.965 ******** skipping: [managed-node1] => { "changed": false, "false_condition": "not __ssh_is_ostree is defined", "skip_reason": "Conditional result was False" } TASK [fedora.linux_system_roles.ssh : Check if transactional-update exists in /sbin] *** task path: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/set_vars.yml:22 Thursday 19 March 2026 19:46:22 -0400 (0:00:00.016) 0:00:04.981 ******** ok: [managed-node1] => { "changed": false, "stat": { "exists": false } } TASK [fedora.linux_system_roles.ssh : Set flag if transactional-update exists] *** task path: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/set_vars.yml:27 Thursday 19 March 2026 19:46:22 -0400 (0:00:00.341) 0:00:05.323 ******** ok: [managed-node1] => { "ansible_facts": { "__ssh_is_transactional": false }, "changed": false } TASK [fedora.linux_system_roles.ssh : Set platform/version specific variables] *** task path: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/set_vars.yml:31 Thursday 19 March 2026 19:46:22 -0400 (0:00:00.024) 0:00:05.348 ******** skipping: [managed-node1] => (item=RedHat.yml) => { "ansible_loop_var": "item", "changed": false, "false_condition": "__vars_file is file", "item": "RedHat.yml", "skip_reason": "Conditional result was False" } skipping: [managed-node1] => (item=CentOS.yml) => { "ansible_loop_var": "item", "changed": false, "false_condition": "__vars_file is file", "item": "CentOS.yml", "skip_reason": "Conditional result was False" } ok: [managed-node1] => (item=CentOS_10.yml) => { "ansible_facts": { "__ssh_defaults": { "Include": "/etc/ssh/ssh_config.d/*.conf" }, "__ssh_drop_in_name": "00-ansible", "__ssh_supports_drop_in": true }, "ansible_included_var_files": [ "/tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/roles/ssh/vars/CentOS_10.yml" ], "ansible_loop_var": "item", "changed": false, "item": "CentOS_10.yml" } ok: [managed-node1] => (item=CentOS_10.yml) => { "ansible_facts": { "__ssh_defaults": { "Include": "/etc/ssh/ssh_config.d/*.conf" }, "__ssh_drop_in_name": "00-ansible", "__ssh_supports_drop_in": true }, "ansible_included_var_files": [ "/tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/roles/ssh/vars/CentOS_10.yml" ], "ansible_loop_var": "item", "changed": false, "item": "CentOS_10.yml" } TASK [fedora.linux_system_roles.ssh : Ensure required packages are installed] *** task path: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:5 Thursday 19 March 2026 19:46:22 -0400 (0:00:00.047) 0:00:05.395 ******** ok: [managed-node1] => { "changed": false, "rc": 0, "results": [] } MSG: Nothing to do TASK [fedora.linux_system_roles.ssh : Notify user that reboot is needed to apply changes] *** task path: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:17 Thursday 19 March 2026 19:46:24 -0400 (0:00:01.139) 0:00:06.535 ******** skipping: [managed-node1] => { "false_condition": "__ssh_is_transactional | d(false)" } TASK [fedora.linux_system_roles.ssh : Reboot transactional update systems] ***** task path: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:22 Thursday 19 March 2026 19:46:24 -0400 (0:00:00.017) 0:00:06.552 ******** skipping: [managed-node1] => { "changed": false, "false_condition": "__ssh_is_transactional | d(false)", "skip_reason": "Conditional result was False" } TASK [fedora.linux_system_roles.ssh : Fail if reboot is needed and not set] **** task path: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:27 Thursday 19 March 2026 19:46:24 -0400 (0:00:00.014) 0:00:06.566 ******** skipping: [managed-node1] => { "changed": false, "false_condition": "__ssh_is_transactional | d(false)", "skip_reason": "Conditional result was False" } TASK [fedora.linux_system_roles.ssh : Gather information about the user for user configuration] *** task path: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:35 Thursday 19 March 2026 19:46:24 -0400 (0:00:00.011) 0:00:06.577 ******** skipping: [managed-node1] => { "changed": false, "false_condition": "ssh_user is not none", "skip_reason": "Conditional result was False" } TASK [fedora.linux_system_roles.ssh : Make sure the ~/.ssh/ directory exists and has expected permissions] *** task path: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:42 Thursday 19 March 2026 19:46:24 -0400 (0:00:00.021) 0:00:06.598 ******** skipping: [managed-node1] => { "changed": false, "false_condition": "ssh_user is not none", "skip_reason": "Conditional result was False" } TASK [fedora.linux_system_roles.ssh : Generate the configuration file] ********* task path: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:53 Thursday 19 March 2026 19:46:24 -0400 (0:00:00.018) 0:00:06.617 ******** changed: [managed-node1] => { "backup_file": "/etc/ssh/ssh_config.d/00-ansible.conf.21404.2026-03-19@19:46:24~", "changed": true, "checksum": "e0863bc2265d06827abda9e96f665939d0018753", "dest": "/etc/ssh/ssh_config.d/00-ansible.conf", "gid": 0, "group": "root", "md5sum": "38b427de308be2423e9bd03ac7ef9a6d", "mode": "0644", "owner": "root", "secontext": "system_u:object_r:etc_t:s0", "size": 76, "src": "/root/.ansible/tmp/ansible-tmp-1773963984.1861303-14495-250800239683290/.source.conf", "state": "file", "uid": 0 } TASK [Download the global configuration file] ********************************** task path: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tests_precedence.yml:25 Thursday 19 March 2026 19:46:25 -0400 (0:00:00.936) 0:00:07.554 ******** ok: [managed-node1] => { "changed": false, "content": "IwojIEFuc2libGUgbWFuYWdlZAojCiMgc3lzdGVtX3JvbGU6c3NoCgpQb3J0IDIyMgpTdHJpY3RIb3N0S2V5Q2hlY2tpbmcgeWVzCg==", "encoding": "base64", "source": "/etc/ssh/ssh_config.d/00-ansible.conf" } TASK [Verify the options are in the file] ************************************** task path: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tests_precedence.yml:30 Thursday 19 March 2026 19:46:25 -0400 (0:00:00.493) 0:00:08.047 ******** ok: [managed-node1] => { "changed": false } MSG: All assertions passed TASK [Restore configuration files] ********************************************* task path: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tests_precedence.yml:38 Thursday 19 March 2026 19:46:25 -0400 (0:00:00.023) 0:00:08.071 ******** included: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/restore.yml for managed-node1 TASK [Restore backed up files and remove what was not present] ***************** task path: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/restore.yml:2 Thursday 19 March 2026 19:46:25 -0400 (0:00:00.018) 0:00:08.089 ******** ok: [managed-node1] => (item=/etc/ssh/ssh_config.d/00-ansible.conf) => { "ansible_loop_var": "item", "changed": false, "cmd": "if test -f /tmp/ansible._7qdqzdl//etc/ssh/ssh_config.d/00-ansible.conf; then\n cp -a /tmp/ansible._7qdqzdl//etc/ssh/ssh_config.d/00-ansible.conf $(dirname /etc/ssh/ssh_config.d/00-ansible.conf)\nelif test -f /etc/ssh/ssh_config.d/00-ansible.conf; then\n rm /etc/ssh/ssh_config.d/00-ansible.conf\nfi\n", "delta": "0:00:00.005570", "end": "2026-03-19 19:46:25.936924", "item": "/etc/ssh/ssh_config.d/00-ansible.conf", "rc": 0, "start": "2026-03-19 19:46:25.931354" } ok: [managed-node1] => (item=/etc/ssh/ssh_config) => { "ansible_loop_var": "item", "changed": false, "cmd": "if test -f /tmp/ansible._7qdqzdl//etc/ssh/ssh_config; then\n cp -a /tmp/ansible._7qdqzdl//etc/ssh/ssh_config $(dirname /etc/ssh/ssh_config)\nelif test -f /etc/ssh/ssh_config; then\n rm /etc/ssh/ssh_config\nfi\n", "delta": "0:00:00.005660", "end": "2026-03-19 19:46:26.267441", "item": "/etc/ssh/ssh_config", "rc": 0, "start": "2026-03-19 19:46:26.261781" } TASK [Remove temporary directory for backup files] ***************************** task path: /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/restore.yml:15 Thursday 19 March 2026 19:46:26 -0400 (0:00:00.720) 0:00:08.810 ******** ok: [managed-node1] => { "changed": false, "path": "/tmp/ansible._7qdqzdl", "state": "absent" } PLAY RECAP ********************************************************************* managed-node1 : ok=24 changed=1 unreachable=0 failed=0 skipped=9 rescued=0 ignored=0 SYSTEM ROLES ERRORS BEGIN v1 [] SYSTEM ROLES ERRORS END v1 TASKS RECAP ******************************************************************** Thursday 19 March 2026 19:46:26 -0400 (0:00:00.527) 0:00:09.337 ******** =============================================================================== Gathering Facts --------------------------------------------------------- 1.28s /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tests_precedence.yml:2 fedora.linux_system_roles.ssh : Ensure required packages are installed --- 1.14s /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:5 fedora.linux_system_roles.ssh : Generate the configuration file --------- 0.94s /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:53 Make sure openssh is installed before creating backup ------------------- 0.88s /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/setup.yml:19 Backup files ------------------------------------------------------------ 0.87s /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/backup.yml:13 Restore backed up files and remove what was not present ----------------- 0.72s /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/restore.yml:2 fedora.linux_system_roles.ssh : Ensure ansible_facts used by role ------- 0.60s /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/set_vars.yml:2 Remove temporary directory for backup files ----------------------------- 0.53s /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/restore.yml:15 Check if system is ostree ----------------------------------------------- 0.52s /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/setup.yml:10 Download the global configuration file ---------------------------------- 0.49s /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tests_precedence.yml:25 Create a temporary directory for backup files --------------------------- 0.46s /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/backup.yml:5 fedora.linux_system_roles.ssh : Check if transactional-update exists in /sbin --- 0.34s /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/set_vars.yml:22 Run the role normally --------------------------------------------------- 0.11s /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/run_role_with_clear_facts.yml:32 fedora.linux_system_roles.ssh : Set platform/version specific variables --- 0.05s /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/set_vars.yml:31 fedora.linux_system_roles.ssh : Set platform/version specific variables --- 0.03s /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:2 Define specific variables ----------------------------------------------- 0.03s /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/setup.yml:37 Backup configuration files ---------------------------------------------- 0.03s /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tests_precedence.yml:10 Set flag to indicate system is ostree ----------------------------------- 0.03s /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/setup.yml:15 fedora.linux_system_roles.ssh : Set flag if transactional-update exists --- 0.02s /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/set_vars.yml:27 Verify the options are in the file -------------------------------------- 0.02s /tmp/collections-hfN/ansible_collections/fedora/linux_system_roles/tests/ssh/tests_precedence.yml:30