# STDOUT: ---v---v---v---v---v--- ansible-playbook 2.9.27 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.9/lib/python3.9/site-packages/ansible executable location = /opt/ansible-2.9/bin/ansible-playbook python version = 3.9.18 (main, Sep 7 2023, 00:00:00) [GCC 11.4.1 20230605 (Red Hat 11.4.1-2)] Using /etc/ansible/ansible.cfg as config file statically imported: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/create_test_interfaces_with_dhcp.yml statically imported: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/assert_device_present.yml statically imported: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/assert_device_present.yml statically imported: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/assert_device_present.yml statically imported: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/remove_test_interfaces_with_dhcp.yml Skipping callback 'actionable', as we already have a stdout callback. Skipping callback 'counter_enabled', as we already have a stdout callback. Skipping callback 'debug', as we already have a stdout callback. Skipping callback 'dense', as we already have a stdout callback. Skipping callback 'dense', as we already have a stdout callback. Skipping callback 'full_skip', as we already have a stdout callback. Skipping callback 'json', as we already have a stdout callback. Skipping callback 'minimal', as we already have a stdout callback. Skipping callback 'null', as we already have a stdout callback. Skipping callback 'oneline', as we already have a stdout callback. Skipping callback 'selective', as we already have a stdout callback. Skipping callback 'skippy', as we already have a stdout callback. Skipping callback 'stderr', as we already have a stdout callback. Skipping callback 'unixy', as we already have a stdout callback. Skipping callback 'yaml', as we already have a stdout callback. PLAYBOOK: tests_bond_deprecated_nm.yml ***************************************** 2 plays in /WORKDIR/git-route_typedtuxjrqv/tests/tests_bond_deprecated_nm.yml PLAY [Run playbook 'playbooks/tests_bond_deprecated.yml' with nm as provider] *** TASK [Gathering Facts] ********************************************************* task path: /WORKDIR/git-route_typedtuxjrqv/tests/tests_bond_deprecated_nm.yml:6 Wednesday 10 January 2024 15:32:05 +0000 (0:00:00.012) 0:00:00.012 ***** ok: [sut] META: ran handlers TASK [Include the task 'el_repo_setup.yml'] ************************************ task path: /WORKDIR/git-route_typedtuxjrqv/tests/tests_bond_deprecated_nm.yml:9 Wednesday 10 January 2024 15:32:10 +0000 (0:00:05.515) 0:00:05.527 ***** included: /WORKDIR/git-route_typedtuxjrqv/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_typedtuxjrqv/tests/tasks/el_repo_setup.yml:3 Wednesday 10 January 2024 15:32:10 +0000 (0:00:00.011) 0:00:05.538 ***** ok: [sut] TASK [Check if system is ostree] *********************************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/tasks/el_repo_setup.yml:19 Wednesday 10 January 2024 15:32:11 +0000 (0:00:00.226) 0:00:05.765 ***** ok: [sut] => { "changed": false, "stat": { "exists": false } } TASK [Set flag to indicate system is ostree] *********************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/tasks/el_repo_setup.yml:24 Wednesday 10 January 2024 15:32:16 +0000 (0:00:05.223) 0:00:10.989 ***** ok: [sut] => { "ansible_facts": { "__network_is_ostree": false }, "changed": false } TASK [Fix CentOS6 Base repo] *************************************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/tasks/el_repo_setup.yml:28 Wednesday 10 January 2024 15:32:16 +0000 (0:00:00.020) 0:00:11.009 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Include the task 'enable_epel.yml'] ************************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/tasks/el_repo_setup.yml:53 Wednesday 10 January 2024 15:32:16 +0000 (0:00:00.018) 0:00:11.027 ***** included: /WORKDIR/git-route_typedtuxjrqv/tests/tasks/enable_epel.yml for sut TASK [Create EPEL 7] *********************************************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/tasks/enable_epel.yml:8 Wednesday 10 January 2024 15:32:16 +0000 (0:00:00.030) 0:00:11.058 ***** ok: [sut] => { "attempts": 1, "changed": false, "cmd": [ "rpm", "-iv", "https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm" ], "rc": 0 } STDOUT: skipped, since /etc/yum.repos.d/epel.repo exists TASK [Install yum-utils package] *********************************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/tasks/enable_epel.yml:24 Wednesday 10 January 2024 15:32:16 +0000 (0:00:00.186) 0:00:11.244 ***** ok: [sut] => { "changed": false, "rc": 0, "results": [ "yum-utils-1.1.31-54.el7_8.noarch providing yum-utils is already installed" ] } TASK [Enable EPEL 7] *********************************************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/tasks/enable_epel.yml:30 Wednesday 10 January 2024 15:32:16 +0000 (0:00:00.460) 0:00:11.705 ***** ok: [sut] => { "changed": false, "cmd": [ "yum-config-manager", "--enable", "epel" ], "delta": "0:00:00.177486", "end": "2024-01-10 15:32:17.227949", "rc": 0, "start": "2024-01-10 15:32:17.050463" } STDOUT: Loaded plugins: fastestmirror ================================== repo: epel ================================== [epel] async = True bandwidth = 0 base_persistdir = /var/lib/yum/repos/x86_64/7 baseurl = cache = 0 cachedir = /var/cache/yum/x86_64/7/epel check_config_file_age = True compare_providers_priority = 80 cost = 1000 deltarpm_metadata_percentage = 100 deltarpm_percentage = enabled = True enablegroups = True exclude = failovermethod = priority ftp_disable_epsv = False gpgcadir = /var/lib/yum/repos/x86_64/7/epel/gpgcadir gpgcakey = gpgcheck = True gpgdir = /var/lib/yum/repos/x86_64/7/epel/gpgdir gpgkey = file:///etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL-7 hdrdir = /var/cache/yum/x86_64/7/epel/headers http_caching = all includepkgs = ip_resolve = keepalive = True keepcache = False mddownloadpolicy = sqlite mdpolicy = group:small mediaid = metadata_expire = 21600 metadata_expire_filter = read-only:present metalink = https://mirrors.fedoraproject.org/metalink?repo=epel-7&arch=x86_64&infra=stock&content=centos minrate = 0 mirrorlist = mirrorlist_expire = 86400 name = Extra Packages for Enterprise Linux 7 - x86_64 old_base_cache_dir = password = persistdir = /var/lib/yum/repos/x86_64/7/epel pkgdir = /var/cache/yum/x86_64/7/epel/packages proxy = False proxy_dict = proxy_password = proxy_username = repo_gpgcheck = False retries = 10 skip_if_unavailable = False ssl_check_cert_permissions = True sslcacert = sslclientcert = sslclientkey = sslverify = True throttle = 0 timeout = 30.0 ui_id = epel/x86_64 ui_repoid_vars = releasever, basearch username = TASK [Enable EPEL 8] *********************************************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/tasks/enable_epel.yml:35 Wednesday 10 January 2024 15:32:17 +0000 (0:00:00.301) 0:00:12.006 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Enable EPEL 6] *********************************************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/tasks/enable_epel.yml:40 Wednesday 10 January 2024 15:32:17 +0000 (0:00:00.011) 0:00:12.018 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Set network provider to 'nm'] ******************************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/tests_bond_deprecated_nm.yml:11 Wednesday 10 January 2024 15:32:17 +0000 (0:00:00.010) 0:00:12.028 ***** ok: [sut] => { "ansible_facts": { "network_provider": "nm" }, "changed": false } META: ran handlers META: ran handlers PLAY [Play for testing bond device using deprecated 'master' argument] ********* TASK [Gathering Facts] ********************************************************* task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tests_bond_deprecated.yml:3 Wednesday 10 January 2024 15:32:17 +0000 (0:00:00.011) 0:00:12.040 ***** ok: [sut] META: ran handlers TASK [INIT Prepare setup] ****************************************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tests_bond_deprecated.yml:13 Wednesday 10 January 2024 15:32:22 +0000 (0:00:05.420) 0:00:17.460 ***** ok: [sut] => {} MSG: ################################################## TASK [Install dnsmasq] ********************************************************* task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/create_test_interfaces_with_dhcp.yml:3 Wednesday 10 January 2024 15:32:22 +0000 (0:00:00.010) 0:00:17.471 ***** changed: [sut] => { "changed": true, "changes": { "installed": [ "dnsmasq" ] }, "rc": 0, "results": [ "Loaded plugins: fastestmirror\nLoading mirror speeds from cached hostfile\n * base: download.cf.centos.org\n * epel: mirror.cogentco.com\n * extras: download.cf.centos.org\n * updates: download.cf.centos.org\nResolving Dependencies\n--> Running transaction check\n---> Package dnsmasq.x86_64 0:2.76-17.el7_9.3 will be installed\n--> Processing Dependency: libnettle.so.4()(64bit) for package: dnsmasq-2.76-17.el7_9.3.x86_64\n--> Running transaction check\n---> Package nettle.x86_64 0:2.7.1-9.el7_9 will be installed\n--> Finished Dependency Resolution\n\nDependencies Resolved\n\n================================================================================\n Package Arch Version Repository Size\n================================================================================\nInstalling:\n dnsmasq x86_64 2.76-17.el7_9.3 updates 281 k\nInstalling for dependencies:\n nettle x86_64 2.7.1-9.el7_9 updates 328 k\n\nTransaction Summary\n================================================================================\nInstall 1 Package (+1 Dependent package)\n\nTotal download size: 608 k\nInstalled size: 1.3 M\nDownloading packages:\n--------------------------------------------------------------------------------\nTotal 2.0 MB/s | 608 kB 00:00 \nRunning transaction check\nRunning transaction test\nTransaction test succeeded\nRunning transaction\n Installing : nettle-2.7.1-9.el7_9.x86_64 1/2 \n Installing : dnsmasq-2.76-17.el7_9.3.x86_64 2/2 \n Verifying : dnsmasq-2.76-17.el7_9.3.x86_64 1/2 \n Verifying : nettle-2.7.1-9.el7_9.x86_64 2/2 \n\nInstalled:\n dnsmasq.x86_64 0:2.76-17.el7_9.3 \n\nDependency Installed:\n nettle.x86_64 0:2.7.1-9.el7_9 \n\nComplete!\n" ] } TASK [Install pgrep, sysctl] *************************************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/create_test_interfaces_with_dhcp.yml:10 Wednesday 10 January 2024 15:32:25 +0000 (0:00:03.228) 0:00:20.700 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Install pgrep, sysctl] *************************************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/create_test_interfaces_with_dhcp.yml:20 Wednesday 10 January 2024 15:32:25 +0000 (0:00:00.010) 0:00:20.711 ***** ok: [sut] => { "changed": false, "rc": 0, "results": [ "procps-ng-3.3.10-28.el7.x86_64 providing procps-ng is already installed" ] } TASK [Create test interfaces] ************************************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/create_test_interfaces_with_dhcp.yml:30 Wednesday 10 January 2024 15:32:26 +0000 (0:00:00.376) 0:00:21.088 ***** ok: [sut] => { "changed": false, "cmd": "set -euo pipefail\nip link add test1 type veth peer name test1p\nip link add test2 type veth peer name test2p\nif [ -n \"$(pgrep NetworkManager)\" ];then\n nmcli d set test1 managed true\n nmcli d set test2 managed true\n # NetworkManager should not manage DHCP server ports\n nmcli d set test1p managed false\n nmcli d set test2p managed false\nfi\nip link set test1p up\nip link set test2p up\n\n# Create the 'testbr' - providing both 10.x ipv4 and 2620:52:0 ipv6 dhcp\nip link add name testbr type bridge forward_delay 0\nif [ -n \"$(pgrep NetworkManager)\" ];then\n # NetworkManager should not manage DHCP server ports\n nmcli d set testbr managed false\nfi\nip link set testbr up\ntimer=0\n# The while loop following is a workaround for the NM bug, which can be\n# tracked in https://bugzilla.redhat.com/show_bug.cgi?id=2079642\nwhile ! ip addr show testbr | grep -q 'inet [1-9]'\ndo\n let \"timer+=1\"\n if [ $timer -eq 30 ]; then break; fi\n sleep 1\n ip addr add 192.0.2.1/24 dev testbr\n ip -6 addr add 2001:DB8::1/32 dev testbr\ndone\n\nif grep 'release 6' /etc/redhat-release; then\n # We need bridge-utils and radvd only in rhel6\n if ! rpm -q --quiet radvd; then yum -y install radvd; fi\n if ! rpm -q --quiet bridge-utils; then yum -y install bridge-utils; fi\n\n # We need to add iptables rule to allow dhcp request\n iptables -I INPUT -i testbr -p udp --dport 67:68 --sport 67:68 -j ACCEPT\n\n # Add test1, test2 peers into the testbr\n brctl addif testbr test1p\n brctl addif testbr test2p\n\n # in RHEL6 /run is not present\n mkdir -p /run\n\n # and dnsmasq does not support ipv6\n dnsmasq --pid-file=/run/dhcp_testbr.pid --dhcp-leasefile=/run/dhcp_testbr.lease --dhcp-range=192.0.2.1,192.0.2.254,240 --interface=testbr --bind-interfaces\n\n # start radvd for ipv6\n echo 'interface testbr {' > /etc/radvd.conf\n echo ' AdvSendAdvert on;' >> /etc/radvd.conf\n echo ' prefix 2001:DB8::/64 { ' >> /etc/radvd.conf\n echo ' AdvOnLink on; }; ' >> /etc/radvd.conf\n echo ' }; ' >> /etc/radvd.conf\n\n # enable ipv6 forwarding\n sysctl -w net.ipv6.conf.all.forwarding=1\n service radvd restart\n\nelse\n ip link set test1p master testbr\n ip link set test2p master testbr\n # Run joint DHCP4/DHCP6 server with RA enabled in veth namespace\n dnsmasq --pid-file=/run/dhcp_testbr.pid --dhcp-leasefile=/run/dhcp_testbr.lease --dhcp-range=192.0.2.1,192.0.2.254,240 --dhcp-range=2001:DB8::10,2001:DB8::1FF,slaac,64,240 --enable-ra --interface=testbr --bind-interfaces\nfi\n", "delta": "0:00:01.198233", "end": "2024-01-10 15:32:27.633173", "rc": 0, "start": "2024-01-10 15:32:26.434940" } TASK [Include the task 'get_interface_stat.yml'] ******************************* task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/assert_device_present.yml:3 Wednesday 10 January 2024 15:32:27 +0000 (0:00:01.324) 0:00:22.412 ***** included: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_interface_stat.yml for sut TASK [Get stat for interface test1] ******************************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_interface_stat.yml:3 Wednesday 10 January 2024 15:32:27 +0000 (0:00:00.014) 0:00:22.427 ***** ok: [sut] => { "changed": false, "stat": { "atime": 1704900746.4493775, "block_size": 4096, "blocks": 0, "ctime": 1704900746.4493775, "dev": 18, "device_type": 0, "executable": true, "exists": true, "gid": 0, "gr_name": "root", "inode": 17708, "isblk": false, "ischr": false, "isdir": false, "isfifo": false, "isgid": false, "islnk": true, "isreg": false, "issock": false, "isuid": false, "lnk_source": "/sys/devices/virtual/net/test1", "lnk_target": "../../devices/virtual/net/test1", "mode": "0777", "mtime": 1704900746.4493775, "nlink": 1, "path": "/sys/class/net/test1", "pw_name": "root", "readable": true, "rgrp": true, "roth": true, "rusr": true, "size": 0, "uid": 0, "wgrp": true, "woth": true, "writeable": true, "wusr": true, "xgrp": true, "xoth": true, "xusr": true } } TASK [Assert that the interface is present - 'test1'] ************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/assert_device_present.yml:5 Wednesday 10 January 2024 15:32:32 +0000 (0:00:05.154) 0:00:27.581 ***** ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Include the task 'get_interface_stat.yml'] ******************************* task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/assert_device_present.yml:3 Wednesday 10 January 2024 15:32:32 +0000 (0:00:00.012) 0:00:27.594 ***** included: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_interface_stat.yml for sut TASK [Get stat for interface test2] ******************************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_interface_stat.yml:3 Wednesday 10 January 2024 15:32:32 +0000 (0:00:00.012) 0:00:27.606 ***** ok: [sut] => { "changed": false, "stat": { "atime": 1704900746.4563775, "block_size": 4096, "blocks": 0, "ctime": 1704900746.4553776, "dev": 18, "device_type": 0, "executable": true, "exists": true, "gid": 0, "gr_name": "root", "inode": 17873, "isblk": false, "ischr": false, "isdir": false, "isfifo": false, "isgid": false, "islnk": true, "isreg": false, "issock": false, "isuid": false, "lnk_source": "/sys/devices/virtual/net/test2", "lnk_target": "../../devices/virtual/net/test2", "mode": "0777", "mtime": 1704900746.4553776, "nlink": 1, "path": "/sys/class/net/test2", "pw_name": "root", "readable": true, "rgrp": true, "roth": true, "rusr": true, "size": 0, "uid": 0, "wgrp": true, "woth": true, "writeable": true, "wusr": true, "xgrp": true, "xoth": true, "xusr": true } } TASK [Assert that the interface is present - 'test2'] ************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/assert_device_present.yml:5 Wednesday 10 January 2024 15:32:32 +0000 (0:00:00.124) 0:00:27.731 ***** ok: [sut] => { "changed": false } MSG: All assertions passed TASK [TEST Add Bond with 2 ports using deprecated 'master' argument] *********** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tests_bond_deprecated.yml:28 Wednesday 10 January 2024 15:32:32 +0000 (0:00:00.011) 0:00:27.742 ***** ok: [sut] => {} MSG: ################################################## TASK [linux-system-roles.network : Ensure ansible_facts used by role] ********** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:4 Wednesday 10 January 2024 15:32:32 +0000 (0:00:00.009) 0:00:27.752 ***** included: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/set_facts.yml for sut TASK [linux-system-roles.network : Ensure ansible_facts used by role are present] *** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/set_facts.yml:3 Wednesday 10 January 2024 15:32:33 +0000 (0:00:00.064) 0:00:27.816 ***** skipping: [sut] => { "censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": false } TASK [linux-system-roles.network : Check if system is ostree] ****************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/set_facts.yml:13 Wednesday 10 January 2024 15:32:33 +0000 (0:00:00.010) 0:00:27.826 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Set flag to indicate system is ostree] ****** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/set_facts.yml:18 Wednesday 10 January 2024 15:32:33 +0000 (0:00:00.009) 0:00:27.836 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Check which services are running] *********** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/set_facts.yml:22 Wednesday 10 January 2024 15:32:33 +0000 (0:00:00.009) 0:00:27.845 ***** ok: [sut] => { "censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": false } TASK [linux-system-roles.network : Check which packages are installed] ********* task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/set_facts.yml:27 Wednesday 10 January 2024 15:32:33 +0000 (0:00:00.773) 0:00:28.619 ***** ok: [sut] => { "censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": false } TASK [linux-system-roles.network : Print network provider] ********************* task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:7 Wednesday 10 January 2024 15:32:39 +0000 (0:00:06.082) 0:00:34.701 ***** ok: [sut] => {} MSG: Using network provider: nm TASK [linux-system-roles.network : Abort applying the network state configuration if using the `network_state` variable with the initscripts provider] *** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:11 Wednesday 10 January 2024 15:32:39 +0000 (0:00:00.022) 0:00:34.724 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Abort applying the network state configuration if the system version of the managed host is below 8] *** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:19 Wednesday 10 January 2024 15:32:39 +0000 (0:00:00.018) 0:00:34.743 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Install packages] *************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:30 Wednesday 10 January 2024 15:32:40 +0000 (0:00:00.031) 0:00:34.775 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Install NetworkManager and nmstate when using network_state variable] *** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:40 Wednesday 10 January 2024 15:32:40 +0000 (0:00:00.042) 0:00:34.817 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Install python3-libnmstate when using network_state variable] *** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:55 Wednesday 10 January 2024 15:32:40 +0000 (0:00:00.025) 0:00:34.842 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Restart NetworkManager due to wireless or team interfaces] *** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:71 Wednesday 10 January 2024 15:32:40 +0000 (0:00:00.020) 0:00:34.863 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Enable and start NetworkManager] ************ task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:85 Wednesday 10 January 2024 15:32:40 +0000 (0:00:00.025) 0:00:34.888 ***** ok: [sut] => { "censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": false } TASK [linux-system-roles.network : Enable and start wpa_supplicant] ************ task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:96 Wednesday 10 January 2024 15:32:40 +0000 (0:00:00.356) 0:00:35.245 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Enable network service] ********************* task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:105 Wednesday 10 January 2024 15:32:40 +0000 (0:00:00.024) 0:00:35.269 ***** skipping: [sut] => { "censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": false } TASK [linux-system-roles.network : Ensure initscripts network file dependency is present] *** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:113 Wednesday 10 January 2024 15:32:40 +0000 (0:00:00.019) 0:00:35.289 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Configure networking connection profiles] *** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:122 Wednesday 10 January 2024 15:32:40 +0000 (0:00:00.019) 0:00:35.308 ***** changed: [sut] => { "_invocation": { "module_args": { "__debug_flags": "", "__header": "#\n# Ansible managed\n#\n# system_role:network\n", "connections": [ { "bond": { "miimon": 110, "mode": "active-backup" }, "interface_name": "deprecated-bond", "ip": { "route_metric4": 65535 }, "name": "bond0", "state": "up", "type": "bond" }, { "interface_name": "test1", "master": "bond0", "name": "bond0.0", "state": "up", "type": "ethernet" }, { "interface_name": "test2", "master": "bond0", "name": "bond0.1", "state": "up", "type": "ethernet" } ], "force_state_change": false, "ignore_errors": false, "provider": "nm" } }, "changed": true } STDERR: [007] #0, state:up persistent_state:present, 'bond0': add connection bond0, 90ad7ebf-7a9b-4894-a8a3-82446759598d [008] #1, state:up persistent_state:present, 'bond0.0': add connection bond0.0, af186a0d-ba6e-4dc3-a11b-2b06f6f22ccb [009] #2, state:up persistent_state:present, 'bond0.1': add connection bond0.1, 8942036d-3673-4d50-bd06-3a3dee59a1b4 [010] #0, state:up persistent_state:present, 'bond0': up connection bond0, 90ad7ebf-7a9b-4894-a8a3-82446759598d (is-modified) [011] #1, state:up persistent_state:present, 'bond0.0': up connection bond0.0, af186a0d-ba6e-4dc3-a11b-2b06f6f22ccb (not-active) [012] #2, state:up persistent_state:present, 'bond0.1': up connection bond0.1, 8942036d-3673-4d50-bd06-3a3dee59a1b4 (not-active) TASK [linux-system-roles.network : Configure networking state] ***************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:134 Wednesday 10 January 2024 15:32:41 +0000 (0:00:00.605) 0:00:35.913 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Show stderr messages for the network_connections] *** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:140 Wednesday 10 January 2024 15:32:41 +0000 (0:00:00.019) 0:00:35.933 ***** ok: [sut] => { "__network_connections_result.stderr_lines": [ "[007] #0, state:up persistent_state:present, 'bond0': add connection bond0, 90ad7ebf-7a9b-4894-a8a3-82446759598d", "[008] #1, state:up persistent_state:present, 'bond0.0': add connection bond0.0, af186a0d-ba6e-4dc3-a11b-2b06f6f22ccb", "[009] #2, state:up persistent_state:present, 'bond0.1': add connection bond0.1, 8942036d-3673-4d50-bd06-3a3dee59a1b4", "[010] #0, state:up persistent_state:present, 'bond0': up connection bond0, 90ad7ebf-7a9b-4894-a8a3-82446759598d (is-modified)", "[011] #1, state:up persistent_state:present, 'bond0.0': up connection bond0.0, af186a0d-ba6e-4dc3-a11b-2b06f6f22ccb (not-active)", "[012] #2, state:up persistent_state:present, 'bond0.1': up connection bond0.1, 8942036d-3673-4d50-bd06-3a3dee59a1b4 (not-active)" ] } TASK [linux-system-roles.network : Show debug messages for the network_connections] *** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:144 Wednesday 10 January 2024 15:32:41 +0000 (0:00:00.020) 0:00:35.953 ***** ok: [sut] => { "__network_connections_result": { "_invocation": { "module_args": { "__debug_flags": "", "__header": "#\n# Ansible managed\n#\n# system_role:network\n", "connections": [ { "bond": { "miimon": 110, "mode": "active-backup" }, "interface_name": "deprecated-bond", "ip": { "route_metric4": 65535 }, "name": "bond0", "state": "up", "type": "bond" }, { "interface_name": "test1", "master": "bond0", "name": "bond0.0", "state": "up", "type": "ethernet" }, { "interface_name": "test2", "master": "bond0", "name": "bond0.1", "state": "up", "type": "ethernet" } ], "force_state_change": false, "ignore_errors": false, "provider": "nm" } }, "changed": true, "failed": false, "stderr": "[007] #0, state:up persistent_state:present, 'bond0': add connection bond0, 90ad7ebf-7a9b-4894-a8a3-82446759598d\n[008] #1, state:up persistent_state:present, 'bond0.0': add connection bond0.0, af186a0d-ba6e-4dc3-a11b-2b06f6f22ccb\n[009] #2, state:up persistent_state:present, 'bond0.1': add connection bond0.1, 8942036d-3673-4d50-bd06-3a3dee59a1b4\n[010] #0, state:up persistent_state:present, 'bond0': up connection bond0, 90ad7ebf-7a9b-4894-a8a3-82446759598d (is-modified)\n[011] #1, state:up persistent_state:present, 'bond0.0': up connection bond0.0, af186a0d-ba6e-4dc3-a11b-2b06f6f22ccb (not-active)\n[012] #2, state:up persistent_state:present, 'bond0.1': up connection bond0.1, 8942036d-3673-4d50-bd06-3a3dee59a1b4 (not-active)\n", "stderr_lines": [ "[007] #0, state:up persistent_state:present, 'bond0': add connection bond0, 90ad7ebf-7a9b-4894-a8a3-82446759598d", "[008] #1, state:up persistent_state:present, 'bond0.0': add connection bond0.0, af186a0d-ba6e-4dc3-a11b-2b06f6f22ccb", "[009] #2, state:up persistent_state:present, 'bond0.1': add connection bond0.1, 8942036d-3673-4d50-bd06-3a3dee59a1b4", "[010] #0, state:up persistent_state:present, 'bond0': up connection bond0, 90ad7ebf-7a9b-4894-a8a3-82446759598d (is-modified)", "[011] #1, state:up persistent_state:present, 'bond0.0': up connection bond0.0, af186a0d-ba6e-4dc3-a11b-2b06f6f22ccb (not-active)", "[012] #2, state:up persistent_state:present, 'bond0.1': up connection bond0.1, 8942036d-3673-4d50-bd06-3a3dee59a1b4 (not-active)" ] } } TASK [linux-system-roles.network : Show debug messages for the network_state] *** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:149 Wednesday 10 January 2024 15:32:41 +0000 (0:00:00.020) 0:00:35.973 ***** skipping: [sut] => {} TASK [linux-system-roles.network : Re-test connectivity] *********************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:155 Wednesday 10 January 2024 15:32:41 +0000 (0:00:00.019) 0:00:35.992 ***** ok: [sut] => { "changed": false, "ping": "pong" } TASK [Include the task 'get_interface_stat.yml'] ******************************* task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/assert_device_present.yml:3 Wednesday 10 January 2024 15:32:41 +0000 (0:00:00.218) 0:00:36.211 ***** included: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_interface_stat.yml for sut TASK [Get stat for interface deprecated-bond] ********************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_interface_stat.yml:3 Wednesday 10 January 2024 15:32:41 +0000 (0:00:00.036) 0:00:36.247 ***** ok: [sut] => { "changed": false, "stat": { "atime": 1704900760.9513505, "block_size": 4096, "blocks": 0, "ctime": 1704900760.9413505, "dev": 18, "device_type": 0, "executable": true, "exists": true, "gid": 0, "gr_name": "root", "inode": 18290, "isblk": false, "ischr": false, "isdir": false, "isfifo": false, "isgid": false, "islnk": true, "isreg": false, "issock": false, "isuid": false, "lnk_source": "/sys/devices/virtual/net/deprecated-bond", "lnk_target": "../../devices/virtual/net/deprecated-bond", "mode": "0777", "mtime": 1704900760.9413505, "nlink": 1, "path": "/sys/class/net/deprecated-bond", "pw_name": "root", "readable": true, "rgrp": true, "roth": true, "rusr": true, "size": 0, "uid": 0, "wgrp": true, "woth": true, "writeable": true, "wusr": true, "xgrp": true, "xoth": true, "xusr": true } } TASK [Assert that the interface is present - 'deprecated-bond'] **************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/assert_device_present.yml:5 Wednesday 10 January 2024 15:32:46 +0000 (0:00:05.168) 0:00:41.415 ***** ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Include the task 'assert_profile_present.yml'] *************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tests_bond_deprecated.yml:62 Wednesday 10 January 2024 15:32:46 +0000 (0:00:00.023) 0:00:41.438 ***** included: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/assert_profile_present.yml for sut included: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/assert_profile_present.yml for sut included: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/assert_profile_present.yml for sut TASK [Include the task 'get_profile_stat.yml'] ********************************* task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/assert_profile_present.yml:3 Wednesday 10 January 2024 15:32:46 +0000 (0:00:00.060) 0:00:41.498 ***** included: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_profile_stat.yml for sut TASK [Initialize NM profile exist and ansible_managed comment flag] ************ task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_profile_stat.yml:3 Wednesday 10 January 2024 15:32:46 +0000 (0:00:00.033) 0:00:41.532 ***** ok: [sut] => { "ansible_facts": { "lsr_net_profile_ansible_managed": false, "lsr_net_profile_exists": false, "lsr_net_profile_fingerprint": false }, "changed": false } TASK [Stat profile file] ******************************************************* task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_profile_stat.yml:9 Wednesday 10 January 2024 15:32:46 +0000 (0:00:00.019) 0:00:41.551 ***** ok: [sut] => { "changed": false, "stat": { "atime": 1704900760.9163504, "block_size": 4096, "blocks": 8, "ctime": 1704900760.9153504, "dev": 51713, "device_type": 0, "executable": false, "exists": true, "gid": 0, "gr_name": "root", "inode": 25404, "isblk": false, "ischr": false, "isdir": false, "isfifo": false, "isgid": false, "islnk": false, "isreg": true, "issock": false, "isuid": false, "mode": "0644", "mtime": 1704900760.9153504, "nlink": 1, "path": "/etc/sysconfig/network-scripts/ifcfg-bond0", "pw_name": "root", "readable": true, "rgrp": true, "roth": true, "rusr": true, "size": 374, "uid": 0, "wgrp": false, "woth": false, "writeable": true, "wusr": true, "xgrp": false, "xoth": false, "xusr": false } } TASK [Set NM profile exist flag based on the profile files] ******************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_profile_stat.yml:17 Wednesday 10 January 2024 15:32:46 +0000 (0:00:00.134) 0:00:41.686 ***** ok: [sut] => { "ansible_facts": { "lsr_net_profile_exists": true }, "changed": false } TASK [Get NM profile info] ***************************************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_profile_stat.yml:25 Wednesday 10 January 2024 15:32:46 +0000 (0:00:00.021) 0:00:41.708 ***** ok: [sut] => { "changed": false, "cmd": "nmcli -f NAME,FILENAME connection show |grep bond0 | grep /etc", "delta": "0:00:00.032973", "end": "2024-01-10 15:32:47.086198", "rc": 0, "start": "2024-01-10 15:32:47.053225" } STDOUT: bond0 /etc/sysconfig/network-scripts/ifcfg-bond0 bond0.0 /etc/sysconfig/network-scripts/ifcfg-bond0.0 bond0.1 /etc/sysconfig/network-scripts/ifcfg-bond0.1 TASK [Set NM profile exist flag and ansible_managed flag true based on the nmcli output] *** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_profile_stat.yml:35 Wednesday 10 January 2024 15:32:47 +0000 (0:00:00.165) 0:00:41.874 ***** ok: [sut] => { "ansible_facts": { "lsr_net_profile_ansible_managed": true, "lsr_net_profile_exists": true, "lsr_net_profile_fingerprint": true }, "changed": false } TASK [Get the ansible_managed comment in ifcfg-bond0] ************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_profile_stat.yml:49 Wednesday 10 January 2024 15:32:47 +0000 (0:00:00.022) 0:00:41.896 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Verify the ansible_managed comment in ifcfg-bond0] *********************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_profile_stat.yml:56 Wednesday 10 January 2024 15:32:47 +0000 (0:00:00.021) 0:00:41.918 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Get the fingerprint comment in ifcfg-bond0] ****************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_profile_stat.yml:62 Wednesday 10 January 2024 15:32:47 +0000 (0:00:00.021) 0:00:41.939 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Verify the fingerprint comment in ifcfg-bond0] *************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_profile_stat.yml:69 Wednesday 10 January 2024 15:32:47 +0000 (0:00:00.021) 0:00:41.961 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Assert that the profile is present - 'bond0'] **************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/assert_profile_present.yml:5 Wednesday 10 January 2024 15:32:47 +0000 (0:00:00.021) 0:00:41.982 ***** ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Assert that the ansible managed comment is present in 'bond0'] *********** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/assert_profile_present.yml:10 Wednesday 10 January 2024 15:32:47 +0000 (0:00:00.021) 0:00:42.003 ***** ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Assert that the fingerprint comment is present in bond0] ***************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/assert_profile_present.yml:15 Wednesday 10 January 2024 15:32:47 +0000 (0:00:00.021) 0:00:42.025 ***** ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Include the task 'get_profile_stat.yml'] ********************************* task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/assert_profile_present.yml:3 Wednesday 10 January 2024 15:32:47 +0000 (0:00:00.019) 0:00:42.044 ***** included: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_profile_stat.yml for sut TASK [Initialize NM profile exist and ansible_managed comment flag] ************ task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_profile_stat.yml:3 Wednesday 10 January 2024 15:32:47 +0000 (0:00:00.032) 0:00:42.077 ***** ok: [sut] => { "ansible_facts": { "lsr_net_profile_ansible_managed": false, "lsr_net_profile_exists": false, "lsr_net_profile_fingerprint": false }, "changed": false } TASK [Stat profile file] ******************************************************* task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_profile_stat.yml:9 Wednesday 10 January 2024 15:32:47 +0000 (0:00:00.040) 0:00:42.117 ***** ok: [sut] => { "changed": false, "stat": { "atime": 1704900760.9793503, "block_size": 4096, "blocks": 8, "ctime": 1704900760.9793503, "dev": 51713, "device_type": 0, "executable": false, "exists": true, "gid": 0, "gr_name": "root", "inode": 25411, "isblk": false, "ischr": false, "isdir": false, "isfifo": false, "isgid": false, "islnk": false, "isreg": true, "issock": false, "isuid": false, "mode": "0644", "mtime": 1704900760.9793503, "nlink": 1, "path": "/etc/sysconfig/network-scripts/ifcfg-bond0.0", "pw_name": "root", "readable": true, "rgrp": true, "roth": true, "rusr": true, "size": 175, "uid": 0, "wgrp": false, "woth": false, "writeable": true, "wusr": true, "xgrp": false, "xoth": false, "xusr": false } } TASK [Set NM profile exist flag based on the profile files] ******************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_profile_stat.yml:17 Wednesday 10 January 2024 15:32:47 +0000 (0:00:00.135) 0:00:42.252 ***** ok: [sut] => { "ansible_facts": { "lsr_net_profile_exists": true }, "changed": false } TASK [Get NM profile info] ***************************************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_profile_stat.yml:25 Wednesday 10 January 2024 15:32:47 +0000 (0:00:00.021) 0:00:42.274 ***** ok: [sut] => { "changed": false, "cmd": "nmcli -f NAME,FILENAME connection show |grep bond0.0 | grep /etc", "delta": "0:00:00.030241", "end": "2024-01-10 15:32:47.648179", "rc": 0, "start": "2024-01-10 15:32:47.617938" } STDOUT: bond0.0 /etc/sysconfig/network-scripts/ifcfg-bond0.0 TASK [Set NM profile exist flag and ansible_managed flag true based on the nmcli output] *** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_profile_stat.yml:35 Wednesday 10 January 2024 15:32:47 +0000 (0:00:00.161) 0:00:42.435 ***** ok: [sut] => { "ansible_facts": { "lsr_net_profile_ansible_managed": true, "lsr_net_profile_exists": true, "lsr_net_profile_fingerprint": true }, "changed": false } TASK [Get the ansible_managed comment in ifcfg-bond0.0] ************************ task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_profile_stat.yml:49 Wednesday 10 January 2024 15:32:47 +0000 (0:00:00.022) 0:00:42.458 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Verify the ansible_managed comment in ifcfg-bond0.0] ********************* task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_profile_stat.yml:56 Wednesday 10 January 2024 15:32:47 +0000 (0:00:00.021) 0:00:42.480 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Get the fingerprint comment in ifcfg-bond0.0] **************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_profile_stat.yml:62 Wednesday 10 January 2024 15:32:47 +0000 (0:00:00.021) 0:00:42.501 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Verify the fingerprint comment in ifcfg-bond0.0] ************************* task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_profile_stat.yml:69 Wednesday 10 January 2024 15:32:47 +0000 (0:00:00.021) 0:00:42.523 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Assert that the profile is present - 'bond0.0'] ************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/assert_profile_present.yml:5 Wednesday 10 January 2024 15:32:47 +0000 (0:00:00.021) 0:00:42.544 ***** ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Assert that the ansible managed comment is present in 'bond0.0'] ********* task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/assert_profile_present.yml:10 Wednesday 10 January 2024 15:32:47 +0000 (0:00:00.021) 0:00:42.566 ***** ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Assert that the fingerprint comment is present in bond0.0] *************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/assert_profile_present.yml:15 Wednesday 10 January 2024 15:32:47 +0000 (0:00:00.021) 0:00:42.588 ***** ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Include the task 'get_profile_stat.yml'] ********************************* task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/assert_profile_present.yml:3 Wednesday 10 January 2024 15:32:47 +0000 (0:00:00.020) 0:00:42.608 ***** included: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_profile_stat.yml for sut TASK [Initialize NM profile exist and ansible_managed comment flag] ************ task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_profile_stat.yml:3 Wednesday 10 January 2024 15:32:47 +0000 (0:00:00.042) 0:00:42.651 ***** ok: [sut] => { "ansible_facts": { "lsr_net_profile_ansible_managed": false, "lsr_net_profile_exists": false, "lsr_net_profile_fingerprint": false }, "changed": false } TASK [Stat profile file] ******************************************************* task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_profile_stat.yml:9 Wednesday 10 January 2024 15:32:47 +0000 (0:00:00.021) 0:00:42.672 ***** ok: [sut] => { "changed": false, "stat": { "atime": 1704900760.9973502, "block_size": 4096, "blocks": 8, "ctime": 1704900760.9973502, "dev": 51713, "device_type": 0, "executable": false, "exists": true, "gid": 0, "gr_name": "root", "inode": 25401, "isblk": false, "ischr": false, "isdir": false, "isfifo": false, "isgid": false, "islnk": false, "isreg": true, "issock": false, "isuid": false, "mode": "0644", "mtime": 1704900760.9973502, "nlink": 1, "path": "/etc/sysconfig/network-scripts/ifcfg-bond0.1", "pw_name": "root", "readable": true, "rgrp": true, "roth": true, "rusr": true, "size": 175, "uid": 0, "wgrp": false, "woth": false, "writeable": true, "wusr": true, "xgrp": false, "xoth": false, "xusr": false } } TASK [Set NM profile exist flag based on the profile files] ******************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_profile_stat.yml:17 Wednesday 10 January 2024 15:32:48 +0000 (0:00:00.137) 0:00:42.809 ***** ok: [sut] => { "ansible_facts": { "lsr_net_profile_exists": true }, "changed": false } TASK [Get NM profile info] ***************************************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_profile_stat.yml:25 Wednesday 10 January 2024 15:32:48 +0000 (0:00:00.021) 0:00:42.830 ***** ok: [sut] => { "changed": false, "cmd": "nmcli -f NAME,FILENAME connection show |grep bond0.1 | grep /etc", "delta": "0:00:00.029540", "end": "2024-01-10 15:32:53.234271", "rc": 0, "start": "2024-01-10 15:32:53.204731" } STDOUT: bond0.1 /etc/sysconfig/network-scripts/ifcfg-bond0.1 TASK [Set NM profile exist flag and ansible_managed flag true based on the nmcli output] *** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_profile_stat.yml:35 Wednesday 10 January 2024 15:32:53 +0000 (0:00:05.191) 0:00:48.022 ***** ok: [sut] => { "ansible_facts": { "lsr_net_profile_ansible_managed": true, "lsr_net_profile_exists": true, "lsr_net_profile_fingerprint": true }, "changed": false } TASK [Get the ansible_managed comment in ifcfg-bond0.1] ************************ task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_profile_stat.yml:49 Wednesday 10 January 2024 15:32:53 +0000 (0:00:00.023) 0:00:48.046 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Verify the ansible_managed comment in ifcfg-bond0.1] ********************* task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_profile_stat.yml:56 Wednesday 10 January 2024 15:32:53 +0000 (0:00:00.021) 0:00:48.067 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Get the fingerprint comment in ifcfg-bond0.1] **************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_profile_stat.yml:62 Wednesday 10 January 2024 15:32:53 +0000 (0:00:00.025) 0:00:48.092 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Verify the fingerprint comment in ifcfg-bond0.1] ************************* task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_profile_stat.yml:69 Wednesday 10 January 2024 15:32:53 +0000 (0:00:00.022) 0:00:48.115 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [Assert that the profile is present - 'bond0.1'] ************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/assert_profile_present.yml:5 Wednesday 10 January 2024 15:32:53 +0000 (0:00:00.021) 0:00:48.136 ***** ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Assert that the ansible managed comment is present in 'bond0.1'] ********* task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/assert_profile_present.yml:10 Wednesday 10 January 2024 15:32:53 +0000 (0:00:00.038) 0:00:48.174 ***** ok: [sut] => { "changed": false } MSG: All assertions passed TASK [Assert that the fingerprint comment is present in bond0.1] *************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/assert_profile_present.yml:15 Wednesday 10 January 2024 15:32:53 +0000 (0:00:00.022) 0:00:48.197 ***** ok: [sut] => { "changed": false } MSG: All assertions passed TASK [** TEST check polling interval] ****************************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tests_bond_deprecated.yml:70 Wednesday 10 January 2024 15:32:53 +0000 (0:00:00.020) 0:00:48.218 ***** ok: [sut] => { "attempts": 1, "changed": false, "cmd": [ "grep", "Polling Interval", "/proc/net/bonding/deprecated-bond" ], "delta": "0:00:00.003519", "end": "2024-01-10 15:32:53.566099", "rc": 0, "start": "2024-01-10 15:32:53.562580" } STDOUT: MII Polling Interval (ms): 110 TASK [** TEST check IPv4] ****************************************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tests_bond_deprecated.yml:76 Wednesday 10 January 2024 15:32:53 +0000 (0:00:00.136) 0:00:48.354 ***** ok: [sut] => { "attempts": 1, "changed": false, "cmd": [ "ip", "-4", "a", "s", "deprecated-bond" ], "delta": "0:00:00.004140", "end": "2024-01-10 15:32:58.786754", "rc": 0, "start": "2024-01-10 15:32:58.782614" } STDOUT: 17: deprecated-bond: mtu 1500 qdisc noqueue state UP group default qlen 1000 inet 192.0.2.189/24 brd 192.0.2.255 scope global noprefixroute dynamic deprecated-bond valid_lft 226sec preferred_lft 226sec TASK [** TEST check IPv6] ****************************************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tests_bond_deprecated.yml:83 Wednesday 10 January 2024 15:32:58 +0000 (0:00:05.221) 0:00:53.576 ***** ok: [sut] => { "attempts": 1, "changed": false, "cmd": [ "ip", "-6", "a", "s", "deprecated-bond" ], "delta": "0:00:00.004661", "end": "2024-01-10 15:32:58.926524", "rc": 0, "start": "2024-01-10 15:32:58.921863" } STDOUT: 17: deprecated-bond: mtu 1500 state UP qlen 1000 inet6 2001:db8::84/128 scope global noprefixroute dynamic valid_lft 226sec preferred_lft 226sec inet6 2001:db8::73a7:cccd:fb49:131e/64 scope global noprefixroute dynamic valid_lft 1790sec preferred_lft 1790sec inet6 fe80::ec80:87d2:1694:c0f9/64 scope link noprefixroute valid_lft forever preferred_lft forever TASK [linux-system-roles.network : Ensure ansible_facts used by role] ********** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:4 Wednesday 10 January 2024 15:32:58 +0000 (0:00:00.140) 0:00:53.716 ***** included: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/set_facts.yml for sut TASK [linux-system-roles.network : Ensure ansible_facts used by role are present] *** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/set_facts.yml:3 Wednesday 10 January 2024 15:32:59 +0000 (0:00:00.056) 0:00:53.773 ***** skipping: [sut] => { "censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": false } TASK [linux-system-roles.network : Check if system is ostree] ****************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/set_facts.yml:13 Wednesday 10 January 2024 15:32:59 +0000 (0:00:00.026) 0:00:53.799 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Set flag to indicate system is ostree] ****** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/set_facts.yml:18 Wednesday 10 January 2024 15:32:59 +0000 (0:00:00.019) 0:00:53.819 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Check which services are running] *********** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/set_facts.yml:22 Wednesday 10 January 2024 15:32:59 +0000 (0:00:00.025) 0:00:53.844 ***** ok: [sut] => { "censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": false } TASK [linux-system-roles.network : Check which packages are installed] ********* task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/set_facts.yml:27 Wednesday 10 January 2024 15:32:59 +0000 (0:00:00.722) 0:00:54.567 ***** ok: [sut] => { "censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": false } TASK [linux-system-roles.network : Print network provider] ********************* task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:7 Wednesday 10 January 2024 15:33:00 +0000 (0:00:00.916) 0:00:55.483 ***** ok: [sut] => {} MSG: Using network provider: nm TASK [linux-system-roles.network : Abort applying the network state configuration if using the `network_state` variable with the initscripts provider] *** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:11 Wednesday 10 January 2024 15:33:00 +0000 (0:00:00.021) 0:00:55.504 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Abort applying the network state configuration if the system version of the managed host is below 8] *** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:19 Wednesday 10 January 2024 15:33:00 +0000 (0:00:00.018) 0:00:55.523 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Install packages] *************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:30 Wednesday 10 January 2024 15:33:00 +0000 (0:00:00.039) 0:00:55.562 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Install NetworkManager and nmstate when using network_state variable] *** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:40 Wednesday 10 January 2024 15:33:00 +0000 (0:00:00.041) 0:00:55.604 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Install python3-libnmstate when using network_state variable] *** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:55 Wednesday 10 January 2024 15:33:00 +0000 (0:00:00.021) 0:00:55.626 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Restart NetworkManager due to wireless or team interfaces] *** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:71 Wednesday 10 January 2024 15:33:00 +0000 (0:00:00.019) 0:00:55.645 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Enable and start NetworkManager] ************ task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:85 Wednesday 10 January 2024 15:33:00 +0000 (0:00:00.024) 0:00:55.670 ***** ok: [sut] => { "censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": false } TASK [linux-system-roles.network : Enable and start wpa_supplicant] ************ task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:96 Wednesday 10 January 2024 15:33:06 +0000 (0:00:05.259) 0:01:00.929 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Enable network service] ********************* task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:105 Wednesday 10 January 2024 15:33:06 +0000 (0:00:00.025) 0:01:00.955 ***** skipping: [sut] => { "censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result", "changed": false } TASK [linux-system-roles.network : Ensure initscripts network file dependency is present] *** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:113 Wednesday 10 January 2024 15:33:06 +0000 (0:00:00.020) 0:01:00.975 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Configure networking connection profiles] *** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:122 Wednesday 10 January 2024 15:33:06 +0000 (0:00:00.037) 0:01:01.013 ***** changed: [sut] => { "_invocation": { "module_args": { "__debug_flags": "", "__header": "#\n# Ansible managed\n#\n# system_role:network\n", "connections": [ { "name": "bond0.1", "persistent_state": "absent", "state": "down" }, { "name": "bond0.0", "persistent_state": "absent", "state": "down" }, { "name": "bond0", "persistent_state": "absent", "state": "down" } ], "force_state_change": false, "ignore_errors": false, "provider": "nm" } }, "changed": true } STDERR: TASK [linux-system-roles.network : Configure networking state] ***************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:134 Wednesday 10 January 2024 15:33:07 +0000 (0:00:00.817) 0:01:01.830 ***** skipping: [sut] => { "changed": false, "skip_reason": "Conditional result was False" } TASK [linux-system-roles.network : Show stderr messages for the network_connections] *** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:140 Wednesday 10 January 2024 15:33:07 +0000 (0:00:00.020) 0:01:01.851 ***** ok: [sut] => { "__network_connections_result.stderr_lines": [ "" ] } TASK [linux-system-roles.network : Show debug messages for the network_connections] *** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:144 Wednesday 10 January 2024 15:33:07 +0000 (0:00:00.021) 0:01:01.872 ***** ok: [sut] => { "__network_connections_result": { "_invocation": { "module_args": { "__debug_flags": "", "__header": "#\n# Ansible managed\n#\n# system_role:network\n", "connections": [ { "name": "bond0.1", "persistent_state": "absent", "state": "down" }, { "name": "bond0.0", "persistent_state": "absent", "state": "down" }, { "name": "bond0", "persistent_state": "absent", "state": "down" } ], "force_state_change": false, "ignore_errors": false, "provider": "nm" } }, "changed": true, "failed": false, "stderr": "\n", "stderr_lines": [ "" ] } } TASK [linux-system-roles.network : Show debug messages for the network_state] *** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:149 Wednesday 10 January 2024 15:33:07 +0000 (0:00:00.021) 0:01:01.894 ***** skipping: [sut] => {} TASK [linux-system-roles.network : Re-test connectivity] *********************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:155 Wednesday 10 January 2024 15:33:07 +0000 (0:00:00.019) 0:01:01.913 ***** ok: [sut] => { "changed": false, "ping": "pong" } TASK [Delete the device 'deprecated-bond'] ************************************* task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tests_bond_deprecated.yml:110 Wednesday 10 January 2024 15:33:07 +0000 (0:00:00.133) 0:01:02.046 ***** ok: [sut] => { "changed": false, "cmd": [ "ip", "link", "del", "deprecated-bond" ], "delta": "0:00:00.011665", "end": "2024-01-10 15:33:07.409244", "failed_when_result": false, "rc": 1, "start": "2024-01-10 15:33:07.397579" } STDERR: Cannot find device "deprecated-bond" MSG: non-zero return code TASK [Remove test interfaces] ************************************************** task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/remove_test_interfaces_with_dhcp.yml:3 Wednesday 10 January 2024 15:33:07 +0000 (0:00:00.149) 0:01:02.195 ***** ok: [sut] => { "changed": false, "cmd": "ip link delete test1\nip link delete test2\nip link delete testbr\n", "delta": "0:00:00.041589", "end": "2024-01-10 15:33:07.585124", "rc": 0, "start": "2024-01-10 15:33:07.543535" } TASK [Stop dnsmasq/radvd services] ********************************************* task path: /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/remove_test_interfaces_with_dhcp.yml:11 Wednesday 10 January 2024 15:33:07 +0000 (0:00:00.176) 0:01:02.372 ***** ok: [sut] => { "changed": false, "cmd": "pkill -F /run/dhcp_testbr.pid\nrm -rf /run/dhcp_testbr.pid\nrm -rf /run/dhcp_testbr.lease\nif grep 'release 6' /etc/redhat-release; then\n # Stop radvd server\n service radvd stop\n iptables -D INPUT -i testbr -p udp --dport 67:68 --sport 67:68 -j ACCEPT\n\nfi\n", "delta": "0:00:00.024394", "end": "2024-01-10 15:33:07.740084", "rc": 0, "start": "2024-01-10 15:33:07.715690" } META: ran handlers META: ran handlers PLAY RECAP ********************************************************************* sut : ok=79 changed=3 unreachable=0 failed=0 skipped=44 rescued=0 ignored=0 Wednesday 10 January 2024 15:33:07 +0000 (0:00:00.143) 0:01:02.515 ***** =============================================================================== linux-system-roles.network : Check which packages are installed --------- 6.08s /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/set_facts.yml:27 Gathering Facts --------------------------------------------------------- 5.52s /WORKDIR/git-route_typedtuxjrqv/tests/tests_bond_deprecated_nm.yml:6 ---------- Gathering Facts --------------------------------------------------------- 5.42s /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tests_bond_deprecated.yml:3 --- linux-system-roles.network : Enable and start NetworkManager ------------ 5.26s /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:85 Check if system is ostree ----------------------------------------------- 5.22s /WORKDIR/git-route_typedtuxjrqv/tests/tasks/el_repo_setup.yml:19 -------------- ** TEST check IPv4 ------------------------------------------------------ 5.22s /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tests_bond_deprecated.yml:76 -- Get NM profile info ----------------------------------------------------- 5.19s /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_profile_stat.yml:25 - Get stat for interface deprecated-bond ---------------------------------- 5.17s /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_interface_stat.yml:3 Get stat for interface test1 -------------------------------------------- 5.15s /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/get_interface_stat.yml:3 Install dnsmasq --------------------------------------------------------- 3.23s /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/create_test_interfaces_with_dhcp.yml:3 Create test interfaces -------------------------------------------------- 1.32s /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/create_test_interfaces_with_dhcp.yml:30 linux-system-roles.network : Check which packages are installed --------- 0.92s /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/set_facts.yml:27 linux-system-roles.network : Configure networking connection profiles --- 0.82s /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:122 linux-system-roles.network : Check which services are running ----------- 0.77s /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/set_facts.yml:22 linux-system-roles.network : Check which services are running ----------- 0.72s /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/set_facts.yml:22 linux-system-roles.network : Configure networking connection profiles --- 0.61s /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:122 Install yum-utils package ----------------------------------------------- 0.46s /WORKDIR/git-route_typedtuxjrqv/tests/tasks/enable_epel.yml:24 ---------------- Install pgrep, sysctl --------------------------------------------------- 0.38s /WORKDIR/git-route_typedtuxjrqv/tests/playbooks/tasks/create_test_interfaces_with_dhcp.yml:20 linux-system-roles.network : Enable and start NetworkManager ------------ 0.36s /WORKDIR/git-route_typedtuxjrqv/tests/roles/linux-system-roles.network/tasks/main.yml:85 Enable EPEL 7 ----------------------------------------------------------- 0.30s /WORKDIR/git-route_typedtuxjrqv/tests/tasks/enable_epel.yml:30 ---------------- ---^---^---^---^---^--- # STDERR: ---v---v---v---v---v--- ---^---^---^---^---^---