# STDOUT: ---v---v---v---v---v--- ansible-playbook [core 2.17.2] config file = /etc/ansible/ansible.cfg configured module search path = ['/home/jenkins/.ansible/plugins/modules', '/usr/share/ansible/plugins/modules'] ansible python module location = /opt/ansible-2.17/lib/python3.11/site-packages/ansible ansible collection location = /WORKDIR/git-route_srce6krps99/.collection executable location = /opt/ansible-2.17/bin/ansible-playbook python version = 3.11.5 (main, Sep 7 2023, 00:00:00) [GCC 11.4.1 20230605 (Red Hat 11.4.1-2)] (/opt/ansible-2.17/bin/python) jinja version = 3.1.4 libyaml = True Using /etc/ansible/ansible.cfg as config file Skipping callback 'debug', 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_unit.yml ******************************************************* 2 plays in /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml PLAY [Setup for test running] ************************************************** TASK [Gathering Facts] ********************************************************* task path: /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:3 Sunday 04 August 2024 17:21:53 +0000 (0:00:00.022) 0:00:00.022 ********* ok: [sut] TASK [Include the task 'el_repo_setup.yml'] ************************************ task path: /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:6 Sunday 04 August 2024 17:21:53 +0000 (0:00:00.802) 0:00:00.825 ********* included: /WORKDIR/git-route_srce6krps99/tests/tasks/el_repo_setup.yml for sut TASK [Gather the minimum subset of ansible_facts required by the network role test] *** task path: /WORKDIR/git-route_srce6krps99/tests/tasks/el_repo_setup.yml:3 Sunday 04 August 2024 17:21:53 +0000 (0:00:00.010) 0:00:00.835 ********* ok: [sut] TASK [Check if system is ostree] *********************************************** task path: /WORKDIR/git-route_srce6krps99/tests/tasks/el_repo_setup.yml:17 Sunday 04 August 2024 17:21:54 +0000 (0:00:00.303) 0:00:01.138 ********* ok: [sut] => { "changed": false, "stat": { "exists": false } } TASK [Set flag to indicate system is ostree] *********************************** task path: /WORKDIR/git-route_srce6krps99/tests/tasks/el_repo_setup.yml:22 Sunday 04 August 2024 17:21:54 +0000 (0:00:00.227) 0:00:01.366 ********* ok: [sut] => { "ansible_facts": { "__network_is_ostree": false }, "changed": false } TASK [Fix CentOS6 Base repo] *************************************************** task path: /WORKDIR/git-route_srce6krps99/tests/tasks/el_repo_setup.yml:26 Sunday 04 August 2024 17:21:54 +0000 (0:00:00.013) 0:00:01.380 ********* skipping: [sut] => { "changed": false, "false_condition": "ansible_distribution_major_version == '6'", "skip_reason": "Conditional result was False" } TASK [Include the task 'enable_epel.yml'] ************************************** task path: /WORKDIR/git-route_srce6krps99/tests/tasks/el_repo_setup.yml:51 Sunday 04 August 2024 17:21:54 +0000 (0:00:00.010) 0:00:01.390 ********* included: /WORKDIR/git-route_srce6krps99/tests/tasks/enable_epel.yml for sut TASK [Create EPEL 9] *********************************************************** task path: /WORKDIR/git-route_srce6krps99/tests/tasks/enable_epel.yml:8 Sunday 04 August 2024 17:21:54 +0000 (0:00:00.019) 0:00:01.410 ********* skipping: [sut] => { "changed": false, "false_condition": "ansible_distribution_major_version in ['7', '8']", "skip_reason": "Conditional result was False" } TASK [Install yum-utils package] *********************************************** task path: /WORKDIR/git-route_srce6krps99/tests/tasks/enable_epel.yml:24 Sunday 04 August 2024 17:21:54 +0000 (0:00:00.010) 0:00:01.420 ********* skipping: [sut] => { "changed": false, "false_condition": "ansible_distribution_major_version in ['7', '8']", "skip_reason": "Conditional result was False" } TASK [Enable EPEL 7] *********************************************************** task path: /WORKDIR/git-route_srce6krps99/tests/tasks/enable_epel.yml:30 Sunday 04 August 2024 17:21:54 +0000 (0:00:00.010) 0:00:01.431 ********* skipping: [sut] => { "changed": false, "false_condition": "ansible_distribution_major_version in ['7', '8']", "skip_reason": "Conditional result was False" } TASK [Enable EPEL 8] *********************************************************** task path: /WORKDIR/git-route_srce6krps99/tests/tasks/enable_epel.yml:35 Sunday 04 August 2024 17:21:54 +0000 (0:00:00.014) 0:00:01.445 ********* skipping: [sut] => { "changed": false, "false_condition": "ansible_distribution_major_version in ['7', '8']", "skip_reason": "Conditional result was False" } TASK [Enable EPEL 6] *********************************************************** task path: /WORKDIR/git-route_srce6krps99/tests/tasks/enable_epel.yml:40 Sunday 04 August 2024 17:21:54 +0000 (0:00:00.008) 0:00:01.454 ********* skipping: [sut] => { "changed": false, "false_condition": "ansible_distribution_major_version == '6'", "skip_reason": "Conditional result was False" } TASK [Install dependencies] **************************************************** task path: /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:9 Sunday 04 August 2024 17:21:54 +0000 (0:00:00.008) 0:00:01.462 ********* ok: [sut] => (item=NetworkManager-libnm) => { "ansible_loop_var": "item", "changed": false, "item": "NetworkManager-libnm", "rc": 0, "results": [] } MSG: Nothing to do failed: [sut] (item=python2-gobject-base) => { "ansible_loop_var": "item", "changed": false, "failures": [ "No package python2-gobject-base available." ], "item": "python2-gobject-base", "rc": 1, "results": [] } MSG: Failed to install some of the specified packages ok: [sut] => (item=python3-gobject-base) => { "ansible_loop_var": "item", "changed": false, "item": "python3-gobject-base", "rc": 0, "results": [] } MSG: Nothing to do ok: [sut] => (item=python-gobject-base) => { "ansible_loop_var": "item", "changed": false, "item": "python-gobject-base", "rc": 0, "results": [] } MSG: Nothing to do failed: [sut] (item=python2-mock) => { "ansible_loop_var": "item", "changed": false, "failures": [ "No package python2-mock available." ], "item": "python2-mock", "rc": 1, "results": [] } MSG: Failed to install some of the specified packages ...ignoring PLAY [Execute python unit tests] *********************************************** TASK [Gathering Facts] ********************************************************* task path: /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:23 Sunday 04 August 2024 17:21:58 +0000 (0:00:03.829) 0:00:05.291 ********* ok: [sut] TASK [Create tempdir for code to test] ***************************************** task path: /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:28 Sunday 04 August 2024 17:21:58 +0000 (0:00:00.578) 0:00:05.869 ********* changed: [sut] => { "changed": true, "gid": 0, "group": "root", "mode": "0700", "owner": "root", "path": "/tmp/lsrtest_0v_opbxw", "secontext": "unconfined_u:object_r:user_tmp_t:s0", "size": 6, "state": "directory", "uid": 0 } TASK [Get tempfile for tar] **************************************************** task path: /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:34 Sunday 04 August 2024 17:21:59 +0000 (0:00:00.218) 0:00:06.088 ********* changed: [sut -> localhost] => { "changed": true, "gid": 1001, "group": "jenkins", "mode": "0600", "owner": "jenkins", "path": "/tmp/lsrtest_2g2f7ot6.tar", "size": 0, "state": "file", "uid": 1000090000 } TASK [Include the task 'get_modules_and_utils_paths.yml'] ********************** task path: /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:41 Sunday 04 August 2024 17:21:59 +0000 (0:00:00.133) 0:00:06.222 ********* included: /WORKDIR/git-route_srce6krps99/tests/tasks/get_modules_and_utils_paths.yml for sut TASK [Set collection paths] **************************************************** task path: /WORKDIR/git-route_srce6krps99/tests/tasks/get_modules_and_utils_paths.yml:3 Sunday 04 August 2024 17:21:59 +0000 (0:00:00.019) 0:00:06.241 ********* ok: [sut] => { "ansible_facts": { "collection_paths": [ "/WORKDIR/git-route_srce6krps99/.collection", "/WORKDIR/git-route_srce6krps99/.collection" ] }, "changed": false } TASK [Set search paths] ******************************************************** task path: /WORKDIR/git-route_srce6krps99/tests/tasks/get_modules_and_utils_paths.yml:13 Sunday 04 August 2024 17:21:59 +0000 (0:00:00.017) 0:00:06.259 ********* ok: [sut] => { "ansible_facts": { "module_utils_search_path": [ "../../module_utils", "../module_utils", "/home/jenkins/.ansible/plugins/module_utils", "/usr/share/ansible/plugins/module_utils" ], "modules_search_path": [ "../../library", "../library", "/home/jenkins/.ansible/plugins/modules", "/usr/share/ansible/plugins/modules" ] }, "changed": false } TASK [Find parent directory and path of modules] ******************************* task path: /WORKDIR/git-route_srce6krps99/tests/tasks/get_modules_and_utils_paths.yml:42 Sunday 04 August 2024 17:21:59 +0000 (0:00:00.021) 0:00:06.280 ********* ok: [sut -> localhost] => { "changed": false, "cmd": "set -euxo pipefail\nfor dir in ../../library ../library /home/jenkins/.ansible/plugins/modules /usr/share/ansible/plugins/modules; do\n if [ -f \"$dir/network_connections.py\" ]; then\n readlink -f \"$(dirname \"$dir\")\"\n basename \"$dir\"\n exit 0\n fi\ndone\nfor dir in /WORKDIR/git-route_srce6krps99/.collection /WORKDIR/git-route_srce6krps99/.collection; do\n if [ ! -d \"$dir\" ]; then continue; fi\n cd \"$dir\"\n for subdir in ansible_collections/*/*/plugins/modules; do\n if [ -f \"$subdir/network_connections.py\" ]; then\n echo \"$dir\"\n echo \"$subdir\"\n exit 0\n fi\n done\ndone\necho network_connections.py not found\nexit 1\n", "delta": "0:00:00.005314", "end": "2024-08-04 17:21:59.569523", "rc": 0, "start": "2024-08-04 17:21:59.564209" } STDOUT: /WORKDIR/git-route_srce6krps99 library STDERR: + for dir in ../../library ../library /home/jenkins/.ansible/plugins/modules /usr/share/ansible/plugins/modules + '[' -f ../../library/network_connections.py ']' + for dir in ../../library ../library /home/jenkins/.ansible/plugins/modules /usr/share/ansible/plugins/modules + '[' -f ../library/network_connections.py ']' ++ dirname ../library + readlink -f .. + basename ../library + exit 0 TASK [Find parent directory and path of module_utils] ************************** task path: /WORKDIR/git-route_srce6krps99/tests/tasks/get_modules_and_utils_paths.yml:69 Sunday 04 August 2024 17:21:59 +0000 (0:00:00.187) 0:00:06.467 ********* ok: [sut -> localhost] => { "changed": false, "cmd": "set -euxo pipefail\nfor dir in ../../module_utils ../module_utils /home/jenkins/.ansible/plugins/module_utils /usr/share/ansible/plugins/module_utils; do\n if [ -d \"$dir/network_lsr\" ]; then\n readlink -f \"$(dirname \"$dir\")\"\n basename \"$dir\"\n exit 0\n fi\ndone\nfor dir in /WORKDIR/git-route_srce6krps99/.collection /WORKDIR/git-route_srce6krps99/.collection; do\n if [ ! -d \"$dir\" ]; then continue; fi\n cd \"$dir\"\n for subdir in ansible_collections/*/*/plugins/module_utils; do\n if [ -d \"$subdir/network_lsr\" ]; then\n echo \"$dir\"\n echo \"$subdir\"\n exit 0\n fi\n done\ndone\necho network_lsr not found\nexit 1\n", "delta": "0:00:00.005350", "end": "2024-08-04 17:21:59.697471", "rc": 0, "start": "2024-08-04 17:21:59.692121" } STDOUT: /WORKDIR/git-route_srce6krps99 module_utils STDERR: + for dir in ../../module_utils ../module_utils /home/jenkins/.ansible/plugins/module_utils /usr/share/ansible/plugins/module_utils + '[' -d ../../module_utils/network_lsr ']' + for dir in ../../module_utils ../module_utils /home/jenkins/.ansible/plugins/module_utils /usr/share/ansible/plugins/module_utils + '[' -d ../module_utils/network_lsr ']' ++ dirname ../module_utils + readlink -f .. + basename ../module_utils + exit 0 TASK [Create Tar file] ********************************************************* task path: /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:48 Sunday 04 August 2024 17:21:59 +0000 (0:00:00.128) 0:00:06.596 ********* ok: [sut -> localhost] => { "changed": false, "cmd": [ "tar", "-cvf", "/tmp/lsrtest_2g2f7ot6.tar", "--exclude", "*.pyc", "--exclude", "__pycache__", "-C", "/WORKDIR/git-route_srce6krps99", "library", "-C", "/WORKDIR/git-route_srce6krps99", "module_utils" ], "delta": "0:00:00.002714", "end": "2024-08-04 17:21:59.821918", "rc": 0, "start": "2024-08-04 17:21:59.819204" } STDOUT: library/ library/__init__.py library/network_connections.py library/network_state.py module_utils/ module_utils/network_lsr/ module_utils/network_lsr/__init__.py module_utils/network_lsr/argument_validator.py module_utils/network_lsr/ethtool.py module_utils/network_lsr/myerror.py module_utils/network_lsr/nm/ module_utils/network_lsr/nm/__init__.py module_utils/network_lsr/nm/active_connection.py module_utils/network_lsr/nm/client.py module_utils/network_lsr/nm/connection.py module_utils/network_lsr/nm/error.py module_utils/network_lsr/nm/provider.py module_utils/network_lsr/nm_provider.py module_utils/network_lsr/utils.py TASK [Copy testrepo.tar to the remote system] ********************************** task path: /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:60 Sunday 04 August 2024 17:21:59 +0000 (0:00:00.122) 0:00:06.718 ********* changed: [sut] => { "changed": true, "checksum": "2c9cfc24549871417d1d42688820995382284303", "dest": "/tmp/lsrtest_0v_opbxw/lsrtest_2g2f7ot6.tar", "gid": 0, "group": "root", "md5sum": "bdee8a74651a4ec65819b04a85f40fc1", "mode": "0600", "owner": "root", "secontext": "unconfined_u:object_r:admin_home_t:s0", "size": 266240, "src": "/root/.ansible/tmp/ansible-tmp-1722792119.8675277-11488-32094041879450/.source.tar", "state": "file", "uid": 0 } TASK [Untar testrepo.tar] ****************************************************** task path: /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:66 Sunday 04 August 2024 17:22:00 +0000 (0:00:00.688) 0:00:07.407 ********* changed: [sut] => { "changed": true, "dest": "/tmp/lsrtest_0v_opbxw", "extract_results": { "cmd": [ "/usr/bin/gtar", "--extract", "-C", "/tmp/lsrtest_0v_opbxw", "-f", "/tmp/lsrtest_0v_opbxw/lsrtest_2g2f7ot6.tar" ], "err": "", "out": "", "rc": 0 }, "gid": 0, "group": "root", "handler": "TarArchive", "mode": "0700", "owner": "root", "secontext": "unconfined_u:object_r:user_tmp_t:s0", "size": 69, "src": "/tmp/lsrtest_0v_opbxw/lsrtest_2g2f7ot6.tar", "state": "directory", "uid": 0 } TASK [Create subdirectory '/ansible/module_utils' under '/tmp/lsrtest_0v_opbxw'] *** task path: /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:72 Sunday 04 August 2024 17:22:01 +0000 (0:00:00.710) 0:00:08.117 ********* changed: [sut] => (item=/tmp/lsrtest_0v_opbxw/ansible) => { "ansible_loop_var": "item", "changed": true, "gid": 0, "group": "root", "item": "/tmp/lsrtest_0v_opbxw/ansible", "mode": "0755", "owner": "root", "path": "/tmp/lsrtest_0v_opbxw/ansible", "secontext": "unconfined_u:object_r:user_tmp_t:s0", "size": 6, "state": "directory", "uid": 0 } changed: [sut] => (item=/tmp/lsrtest_0v_opbxw/ansible/module_utils) => { "ansible_loop_var": "item", "changed": true, "gid": 0, "group": "root", "item": "/tmp/lsrtest_0v_opbxw/ansible/module_utils", "mode": "0755", "owner": "root", "path": "/tmp/lsrtest_0v_opbxw/ansible/module_utils", "secontext": "unconfined_u:object_r:user_tmp_t:s0", "size": 6, "state": "directory", "uid": 0 } TASK [Move module_utils to ansible directory] ********************************** task path: /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:81 Sunday 04 August 2024 17:22:01 +0000 (0:00:00.410) 0:00:08.528 ********* ok: [sut] => { "changed": false, "cmd": "if [ -d /tmp/lsrtest_0v_opbxw/module_utils ]; then\n mv /tmp/lsrtest_0v_opbxw/module_utils /tmp/lsrtest_0v_opbxw/ansible\nfi\n", "delta": "0:00:00.005072", "end": "2024-08-04 17:22:01.802680", "rc": 0, "start": "2024-08-04 17:22:01.797608" } TASK [Fake out python module directories, primarily for python2] *************** task path: /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:88 Sunday 04 August 2024 17:22:01 +0000 (0:00:00.175) 0:00:08.703 ********* ok: [sut] => { "changed": false, "cmd": "for dir in $(find /tmp/lsrtest_0v_opbxw -type d -print); do\n if [ ! -f \"$dir/__init__.py\" ]; then\n touch \"$dir/__init__.py\"\n fi\ndone\n", "delta": "0:00:00.007858", "end": "2024-08-04 17:22:01.979262", "rc": 0, "start": "2024-08-04 17:22:01.971404" } TASK [Copy unit test to remote system] ***************************************** task path: /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:97 Sunday 04 August 2024 17:22:01 +0000 (0:00:00.176) 0:00:08.880 ********* changed: [sut] => { "changed": true, "checksum": "4beffbbd8f24981d7e5d9d43902edecc08a02d14", "dest": "/tmp/lsrtest_0v_opbxw/test_network_connections.py", "gid": 0, "group": "root", "md5sum": "d546c14dfad46533087375e8f45123bd", "mode": "0644", "owner": "root", "secontext": "unconfined_u:object_r:admin_home_t:s0", "size": 206866, "src": "/root/.ansible/tmp/ansible-tmp-1722792122.028804-11543-255361484458100/.source.py", "state": "file", "uid": 0 } TASK [Set _lsr_python_path] **************************************************** task path: /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:103 Sunday 04 August 2024 17:22:02 +0000 (0:00:00.616) 0:00:09.496 ********* ok: [sut] => { "ansible_facts": { "_lsr_python_path": "/tmp/lsrtest_0v_opbxw/library:/tmp/lsrtest_0v_opbxw/ansible/module_utils:/tmp/lsrtest_0v_opbxw/module_utils:/tmp/lsrtest_0v_opbxw" }, "changed": false } TASK [List the files in /tmp/lsrtest_0v_opbxw] ********************************* task path: /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:107 Sunday 04 August 2024 17:22:02 +0000 (0:00:00.011) 0:00:09.508 ********* ok: [sut] => { "changed": false, "cmd": [ "ls", "-alrtFR", "/tmp/lsrtest_0v_opbxw" ], "delta": "0:00:00.005938", "end": "2024-08-04 17:22:02.789360", "rc": 0, "start": "2024-08-04 17:22:02.783422" } STDOUT: /tmp/lsrtest_0v_opbxw: total 468 drwxr-xr-x. 2 1000090000 1001 79 Aug 4 17:06 library/ -rw-------. 1 root root 266240 Aug 4 17:22 lsrtest_2g2f7ot6.tar -rw-r--r--. 1 root root 0 Aug 4 17:22 __init__.py drwxr-xr-x. 3 root root 45 Aug 4 17:22 ansible/ -rw-r--r--. 1 root root 206866 Aug 4 17:22 test_network_connections.py drwx------. 4 root root 118 Aug 4 17:22 ./ drwxrwxrwt. 14 root root 4096 Aug 4 17:22 ../ /tmp/lsrtest_0v_opbxw/library: total 112 -rw-r--r--. 1 1000090000 1001 2736 Aug 4 17:06 network_state.py -rw-r--r--. 1 1000090000 1001 107272 Aug 4 17:06 network_connections.py -rw-r--r--. 1 1000090000 1001 0 Aug 4 17:06 __init__.py drwxr-xr-x. 2 1000090000 1001 79 Aug 4 17:06 ./ drwx------. 4 root root 118 Aug 4 17:22 ../ /tmp/lsrtest_0v_opbxw/ansible: total 0 -rw-r--r--. 1 root root 0 Aug 4 17:22 __init__.py drwxr-xr-x. 3 root root 45 Aug 4 17:22 ./ drwxr-xr-x. 3 1000090000 1001 44 Aug 4 17:22 module_utils/ drwx------. 4 root root 118 Aug 4 17:22 ../ /tmp/lsrtest_0v_opbxw/ansible/module_utils: total 0 drwxr-xr-x. 3 1000090000 1001 138 Aug 4 17:06 network_lsr/ drwxr-xr-x. 3 root root 45 Aug 4 17:22 ../ -rw-r--r--. 1 root root 0 Aug 4 17:22 __init__.py drwxr-xr-x. 3 1000090000 1001 44 Aug 4 17:22 ./ /tmp/lsrtest_0v_opbxw/ansible/module_utils/network_lsr: total 136 -rw-r--r--. 1 1000090000 1001 11387 Aug 4 17:06 utils.py -rw-r--r--. 1 1000090000 1001 1594 Aug 4 17:06 nm_provider.py drwxr-xr-x. 2 1000090000 1001 126 Aug 4 17:06 nm/ -rw-r--r--. 1 1000090000 1001 190 Aug 4 17:06 myerror.py -rw-r--r--. 1 1000090000 1001 0 Aug 4 17:06 __init__.py -rw-r--r--. 1 1000090000 1001 1839 Aug 4 17:06 ethtool.py -rw-r--r--. 1 1000090000 1001 110662 Aug 4 17:06 argument_validator.py drwxr-xr-x. 3 1000090000 1001 138 Aug 4 17:06 ./ drwxr-xr-x. 3 1000090000 1001 44 Aug 4 17:22 ../ /tmp/lsrtest_0v_opbxw/ansible/module_utils/network_lsr/nm: total 20 -rw-r--r--. 1 1000090000 1001 3154 Aug 4 17:06 provider.py -rw-r--r--. 1 1000090000 1001 0 Aug 4 17:06 __init__.py -rw-r--r--. 1 1000090000 1001 175 Aug 4 17:06 error.py -rw-r--r--. 1 1000090000 1001 3546 Aug 4 17:06 connection.py -rw-r--r--. 1 1000090000 1001 3025 Aug 4 17:06 client.py -rw-r--r--. 1 1000090000 1001 4012 Aug 4 17:06 active_connection.py drwxr-xr-x. 3 1000090000 1001 138 Aug 4 17:06 ../ drwxr-xr-x. 2 1000090000 1001 126 Aug 4 17:06 ./ TASK [Debug the lsr Python path] *********************************************** task path: /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:110 Sunday 04 August 2024 17:22:02 +0000 (0:00:00.180) 0:00:09.689 ********* ok: [sut] => {} MSG: path /tmp/lsrtest_0v_opbxw/library:/tmp/lsrtest_0v_opbxw/ansible/module_utils:/tmp/lsrtest_0v_opbxw/module_utils:/tmp/lsrtest_0v_opbxw TASK [Check if python2 is available] ******************************************* task path: /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:114 Sunday 04 August 2024 17:22:02 +0000 (0:00:00.009) 0:00:09.699 ********* fatal: [sut]: FAILED! => { "changed": false, "cmd": "python2 --version", "rc": 2 } MSG: [Errno 2] No such file or directory: b'python2' ...ignoring TASK [Run python2 unit tests] ************************************************** task path: /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:121 Sunday 04 August 2024 17:22:02 +0000 (0:00:00.164) 0:00:09.864 ********* skipping: [sut] => { "changed": false, "false_condition": "python2_available is succeeded and ansible_distribution != 'Fedora'\n", "skip_reason": "Conditional result was False" } TASK [Check if python3 is available] ******************************************* task path: /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:131 Sunday 04 August 2024 17:22:02 +0000 (0:00:00.010) 0:00:09.874 ********* ok: [sut] => { "changed": false, "cmd": [ "python3", "--version" ], "delta": "0:00:00.003389", "end": "2024-08-04 17:22:03.141727", "rc": 0, "start": "2024-08-04 17:22:03.138338" } STDOUT: Python 3.9.19 TASK [Run python3 unit tests] ************************************************** task path: /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:138 Sunday 04 August 2024 17:22:03 +0000 (0:00:00.166) 0:00:10.041 ********* fatal: [sut]: FAILED! => { "changed": false, "cmd": [ "python3", "/tmp/lsrtest_0v_opbxw/test_network_connections.py", "--verbose" ], "delta": "0:00:00.316533", "end": "2024-08-04 17:22:03.629628", "rc": 1, "start": "2024-08-04 17:22:03.313095" } STDERR: test_connection_ensure_setting (__main__.TestNM) ... ok test_connection_list (__main__.TestNM) ... ok test_path_to_glib_bytes (__main__.TestNM) ... ok test_link_read_permaddress (__main__.TestSysUtils) ... ok test_convert_passwd_flags_nm (__main__.TestUtils) ... ok test_mac_ntoa (__main__.TestUtils) ... ok test_802_1x_1 (__main__.TestValidator) Test private key with password ... ok test_802_1x_2 (__main__.TestValidator) Test 802.1x profile with unencrypted private key, ... ok test_802_1x_3 (__main__.TestValidator) Test 802.1x profile with unencrypted private key and ca_path ... ok test_802_1x_ca_path_and_system_ca_certs (__main__.TestValidator) should fail if ca_path and system_ca_certs are used together ... ok test_802_1x_initscripts (__main__.TestValidator) should fail to create ieee802_1x connection with initscripts ... ok test_802_1x_unsupported_type (__main__.TestValidator) should fail if a non ethernet/wireless connection has 802.1x settings defined ... ok test_absent (__main__.TestValidator) ... ok test_auto6_enabled_ipv6_disabled (__main__.TestValidator) Test that enabling `auto6` and disabling IPv6 are mutually exclusive. ... ok test_auto_gateway_false (__main__.TestValidator) ... ok test_auto_gateway_no_gateway (__main__.TestValidator) ... ok test_auto_gateway_true (__main__.TestValidator) ... ok test_bond (__main__.TestValidator) ... ok test_bond_active_backup (__main__.TestValidator) ... ok test_bridge2 (__main__.TestValidator) ... ok test_bridge_no_dhcp4_auto6 (__main__.TestValidator) ... ok test_default_states (__main__.TestValidator) ... ok test_default_states_type (__main__.TestValidator) ... ok test_deprecated_ethtool_names (__main__.TestValidator) Test that for each validator in ... ok test_dns_options_argvalidator (__main__.TestValidator) Test that argvalidator for validating dns_options value is correctly defined. ... ok test_dns_search_without_ipv4_and_ipv6_configuration (__main__.TestValidator) Test that configuring DNS search setting is not allowed when both IPv4 and ... ok test_empty (__main__.TestValidator) ... ok test_ethernet_mac_address (__main__.TestValidator) ... ok test_ethernet_speed_settings (__main__.TestValidator) ... ok test_ethernet_two_defaults (__main__.TestValidator) ... ok test_full_state_absent_defaults (__main__.TestValidator) ... ok test_full_state_absent_no_type (__main__.TestValidator) ... ok test_full_state_present_no_type (__main__.TestValidator) ... ok test_full_state_present_type_defaults (__main__.TestValidator) ... ok test_gateway6_configured_ipv6_disabled (__main__.TestValidator) Test that configuring `gateway6` and disabling IPv6 are mutually exclusive. ... ok test_infiniband (__main__.TestValidator) ... ok test_infiniband2 (__main__.TestValidator) ... ok test_infiniband3 (__main__.TestValidator) ... ok test_interface_name_bond_empty_interface_name (__main__.TestValidator) ... ok test_interface_name_bond_profile_as_interface_name (__main__.TestValidator) ... ok test_interface_name_ethernet_None (__main__.TestValidator) Check that interface_name cannot be None ... ok test_interface_name_ethernet_default (__main__.TestValidator) Use the profile name as interface_name for ethernet profiles ... ok test_interface_name_ethernet_empty (__main__.TestValidator) Allow not to restrict the profile to an interface ... ok test_interface_name_ethernet_explicit (__main__.TestValidator) Use the explicitly provided interface name ... ok test_interface_name_ethernet_invalid_interface_name (__main__.TestValidator) ... ok test_interface_name_ethernet_invalid_profile (__main__.TestValidator) Require explicit interface_name when the profile name is not a ... ok test_interface_name_ethernet_mac (__main__.TestValidator) Do not set interface_name when mac is specified ... ok test_invalid_autoconnect (__main__.TestValidator) ... ok test_invalid_cert_path (__main__.TestValidator) should fail if a relative path is used for 802.1x certs/keys ... ok test_invalid_ethtool_settings (__main__.TestValidator) When both the deprecated and current version of a feature are stated, ... ok test_invalid_mac (__main__.TestValidator) ... ok test_invalid_password_flag (__main__.TestValidator) should fail if an invalid private key password flag is set ... ok test_invalid_persistent_state_down (__main__.TestValidator) ... ok test_invalid_persistent_state_up (__main__.TestValidator) ... ok test_invalid_state_test (__main__.TestValidator) ... ok test_invalid_values (__main__.TestValidator) ... ok test_ipv4_dns_without_ipv4_config (__main__.TestValidator) Test that configuring IPv4 DNS is not allowed when IPv4 is disabled. ... ok test_ipv6_dns_options_without_ipv6_config (__main__.TestValidator) Test that configuring IPv6 DNS options is not allowed when IPv6 is disabled. ... ok test_ipv6_dns_with_ipv6_disabled (__main__.TestValidator) Test that configuring IPv6 DNS is not allowed when IPv6 is disabled. ... ok test_ipv6_dns_with_static_ipv6_configuration (__main__.TestValidator) Test that configuring IPv6 DNS is allowed when static IPv6 is configured. ... ok test_ipv6_dns_without_ipv6_configuration (__main__.TestValidator) Test that configuring IPv6 DNS is not allowed when IPv6 is not configured. ... ok test_ipv6_static (__main__.TestValidator) ... ok test_macvlan (__main__.TestValidator) ... ok test_persistent_state_absent (__main__.TestValidator) ... ok test_persistent_state_present (__main__.TestValidator) ... ok test_route_metric6_configured_ipv6_disabled (__main__.TestValidator) Test that configuring `route_metric6` and disabling IPv6 are mutually ... ok test_route_metric_prefix (__main__.TestValidator) ... ok test_route_v6 (__main__.TestValidator) ... FAIL test_route_without_interface_name (__main__.TestValidator) ... FAIL test_routes (__main__.TestValidator) ... ok test_set_deprecated_ethtool_feature (__main__.TestValidator) When passing a deprecated name, their current version is updated. ... ok test_set_deprecated_master (__main__.TestValidator) wokeignore:rule=master ... ok test_set_deprecated_slave_type (__main__.TestValidator) wokeignore:rule=slave ... ok test_set_ethtool_feature (__main__.TestValidator) When passing the name of an non-deprecated ethtool feature, their ... ok test_state_absent (__main__.TestValidator) ... ok test_state_absent_down (__main__.TestValidator) ... ok test_state_absent_up_no_type (__main__.TestValidator) ... ok test_state_absent_up_type (__main__.TestValidator) ... ok test_state_down_no_type (__main__.TestValidator) ... ok test_state_present (__main__.TestValidator) ... ok test_state_present_down (__main__.TestValidator) ... ok test_state_present_up (__main__.TestValidator) ... ok test_state_up_no_type (__main__.TestValidator) ... ok test_state_up_type (__main__.TestValidator) ... ok test_static_ipv6_configured_ipv6_disabled (__main__.TestValidator) Test that configuring static IPv6 and disabling IPv6 are mutually exclusive. ... ok test_up_ethernet (__main__.TestValidator) ... ok test_up_ethernet_mac_mtu_static_ip (__main__.TestValidator) ... ok test_up_ethernet_no_autoconnect (__main__.TestValidator) ... ok test_up_single_v4_dns (__main__.TestValidator) ... ok test_valid_persistent_state (__main__.TestValidator) Test that when persistent_state is present and state is set to present ... ok test_validate_allow_empty_string_in_list (__main__.TestValidator) Test that when ArgValidatorStr.allow_empty is True, empty string is allowed in ... ok test_validate_bool (__main__.TestValidator) ... ok test_validate_dict (__main__.TestValidator) ... ok test_validate_disallow_none_in_list (__main__.TestValidator) Test that None is not allowed in ArgValidatorList ... ok test_validate_ignore_auto_dns (__main__.TestValidator) Test and validate a connection profile with ipv4_ignore_auto_dns and ... ok test_validate_int (__main__.TestValidator) ... ok test_validate_list (__main__.TestValidator) ... ok test_validate_list_remove_none_or_empty (__main__.TestValidator) Test that when ArgValidatorStr.remove_none_or_empty is True, None or empty ... ok test_validate_range (__main__.TestValidator) ... ok test_validate_str (__main__.TestValidator) ... ok test_vlan (__main__.TestValidator) ... ok test_wireless_eap (__main__.TestValidator) Test wireless connection with wpa-eap ... ok test_wireless_initscripts (__main__.TestValidator) should fail to create wireless connection with initscripts ... ok test_wireless_no_802_1x_for_wpa_eap (__main__.TestValidator) should fail if no 802.1x parameters are defined for a wireless ... ok test_wireless_no_options_defined (__main__.TestValidator) should fail if a connection of type='wireless' does not ... ok test_wireless_no_password (__main__.TestValidator) should fail if wpa-psk is selected and no password provided ... ok test_wireless_password_too_long (__main__.TestValidator) should fail if wpa-psk is selected and no password provided ... ok test_wireless_psk (__main__.TestValidator) Test wireless connection with wpa-psk auth ... ok test_wireless_ssid_too_long (__main__.TestValidator) should fail if ssid longer than 32 bytes ... ok test_wireless_unsupported_type (__main__.TestValidator) should fail if a non wireless connection has wireless settings defined ... ok test_invalid_bond_option_ad (__main__.TestValidatorDictBond) Test the ad bond option restrictions ... ok test_invalid_bond_option_arp (__main__.TestValidatorDictBond) Test the arp bond option restrictions ... ok test_invalid_bond_option_downdelay_updelay (__main__.TestValidatorDictBond) Test the downdelay or updelay bond option restrictions ... ok test_invalid_bond_option_infiniband_port (__main__.TestValidatorDictBond) Test that bond only supports infiniband ports in active-backup mode ... ok test_invalid_bond_option_packets_per_port (__main__.TestValidatorDictBond) Test the packets_per_port bond option restrictions ... ok test_invalid_bond_option_peer_arp_ip_target_arp_interval (__main__.TestValidatorDictBond) Test the arp_ip_target or arp_interval bond option restrictions ... ok test_invalid_bond_option_peer_notif_delay (__main__.TestValidatorDictBond) Test the peer_notif_delay bond option restrictions ... ok test_invalid_bond_option_primary (__main__.TestValidatorDictBond) Test the primary bond option restrictions ... ok test_invalid_bond_option_tlb_dynamic_lb (__main__.TestValidatorDictBond) Test the tlb_dynamic_lb bond option restrictions ... ok test_invalid_pkey_values (__main__.TestValidatorDictInfiniband) ... ok test_interface_name_and_match_when_match_is_None (__main__.TestValidatorMatch) Test that when 'match' setting is None, interface name should be profile name ... ok test_interface_name_when_match_not_specified (__main__.TestValidatorMatch) Test that when 'match' setting is not specified, interface name should be ... ok test_interface_name_when_match_path_is_empty_list (__main__.TestValidatorMatch) Test that when 'match.path' setting is empty list, interface name should be ... ok test_interface_name_when_match_path_is_valid (__main__.TestValidatorMatch) Test that when 'match.path' setting contains interface path, interface name ... ok test_match_path_empty_list (__main__.TestValidatorMatch) Test that 'match.path' setting can be defined as None, [], [""], [None] or "" ... ok test_match_path_invalid_connection_type (__main__.TestValidatorMatch) Test that when 'match.path' setting is correctly defined but the connection ... ok test_match_path_invalid_setting (__main__.TestValidatorMatch) Test that values like ["&"] and ["|"] are invalid values for 'match.path' ... ok test_match_path_setting_normalization (__main__.TestValidatorMatch) Test that 'match.path' setting ["", "usb123", None] will be normalized into ... ok test_match_path_valid_setting (__main__.TestValidatorMatch) Test that values like ["pci-0000:00:03.0"] and ["&!pci-0000:00:0[1-3].0"] are ... ok test_empty_route_table_name (__main__.TestValidatorRouteTable) Test that empty string is invalid value for route table name ... ok test_invalid_numeric_route_tables (__main__.TestValidatorRouteTable) Test that the value less than 1 or greater than 4294967295 are the invalid ... ok test_invalid_route_table_names (__main__.TestValidatorRouteTable) Test that the route table names should not be composed from the characters ... ok test_invalid_value_types_for_route_tables (__main__.TestValidatorRouteTable) Test that the value types apart from string type and integer type are all ... ok test_parse_rt_tables (__main__.TestValidatorRouteTable) Test that the `IPRouteUtils._parse_route_tables_mapping()` will create the ... ok test_table_found_when_validate_route_tables (__main__.TestValidatorRouteTable) Test that the `validate_route_tables()` will find the table id mapping from ... ok test_table_not_found_when_validate_route_tables (__main__.TestValidatorRouteTable) Test that the validation error is raised when the `validate_route_tables()` cannot ... ok test_type_route_with_gateway (__main__.TestValidatorRouteTable) Test that the route type route can not have a gateway ... ok test_valid_numeric_route_tables (__main__.TestValidatorRouteTable) Test that the value between 1 and 4294967295 are the valid value for numeric ... ok test_routing_rule_invalid_from_prefix_length (__main__.TestValidatorRoutingRules) Test that the prefix length for from/src cannot be zero when from/src is ... ok test_routing_rule_invalid_incoming_interface_name (__main__.TestValidatorRoutingRules) Test the invalid incoming interface name specified in the routing rule ... ok test_routing_rule_invalid_outgoing_interface_name (__main__.TestValidatorRoutingRules) Test the invalid outgoing interface name specified in the routing rule ... ok test_routing_rule_invalid_to_prefix_length (__main__.TestValidatorRoutingRules) Test that the prefix length for to/dst cannot be zero when to/dst is specified ... ok test_routing_rule_missing_address_family (__main__.TestValidatorRoutingRules) Test that the address family has to be specified if cannot be derived from src ... ok test_routing_rule_missing_table (__main__.TestValidatorRoutingRules) Test that table has to be defined when the action of the routing rule is ... ok test_routing_rule_validate_address_family (__main__.TestValidatorRoutingRules) Test that the derived address family and the specified address family should be ... ok test_routing_rule_validate_fwmark (__main__.TestValidatorRoutingRules) Test that fwmark requires fwmask to be specified ... ok test_routing_rule_validate_fwmask (__main__.TestValidatorRoutingRules) Test that fwmask requires fwmark to be specified ... ok test_routing_rule_validate_suppress_prefixlength (__main__.TestValidatorRoutingRules) Test the invalid suppress_prefixlength setting ... ok test_routing_rule_validate_uid (__main__.TestValidatorRoutingRules) Test the invalid uid specified in the routing rule ... ok test_table_found_when_lookup_named_table (__main__.TestValidatorRoutingRules) Test that the `validate_route_tables()` will find the table id mapping from ... ok ====================================================================== FAIL: test_route_v6 (__main__.TestValidator) ---------------------------------------------------------------------- Traceback (most recent call last): File "/tmp/lsrtest_0v_opbxw/test_network_connections.py", line 2743, in test_route_v6 self.do_connections_validate( File "/tmp/lsrtest_0v_opbxw/test_network_connections.py", line 350, in do_connections_validate self.do_connections_validate_nm(input_connections, **kwargs) File "/tmp/lsrtest_0v_opbxw/test_network_connections.py", line 308, in do_connections_validate_nm self.assert_nm_connection_routes_expected( File "/tmp/lsrtest_0v_opbxw/test_network_connections.py", line 245, in assert_nm_connection_routes_expected self.assertEqual(route_list_exp, route_list_new) AssertionError: Lists differ: [{'network': '192.168.40.0', 'prefix': 24, '[721 chars]10>}] != [{'family': 2, 'network': '192.168.40.0', 'p[529 chars]one}] First differing element 0: {'network': '192.168.40.0', 'prefix': 24, '[105 chars]: 2>} {'family': 2, 'network': '192.168.40.0', 'p[67 chars]None} - [{'family': , + [{'family': 2, 'gateway': None, 'metric': 545, 'network': '192.168.40.0', 'prefix': 24, - 'src': None, 'table': None, 'type': None}, - {'family': , + {'family': 2, 'gateway': None, 'metric': -1, 'network': '192.168.46.0', 'prefix': 30, - 'src': None, 'table': None, 'type': None}, - {'family': , + {'family': 2, 'gateway': None, 'metric': 545, 'network': '192.168.45.0', 'prefix': 24, - 'src': None, 'table': None, 'type': None}, - {'family': , + {'family': 10, 'gateway': None, 'metric': -1, 'network': 'a:b:c:f::', 'prefix': 64, - 'src': None, 'table': None, 'type': None}, - {'family': , + {'family': 10, 'gateway': None, 'metric': -1, 'network': 'a:b:c:d::', 'prefix': 64, - 'src': None, 'table': None, 'type': None}] ====================================================================== FAIL: test_route_without_interface_name (__main__.TestValidator) ---------------------------------------------------------------------- Traceback (most recent call last): File "/tmp/lsrtest_0v_opbxw/test_network_connections.py", line 2902, in test_route_without_interface_name self.do_connections_validate( File "/tmp/lsrtest_0v_opbxw/test_network_connections.py", line 350, in do_connections_validate self.do_connections_validate_nm(input_connections, **kwargs) File "/tmp/lsrtest_0v_opbxw/test_network_connections.py", line 308, in do_connections_validate_nm self.assert_nm_connection_routes_expected( File "/tmp/lsrtest_0v_opbxw/test_network_connections.py", line 245, in assert_nm_connection_routes_expected self.assertEqual(route_list_exp, route_list_new) AssertionError: Lists differ: [{'network': '192.168.40.0', 'prefix': 24, '[721 chars]10>}] != [{'family': 2, 'network': '192.168.40.0', 'p[529 chars]one}] First differing element 0: {'network': '192.168.40.0', 'prefix': 24, '[105 chars]: 2>} {'family': 2, 'network': '192.168.40.0', 'p[67 chars]None} - [{'family': , + [{'family': 2, 'gateway': None, 'metric': 545, 'network': '192.168.40.0', 'prefix': 24, - 'src': None, 'table': None, 'type': None}, - {'family': , + {'family': 2, 'gateway': None, 'metric': -1, 'network': '192.168.46.0', 'prefix': 30, - 'src': None, 'table': None, 'type': None}, - {'family': , + {'family': 2, 'gateway': None, 'metric': 545, 'network': '192.168.45.0', 'prefix': 24, - 'src': None, 'table': None, 'type': None}, - {'family': , + {'family': 10, 'gateway': None, 'metric': -1, 'network': 'a:b:c:f::', 'prefix': 64, - 'src': None, 'table': None, 'type': None}, - {'family': , + {'family': 10, 'gateway': None, 'metric': -1, 'network': 'a:b:c:d::', 'prefix': 64, - 'src': None, 'table': None, 'type': None}] ---------------------------------------------------------------------- Ran 150 tests in 0.084s FAILED (failures=2) MSG: non-zero return code TASK [Remove local tar file] *************************************************** task path: /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:158 Sunday 04 August 2024 17:22:03 +0000 (0:00:00.489) 0:00:10.530 ********* changed: [sut -> localhost] => { "changed": true, "path": "/tmp/lsrtest_2g2f7ot6.tar", "state": "absent" } TASK [Remove tempdir] ********************************************************** task path: /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:164 Sunday 04 August 2024 17:22:03 +0000 (0:00:00.120) 0:00:10.651 ********* changed: [sut] => { "changed": true, "path": "/tmp/lsrtest_0v_opbxw", "state": "absent" } TASK [Verify network state restored to default] ******************************** task path: /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:169 Sunday 04 August 2024 17:22:03 +0000 (0:00:00.173) 0:00:10.825 ********* included: /WORKDIR/git-route_srce6krps99/tests/tasks/check_network_dns.yml for sut TASK [Check routes and DNS] **************************************************** task path: /WORKDIR/git-route_srce6krps99/tests/tasks/check_network_dns.yml:6 Sunday 04 August 2024 17:22:03 +0000 (0:00:00.013) 0:00:10.838 ********* ok: [sut] => { "changed": false, "cmd": "set -euo pipefail\necho IP\nip a\necho IP ROUTE\nip route\necho IP -6 ROUTE\nip -6 route\necho RESOLV\nif [ -f /etc/resolv.conf ]; then\n cat /etc/resolv.conf\nelse\n echo NO /etc/resolv.conf\n ls -alrtF /etc/resolv.* || :\nfi\n", "delta": "0:00:00.008739", "end": "2024-08-04 17:22:04.113418", "rc": 0, "start": "2024-08-04 17:22:04.104679" } STDOUT: IP 1: lo: mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000 link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00 inet 127.0.0.1/8 scope host lo valid_lft forever preferred_lft forever inet6 ::1/128 scope host valid_lft forever preferred_lft forever 2: eth0: mtu 9001 qdisc mq state UP group default qlen 1000 link/ether 02:cf:c3:bd:6b:01 brd ff:ff:ff:ff:ff:ff altname enX0 inet 10.31.44.187/22 brd 10.31.47.255 scope global dynamic noprefixroute eth0 valid_lft 3580sec preferred_lft 3580sec inet6 fe80::cf:c3ff:febd:6b01/64 scope link valid_lft forever preferred_lft forever IP ROUTE default via 10.31.44.1 dev eth0 proto dhcp src 10.31.44.187 metric 100 10.31.44.0/22 dev eth0 proto kernel scope link src 10.31.44.187 metric 100 IP -6 ROUTE ::1 dev lo proto kernel metric 256 pref medium fe80::/64 dev eth0 proto kernel metric 256 pref medium RESOLV # Generated by NetworkManager search us-east-1.aws.redhat.com testing-farm nameserver 10.29.169.13 nameserver 10.29.170.12 nameserver 10.2.32.1 TASK [Verify DNS and network connectivity] ************************************* task path: /WORKDIR/git-route_srce6krps99/tests/tasks/check_network_dns.yml:24 Sunday 04 August 2024 17:22:04 +0000 (0:00:00.175) 0:00:11.013 ********* ok: [sut] => { "changed": false, "cmd": "set -euo pipefail\necho CHECK DNS AND CONNECTIVITY\nfor host in mirrors.fedoraproject.org mirrors.centos.org; do\n if ! getent hosts \"$host\"; then\n echo FAILED to lookup host \"$host\"\n exit 1\n fi\n if ! curl -o /dev/null https://\"$host\"; then\n echo FAILED to contact host \"$host\"\n exit 1\n fi\ndone\n", "delta": "0:00:00.313778", "end": "2024-08-04 17:22:04.593320", "rc": 0, "start": "2024-08-04 17:22:04.279542" } STDOUT: CHECK DNS AND CONNECTIVITY 2600:2701:4000:5211:dead:beef:fe:fed3 wildcard.fedoraproject.org mirrors.fedoraproject.org 2620:52:3:1:dead:beef:cafe:fed6 wildcard.fedoraproject.org mirrors.fedoraproject.org 2605:bc80:3010:600:dead:beef:cafe:fed9 wildcard.fedoraproject.org mirrors.fedoraproject.org 2600:1f14:fad:5c02:7c8a:72d0:1c58:c189 wildcard.fedoraproject.org mirrors.fedoraproject.org 2604:1580:fe00:0:dead:beef:cafe:fed1 wildcard.fedoraproject.org mirrors.fedoraproject.org 2620:52:3:1:dead:beef:cafe:fed6 wildcard.fedoraproject.org mirrors.centos.org mirrors.fedoraproject.org 2600:1f14:fad:5c02:7c8a:72d0:1c58:c189 wildcard.fedoraproject.org mirrors.centos.org mirrors.fedoraproject.org 2605:bc80:3010:600:dead:beef:cafe:fed9 wildcard.fedoraproject.org mirrors.centos.org mirrors.fedoraproject.org 2604:1580:fe00:0:dead:beef:cafe:fed1 wildcard.fedoraproject.org mirrors.centos.org mirrors.fedoraproject.org 2600:2701:4000:5211:dead:beef:fe:fed3 wildcard.fedoraproject.org mirrors.centos.org mirrors.fedoraproject.org STDERR: % Total % Received % Xferd Average Speed Time Time Time Current Dload Upload Total Spent Left Speed 0 0 0 0 0 0 0 0 --:--:-- --:--:-- --:--:-- 0 100 305 100 305 0 0 3630 0 --:--:-- --:--:-- --:--:-- 3674 % Total % Received % Xferd Average Speed Time Time Time Current Dload Upload Total Spent Left Speed 0 0 0 0 0 0 0 0 --:--:-- --:--:-- --:--:-- 0 100 291 100 291 0 0 1419 0 --:--:-- --:--:-- --:--:-- 1419 to retry, use: --limit @/tmp/tests_unit.retry PLAY RECAP ********************************************************************* sut : ok=32 changed=8 unreachable=0 failed=1 skipped=7 rescued=0 ignored=2 Sunday 04 August 2024 17:22:04 +0000 (0:00:00.479) 0:00:11.493 ********* =============================================================================== Install dependencies ---------------------------------------------------- 3.83s /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:9 ------------------------- Gathering Facts --------------------------------------------------------- 0.80s /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:3 ------------------------- Untar testrepo.tar ------------------------------------------------------ 0.71s /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:66 ------------------------ Copy testrepo.tar to the remote system ---------------------------------- 0.69s /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:60 ------------------------ Copy unit test to remote system ----------------------------------------- 0.62s /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:97 ------------------------ Gathering Facts --------------------------------------------------------- 0.58s /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:23 ------------------------ Run python3 unit tests -------------------------------------------------- 0.49s /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:138 ----------------------- Verify DNS and network connectivity ------------------------------------- 0.48s /WORKDIR/git-route_srce6krps99/tests/tasks/check_network_dns.yml:24 ----------- Create subdirectory '/ansible/module_utils' under '/tmp/lsrtest_0v_opbxw' --- 0.41s /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:72 ------------------------ Gather the minimum subset of ansible_facts required by the network role test --- 0.30s /WORKDIR/git-route_srce6krps99/tests/tasks/el_repo_setup.yml:3 ---------------- Check if system is ostree ----------------------------------------------- 0.23s /WORKDIR/git-route_srce6krps99/tests/tasks/el_repo_setup.yml:17 --------------- Create tempdir for code to test ----------------------------------------- 0.22s /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:28 ------------------------ Find parent directory and path of modules ------------------------------- 0.19s /WORKDIR/git-route_srce6krps99/tests/tasks/get_modules_and_utils_paths.yml:42 - List the files in /tmp/lsrtest_0v_opbxw --------------------------------- 0.18s /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:107 ----------------------- Fake out python module directories, primarily for python2 --------------- 0.18s /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:88 ------------------------ Move module_utils to ansible directory ---------------------------------- 0.18s /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:81 ------------------------ Check routes and DNS ---------------------------------------------------- 0.18s /WORKDIR/git-route_srce6krps99/tests/tasks/check_network_dns.yml:6 ------------ Remove tempdir ---------------------------------------------------------- 0.17s /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:164 ----------------------- Check if python3 is available ------------------------------------------- 0.17s /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:131 ----------------------- Check if python2 is available ------------------------------------------- 0.16s /WORKDIR/git-route_srce6krps99/tests/tests_unit.yml:114 ----------------------- ---^---^---^---^---^--- # STDERR: ---v---v---v---v---v--- [DEPRECATION WARNING]: ANSIBLE_COLLECTIONS_PATHS option, does not fit var naming standard, use the singular form ANSIBLE_COLLECTIONS_PATH instead. This feature will be removed from ansible-core in version 2.19. Deprecation warnings can be disabled by setting deprecation_warnings=False in ansible.cfg. [WARNING]: Platform linux on host sut is using the discovered Python interpreter at /usr/bin/python3.9, 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. ---^---^---^---^---^---