[WARNING]: Deprecation warnings can be disabled by setting `deprecation_warnings=False` in ansible.cfg. [DEPRECATION WARNING]: Importing 'to_bytes' from 'ansible.module_utils._text' is deprecated. This feature will be removed from ansible-core version 2.24. Use ansible.module_utils.common.text.converters instead. [DEPRECATION WARNING]: Importing 'to_text' from 'ansible.module_utils._text' is deprecated. This feature will be removed from ansible-core version 2.24. Use ansible.module_utils.common.text.converters instead. ansible-playbook [core 2.20.2] config file = None configured module search path = ['/root/.ansible/plugins/modules', '/usr/share/ansible/plugins/modules'] ansible python module location = /usr/local/lib/python3.14/site-packages/ansible ansible collection location = /tmp/collections-2lu executable location = /usr/local/bin/ansible-playbook python version = 3.14.2 (main, Dec 5 2025, 00:00:00) [GCC 15.2.1 20251111 (Red Hat 15.2.1-4)] (/usr/bin/python3.14) 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_indentation.yml ************************************************ 1 plays in /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/tests/ssh/tests_indentation.yml PLAY [Test indentation] ******************************************************** TASK [Gathering Facts] ********************************************************* task path: /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/tests/ssh/tests_indentation.yml:2 Saturday 21 February 2026 16:21:04 -0500 (0:00:00.028) 0:00:00.028 ***** [WARNING]: Host 'managed-node2' is using the discovered Python interpreter at '/usr/bin/python3.14', but future installation of another Python interpreter could cause a different interpreter to be discovered. See https://docs.ansible.com/ansible-core/2.20/reference_appendices/interpreter_discovery.html for more information. ok: [managed-node2] TASK [Backup configuration files] ********************************************** task path: /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/tests/ssh/tests_indentation.yml:8 Saturday 21 February 2026 16:21:05 -0500 (0:00:01.281) 0:00:01.310 ***** included: /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/backup.yml for managed-node2 TASK [Setup] ******************************************************************* task path: /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/backup.yml:2 Saturday 21 February 2026 16:21:05 -0500 (0:00:00.031) 0:00:01.341 ***** included: /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/setup.yml for managed-node2 TASK [Ensure facts used by test] *********************************************** task path: /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/setup.yml:2 Saturday 21 February 2026 16:21:05 -0500 (0:00:00.038) 0:00:01.379 ***** skipping: [managed-node2] => { "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-2lu/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/setup.yml:10 Saturday 21 February 2026 16:21:05 -0500 (0:00:00.024) 0:00:01.403 ***** ok: [managed-node2] => { "changed": false, "stat": { "exists": false } } TASK [Set flag to indicate system is ostree] *********************************** task path: /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/setup.yml:15 Saturday 21 February 2026 16:21:06 -0500 (0:00:00.671) 0:00:02.075 ***** ok: [managed-node2] => { "ansible_facts": { "__ssh_is_ostree": false }, "changed": false } TASK [Make sure openssh is installed before creating backup] ******************* task path: /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/setup.yml:19 Saturday 21 February 2026 16:21:06 -0500 (0:00:00.063) 0:00:02.139 ***** ok: [managed-node2] => { "changed": false, "rc": 0, "results": [] } MSG: Nothing to do lsrpackages: openssh-clients TASK [Define common variables] ************************************************* task path: /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/setup.yml:31 Saturday 21 February 2026 16:21:08 -0500 (0:00:01.704) 0:00:03.844 ***** ok: [managed-node2] => { "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-2lu/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/setup.yml:37 Saturday 21 February 2026 16:21:08 -0500 (0:00:00.025) 0:00:03.870 ***** ok: [managed-node2] => { "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-2lu/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/backup.yml:5 Saturday 21 February 2026 16:21:08 -0500 (0:00:00.048) 0:00:03.919 ***** ok: [managed-node2] => { "changed": false, "gid": 0, "group": "root", "mode": "0700", "owner": "root", "path": "/tmp/ansible.ul6qfbut", "secontext": "unconfined_u:object_r:user_tmp_t:s0", "size": 40, "state": "directory", "uid": 0 } TASK [Backup files] ************************************************************ task path: /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/backup.yml:13 Saturday 21 February 2026 16:21:08 -0500 (0:00:00.697) 0:00:04.616 ***** skipping: [managed-node2] => { "changed": false, "skipped_reason": "No items in the list" } TASK [Run role] **************************************************************** task path: /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/tests/ssh/tests_indentation.yml:11 Saturday 21 February 2026 16:21:08 -0500 (0:00:00.027) 0:00:04.643 ***** included: fedora.linux_system_roles.ssh for managed-node2 TASK [fedora.linux_system_roles.ssh : Set platform/version specific variables] *** task path: /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:2 Saturday 21 February 2026 16:21:08 -0500 (0:00:00.041) 0:00:04.685 ***** included: /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/set_vars.yml for managed-node2 TASK [fedora.linux_system_roles.ssh : Ensure ansible_facts used by role] ******* task path: /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/set_vars.yml:2 Saturday 21 February 2026 16:21:08 -0500 (0:00:00.026) 0:00:04.712 ***** skipping: [managed-node2] => { "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-2lu/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/set_vars.yml:10 Saturday 21 February 2026 16:21:08 -0500 (0:00:00.029) 0:00:04.742 ***** skipping: [managed-node2] => { "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-2lu/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/set_vars.yml:15 Saturday 21 February 2026 16:21:08 -0500 (0:00:00.017) 0:00:04.759 ***** skipping: [managed-node2] => { "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-2lu/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/set_vars.yml:22 Saturday 21 February 2026 16:21:09 -0500 (0:00:00.017) 0:00:04.776 ***** ok: [managed-node2] => { "changed": false, "stat": { "exists": false } } TASK [fedora.linux_system_roles.ssh : Set flag if transactional-update exists] *** task path: /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/set_vars.yml:27 Saturday 21 February 2026 16:21:09 -0500 (0:00:00.466) 0:00:05.243 ***** ok: [managed-node2] => { "ansible_facts": { "__ssh_is_transactional": false }, "changed": false } TASK [fedora.linux_system_roles.ssh : Set platform/version specific variables] *** task path: /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/set_vars.yml:31 Saturday 21 February 2026 16:21:09 -0500 (0:00:00.029) 0:00:05.272 ***** skipping: [managed-node2] => (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-node2] => (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-2lu/ansible_collections/fedora/linux_system_roles/roles/ssh/vars/Fedora.yml" ], "ansible_loop_var": "item", "changed": false, "item": "Fedora.yml" } skipping: [managed-node2] => (item=Fedora_43.yml) => { "ansible_loop_var": "item", "changed": false, "false_condition": "__vars_file is file", "item": "Fedora_43.yml", "skip_reason": "Conditional result was False" } skipping: [managed-node2] => (item=Fedora_43.yml) => { "ansible_loop_var": "item", "changed": false, "false_condition": "__vars_file is file", "item": "Fedora_43.yml", "skip_reason": "Conditional result was False" } TASK [fedora.linux_system_roles.ssh : Ensure required packages are installed] *** task path: /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:5 Saturday 21 February 2026 16:21:09 -0500 (0:00:00.049) 0:00:05.321 ***** ok: [managed-node2] => { "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-2lu/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:17 Saturday 21 February 2026 16:21:11 -0500 (0:00:01.491) 0:00:06.813 ***** skipping: [managed-node2] => { "false_condition": "__ssh_is_transactional | d(false)" } TASK [fedora.linux_system_roles.ssh : Reboot transactional update systems] ***** task path: /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:22 Saturday 21 February 2026 16:21:11 -0500 (0:00:00.029) 0:00:06.842 ***** skipping: [managed-node2] => { "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-2lu/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:27 Saturday 21 February 2026 16:21:11 -0500 (0:00:00.026) 0:00:06.869 ***** skipping: [managed-node2] => { "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-2lu/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:35 Saturday 21 February 2026 16:21:11 -0500 (0:00:00.025) 0:00:06.894 ***** skipping: [managed-node2] => { "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-2lu/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:42 Saturday 21 February 2026 16:21:11 -0500 (0:00:00.018) 0:00:06.912 ***** skipping: [managed-node2] => { "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-2lu/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:53 Saturday 21 February 2026 16:21:11 -0500 (0:00:00.018) 0:00:06.930 ***** changed: [managed-node2] => { "changed": true, "checksum": "0977fc11f2c5e1e5aa055031a2cd8fdd3c7dfb61", "dest": "/tmp/ssh_config", "gid": 0, "group": "root", "md5sum": "81adf401f8f8b9f3684259ace53b8f43", "mode": "0644", "owner": "root", "secontext": "unconfined_u:object_r:user_tmp_t:s0", "size": 306, "src": "/root/.ansible/tmp/ansible-tmp-1771708871.2429016-8874-208622863166346/.source", "state": "file", "uid": 0 } TASK [Download the global configuration file] ********************************** task path: /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/tests/ssh/tests_indentation.yml:42 Saturday 21 February 2026 16:21:12 -0500 (0:00:01.338) 0:00:08.269 ***** ok: [managed-node2] => { "changed": false, "content": "IwojIEFuc2libGUgbWFuYWdlZAojCiMgc3lzdGVtX3JvbGU6c3NoCgpGb3J3YXJkWDExIG5vCk1hdGNoIGFsbAogIEdTU0FQSUF1dGhlbnRpY2F0aW9uIHllcwogIFNlbmRFbnYgdGVzdDFfMQogIFNlbmRFbnYgdGVzdDFfMgpNYXRjaCBleGVjIHRydWUKICBVc2VyIG5vYm9keQpIb3N0IGV4YW1wbGUKICBIb3N0bmFtZSBleGFtcGxlLmNvbQogIFNlbmRFbnYgdGVzdDJfMQogIFNlbmRFbnYgdGVzdDJfMgpIb3N0IGxvY2FsCiAgSG9zdG5hbWUgbG9jYWwuZXhhbXBsZS5jb20KICBTZW5kRW52IHRlc3QzXzEKICBTZW5kRW52IHRlc3QzXzIK", "encoding": "base64", "source": "/tmp/ssh_config" } TASK [Verify the options are in the file] ************************************** task path: /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/tests/ssh/tests_indentation.yml:47 Saturday 21 February 2026 16:21:13 -0500 (0:00:00.735) 0:00:09.004 ***** ok: [managed-node2] => { "changed": false } MSG: All assertions passed TASK [Restore configuration files] ********************************************* task path: /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/tests/ssh/tests_indentation.yml:68 Saturday 21 February 2026 16:21:13 -0500 (0:00:00.063) 0:00:09.067 ***** included: /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/restore.yml for managed-node2 TASK [Restore backed up files and remove what was not present] ***************** task path: /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/restore.yml:2 Saturday 21 February 2026 16:21:13 -0500 (0:00:00.021) 0:00:09.088 ***** skipping: [managed-node2] => { "changed": false, "skipped_reason": "No items in the list" } TASK [Remove temporary directory for backup files] ***************************** task path: /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/restore.yml:15 Saturday 21 February 2026 16:21:13 -0500 (0:00:00.028) 0:00:09.116 ***** ok: [managed-node2] => { "changed": false, "path": "/tmp/ansible.ul6qfbut", "state": "absent" } PLAY RECAP ********************************************************************* managed-node2 : ok=20 changed=1 unreachable=0 failed=0 skipped=11 rescued=0 ignored=0 SYSTEM ROLES ERRORS BEGIN v1 [] SYSTEM ROLES ERRORS END v1 TASKS RECAP ******************************************************************** Saturday 21 February 2026 16:21:14 -0500 (0:00:00.651) 0:00:09.767 ***** =============================================================================== Make sure openssh is installed before creating backup ------------------- 1.70s /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/setup.yml:19 fedora.linux_system_roles.ssh : Ensure required packages are installed --- 1.49s /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:5 fedora.linux_system_roles.ssh : Generate the configuration file --------- 1.34s /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:53 Gathering Facts --------------------------------------------------------- 1.28s /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/tests/ssh/tests_indentation.yml:2 Download the global configuration file ---------------------------------- 0.74s /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/tests/ssh/tests_indentation.yml:42 Create a temporary directory for backup files --------------------------- 0.70s /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/backup.yml:5 Check if system is ostree ----------------------------------------------- 0.67s /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/setup.yml:10 Remove temporary directory for backup files ----------------------------- 0.65s /tmp/collections-2lu/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.47s /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/set_vars.yml:22 Set flag to indicate system is ostree ----------------------------------- 0.06s /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/setup.yml:15 Verify the options are in the file -------------------------------------- 0.06s /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/tests/ssh/tests_indentation.yml:47 fedora.linux_system_roles.ssh : Set platform/version specific variables --- 0.05s /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/set_vars.yml:31 Define specific variables ----------------------------------------------- 0.05s /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/setup.yml:37 Run role ---------------------------------------------------------------- 0.04s /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/tests/ssh/tests_indentation.yml:11 Setup ------------------------------------------------------------------- 0.04s /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/backup.yml:2 Backup configuration files ---------------------------------------------- 0.03s /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/tests/ssh/tests_indentation.yml:8 fedora.linux_system_roles.ssh : Ensure ansible_facts used by role ------- 0.03s /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/set_vars.yml:2 fedora.linux_system_roles.ssh : Notify user that reboot is needed to apply changes --- 0.03s /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/main.yml:17 fedora.linux_system_roles.ssh : Set flag if transactional-update exists --- 0.03s /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/roles/ssh/tasks/set_vars.yml:27 Restore backed up files and remove what was not present ----------------- 0.03s /tmp/collections-2lu/ansible_collections/fedora/linux_system_roles/tests/ssh/tasks/restore.yml:2