ansible-playbook [core 2.19.6] config file = None configured module search path = ['/root/.ansible/plugins/modules', '/usr/share/ansible/plugins/modules'] ansible python module location = /usr/local/lib/python3.13/site-packages/ansible ansible collection location = /tmp/collections-mTf executable location = /usr/local/bin/ansible-playbook python version = 3.13.11 (main, Jan 6 2026, 00:00:00) [GCC 15.2.1 20251211 (Red Hat 15.2.1-5)] (/usr/bin/python3.13) jinja version = 3.1.6 pyyaml version = 6.0.2 (with libyaml v0.2.5) No config file found; using defaults running playbook inside collection fedora.linux_system_roles 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_default.yml **************************************************** 3 plays in /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/tests/ssh/tests_default.yml PLAY [Backup configuration files] ********************************************** TASK [Gathering Facts] ********************************************************* task path: /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/tests/ssh/tests_default.yml:2 Saturday 21 February 2026 16:20:45 -0500 (0:00:00.023) 0:00:00.023 ***** [WARNING]: Host 'managed-node3' is using the discovered Python interpreter at '/usr/bin/python3.13', but future installation of another Python interpreter could cause a different interpreter to be discovered. See https://docs.ansible.com/ansible-core/2.19/reference_appendices/interpreter_discovery.html for more information. ok: [managed-node3] TASK [Backup configuration files] ********************************************** task path: /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/tests/ssh/tests_default.yml:9 Saturday 21 February 2026 16:20:46 -0500 (0:00:01.199) 0:00:01.222 ***** included: /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/backup.yml for managed-node3 TASK [Setup] ******************************************************************* task path: /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/backup.yml:2 Saturday 21 February 2026 16:20:46 -0500 (0:00:00.018) 0:00:01.241 ***** included: /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/setup.yml for managed-node3 TASK [Ensure facts used by test] *********************************************** task path: /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/setup.yml:2 Saturday 21 February 2026 16:20:46 -0500 (0:00:00.026) 0:00:01.267 ***** skipping: [managed-node3] => { "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-mTf/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/setup.yml:10 Saturday 21 February 2026 16:20:46 -0500 (0:00:00.020) 0:00:01.288 ***** ok: [managed-node3] => { "changed": false, "stat": { "exists": false } } TASK [Set flag to indicate system is ostree] *********************************** task path: /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/setup.yml:15 Saturday 21 February 2026 16:20:46 -0500 (0:00:00.664) 0:00:01.954 ***** ok: [managed-node3] => { "ansible_facts": { "__ssh_is_ostree": false }, "changed": false } TASK [Make sure openssh is installed before creating backup] ******************* task path: /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/setup.yml:19 Saturday 21 February 2026 16:20:47 -0500 (0:00:00.069) 0:00:02.024 ***** ok: [managed-node3] => { "changed": false, "rc": 0, "results": [] } MSG: Nothing to do lsrpackages: openssh-clients TASK [Define common variables] ************************************************* task path: /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/setup.yml:31 Saturday 21 February 2026 16:20:48 -0500 (0:00:01.889) 0:00:03.914 ***** ok: [managed-node3] => { "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-mTf/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/setup.yml:37 Saturday 21 February 2026 16:20:48 -0500 (0:00:00.025) 0:00:03.939 ***** ok: [managed-node3] => { "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-mTf/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/backup.yml:5 Saturday 21 February 2026 16:20:48 -0500 (0:00:00.054) 0:00:03.994 ***** ok: [managed-node3] => { "changed": false, "gid": 0, "group": "root", "mode": "0700", "owner": "root", "path": "/tmp/ansible.x89iwh8y", "secontext": "unconfined_u:object_r:user_tmp_t:s0", "size": 40, "state": "directory", "uid": 0 } TASK [Backup files] ************************************************************ task path: /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/backup.yml:13 Saturday 21 February 2026 16:20:49 -0500 (0:00:00.607) 0:00:04.601 ***** ok: [managed-node3] => (item=/etc/ssh_config.d/00-ansible.conf) => { "ansible_loop_var": "item", "changed": false, "cmd": "if test -f /etc/ssh_config.d/00-ansible.conf; then\n mkdir -p /tmp/ansible.x89iwh8y/$(dirname /etc/ssh_config.d/00-ansible.conf);\n cp -a /etc/ssh_config.d/00-ansible.conf /tmp/ansible.x89iwh8y/$(dirname /etc/ssh_config.d/00-ansible.conf)\nfi\n", "delta": "0:00:00.003649", "end": "2026-02-21 16:20:50.263651", "item": "/etc/ssh_config.d/00-ansible.conf", "rc": 0, "start": "2026-02-21 16:20:50.260002" } ok: [managed-node3] => (item=/etc/ssh_config) => { "ansible_loop_var": "item", "changed": false, "cmd": "if test -f /etc/ssh_config; then\n mkdir -p /tmp/ansible.x89iwh8y/$(dirname /etc/ssh_config);\n cp -a /etc/ssh_config /tmp/ansible.x89iwh8y/$(dirname /etc/ssh_config)\nfi\n", "delta": "0:00:00.003668", "end": "2026-02-21 16:20:50.731114", "item": "/etc/ssh_config", "rc": 0, "start": "2026-02-21 16:20:50.727446" } PLAY [Ensure that the role runs with default parameters] *********************** TASK [fedora.linux_system_roles.ssh : Set platform/version specific variables] *** task path: /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:2 Saturday 21 February 2026 16:20:50 -0500 (0:00:01.188) 0:00:05.789 ***** included: /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/set_vars.yml for managed-node3 TASK [fedora.linux_system_roles.ssh : Ensure ansible_facts used by role] ******* task path: /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/set_vars.yml:2 Saturday 21 February 2026 16:20:50 -0500 (0:00:00.022) 0:00:05.812 ***** skipping: [managed-node3] => { "changed": false, "false_condition": "__ssh_required_facts | difference(ansible_facts.keys() | list) | length > 0", "skip_reason": "Conditional result was False" } TASK [fedora.linux_system_roles.ssh : Check if system is ostree] *************** task path: /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/set_vars.yml:10 Saturday 21 February 2026 16:20:50 -0500 (0:00:00.030) 0:00:05.842 ***** skipping: [managed-node3] => { "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-mTf/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/set_vars.yml:15 Saturday 21 February 2026 16:20:50 -0500 (0:00:00.017) 0:00:05.859 ***** skipping: [managed-node3] => { "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-mTf/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/set_vars.yml:22 Saturday 21 February 2026 16:20:50 -0500 (0:00:00.018) 0:00:05.877 ***** ok: [managed-node3] => { "changed": false, "stat": { "exists": false } } TASK [fedora.linux_system_roles.ssh : Set flag if transactional-update exists] *** task path: /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/set_vars.yml:27 Saturday 21 February 2026 16:20:51 -0500 (0:00:00.439) 0:00:06.317 ***** ok: [managed-node3] => { "ansible_facts": { "__ssh_is_transactional": false }, "changed": false } TASK [fedora.linux_system_roles.ssh : Set platform/version specific variables] *** task path: /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/set_vars.yml:31 Saturday 21 February 2026 16:20:51 -0500 (0:00:00.025) 0:00:06.343 ***** skipping: [managed-node3] => (item=RedHat.yml) => { "ansible_loop_var": "item", "changed": false, "false_condition": "__vars_file is file", "item": "RedHat.yml", "skip_reason": "Conditional result was False" } ok: [managed-node3] => (item=Fedora.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-mTf/ansible_collections/fedora/linux_system_roles/roles/ssh/vars/Fedora.yml" ], "ansible_loop_var": "item", "changed": false, "item": "Fedora.yml" } skipping: [managed-node3] => (item=Fedora_42.yml) => { "ansible_loop_var": "item", "changed": false, "false_condition": "__vars_file is file", "item": "Fedora_42.yml", "skip_reason": "Conditional result was False" } skipping: [managed-node3] => (item=Fedora_42.yml) => { "ansible_loop_var": "item", "changed": false, "false_condition": "__vars_file is file", "item": "Fedora_42.yml", "skip_reason": "Conditional result was False" } TASK [fedora.linux_system_roles.ssh : Ensure required packages are installed] *** task path: /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:5 Saturday 21 February 2026 16:20:51 -0500 (0:00:00.046) 0:00:06.389 ***** ok: [managed-node3] => { "changed": false, "rc": 0, "results": [] } MSG: Nothing to do lsrpackages: openssh openssh-clients TASK [fedora.linux_system_roles.ssh : Notify user that reboot is needed to apply changes] *** task path: /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:17 Saturday 21 February 2026 16:20:53 -0500 (0:00:01.710) 0:00:08.100 ***** skipping: [managed-node3] => { "false_condition": "__ssh_is_transactional | d(false)" } TASK [fedora.linux_system_roles.ssh : Reboot transactional update systems] ***** task path: /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:22 Saturday 21 February 2026 16:20:53 -0500 (0:00:00.026) 0:00:08.126 ***** skipping: [managed-node3] => { "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-mTf/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:27 Saturday 21 February 2026 16:20:53 -0500 (0:00:00.026) 0:00:08.153 ***** skipping: [managed-node3] => { "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-mTf/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:35 Saturday 21 February 2026 16:20:53 -0500 (0:00:00.025) 0:00:08.179 ***** skipping: [managed-node3] => { "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-mTf/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:42 Saturday 21 February 2026 16:20:53 -0500 (0:00:00.018) 0:00:08.197 ***** skipping: [managed-node3] => { "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-mTf/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:53 Saturday 21 February 2026 16:20:53 -0500 (0:00:00.019) 0:00:08.216 ***** changed: [managed-node3] => { "changed": true, "checksum": "f7064ac5462aad2cda2efeaddcf48db84a38b68b", "dest": "/etc/ssh/ssh_config.d/00-ansible.conf", "gid": 0, "group": "root", "md5sum": "b9842f12c77db4e7cba397c9fdad4642", "mode": "0644", "owner": "root", "secontext": "system_u:object_r:etc_t:s0", "size": 41, "src": "/root/.ansible/tmp/ansible-tmp-1771708853.2939858-6378-33354062002203/.source.conf", "state": "file", "uid": 0 } PLAY [Restore configuration files] ********************************************* TASK [Gathering Facts] ********************************************************* task path: /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/tests/ssh/tests_default.yml:18 Saturday 21 February 2026 16:20:54 -0500 (0:00:01.176) 0:00:09.392 ***** ok: [managed-node3] TASK [Restore configuration files] ********************************************* task path: /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/tests/ssh/tests_default.yml:25 Saturday 21 February 2026 16:20:56 -0500 (0:00:02.021) 0:00:11.414 ***** included: /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/restore.yml for managed-node3 TASK [Restore backed up files and remove what was not present] ***************** task path: /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/restore.yml:2 Saturday 21 February 2026 16:20:56 -0500 (0:00:00.028) 0:00:11.442 ***** ok: [managed-node3] => (item=/etc/ssh_config.d/00-ansible.conf) => { "ansible_loop_var": "item", "changed": false, "cmd": "if test -f /tmp/ansible.x89iwh8y//etc/ssh_config.d/00-ansible.conf; then\n cp -a /tmp/ansible.x89iwh8y//etc/ssh_config.d/00-ansible.conf $(dirname /etc/ssh_config.d/00-ansible.conf)\nelif test -f /etc/ssh_config.d/00-ansible.conf; then\n rm /etc/ssh_config.d/00-ansible.conf\nfi\n", "delta": "0:00:00.003718", "end": "2026-02-21 16:20:56.894541", "item": "/etc/ssh_config.d/00-ansible.conf", "rc": 0, "start": "2026-02-21 16:20:56.890823" } ok: [managed-node3] => (item=/etc/ssh_config) => { "ansible_loop_var": "item", "changed": false, "cmd": "if test -f /tmp/ansible.x89iwh8y//etc/ssh_config; then\n cp -a /tmp/ansible.x89iwh8y//etc/ssh_config $(dirname /etc/ssh_config)\nelif test -f /etc/ssh_config; then\n rm /etc/ssh_config\nfi\n", "delta": "0:00:00.003734", "end": "2026-02-21 16:20:57.351319", "item": "/etc/ssh_config", "rc": 0, "start": "2026-02-21 16:20:57.347585" } TASK [Remove temporary directory for backup files] ***************************** task path: /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/restore.yml:15 Saturday 21 February 2026 16:20:57 -0500 (0:00:00.961) 0:00:12.404 ***** ok: [managed-node3] => { "changed": false, "path": "/tmp/ansible.x89iwh8y", "state": "absent" } PLAY RECAP ********************************************************************* managed-node3 : ok=20 changed=1 unreachable=0 failed=0 skipped=9 rescued=0 ignored=0 SYSTEM ROLES ERRORS BEGIN v1 [] SYSTEM ROLES ERRORS END v1 TASKS RECAP ******************************************************************** Saturday 21 February 2026 16:20:58 -0500 (0:00:00.602) 0:00:13.006 ***** =============================================================================== Gathering Facts --------------------------------------------------------- 2.02s /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/tests/ssh/tests_default.yml:18 Make sure openssh is installed before creating backup ------------------- 1.89s /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/setup.yml:19 fedora.linux_system_roles.ssh : Ensure required packages are installed --- 1.71s /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:5 Gathering Facts --------------------------------------------------------- 1.20s /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/tests/ssh/tests_default.yml:2 Backup files ------------------------------------------------------------ 1.19s /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/backup.yml:13 fedora.linux_system_roles.ssh : Generate the configuration file --------- 1.18s /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:53 Restore backed up files and remove what was not present ----------------- 0.96s /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/restore.yml:2 Check if system is ostree ----------------------------------------------- 0.67s /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/setup.yml:10 Create a temporary directory for backup files --------------------------- 0.61s /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/backup.yml:5 Remove temporary directory for backup files ----------------------------- 0.60s /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/restore.yml:15 fedora.linux_system_roles.ssh : Check if transactional-update exists in /sbin --- 0.44s /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/set_vars.yml:22 Set flag to indicate system is ostree ----------------------------------- 0.07s /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/setup.yml:15 Define specific variables ----------------------------------------------- 0.05s /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/setup.yml:37 fedora.linux_system_roles.ssh : Set platform/version specific variables --- 0.05s /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/set_vars.yml:31 fedora.linux_system_roles.ssh : Ensure ansible_facts used by role ------- 0.03s /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/set_vars.yml:2 Restore configuration files --------------------------------------------- 0.03s /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/tests/ssh/tests_default.yml:25 fedora.linux_system_roles.ssh : Notify user that reboot is needed to apply changes --- 0.03s /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:17 fedora.linux_system_roles.ssh : Reboot transactional update systems ----- 0.03s /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:22 Setup ------------------------------------------------------------------- 0.03s /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/backup.yml:2 fedora.linux_system_roles.ssh : Fail if reboot is needed and not set ---- 0.03s /tmp/collections-mTf/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:27