[
{
    "branch": "main",
    "index": "0",
    "phase": "pre",
    "playbook": "github.com/vexxhost/zuul-config/playbooks/base/pre.yaml",
    "plays": [
        {
            "play": {
                "duration": {
                    "end": "2026-02-28T00:36:05.120219Z",
                    "start": "2026-02-28T00:36:02.412729Z"
                },
                "id": "0242ac17-0011-9e69-e787-000000000002",
                "name": "localhost"
            },
            "tasks": [
                {
                    "hosts": {
                        "localhost": {
                            "action": "gather_facts",
                            "ansible_facts": {
                                "ansible_apparmor": {
                                    "status": "disabled"
                                },
                                "ansible_architecture": "x86_64",
                                "ansible_bios_date": "NA",
                                "ansible_bios_vendor": "NA",
                                "ansible_bios_version": "NA",
                                "ansible_board_asset_tag": "NA",
                                "ansible_board_name": "NA",
                                "ansible_board_serial": "NA",
                                "ansible_board_vendor": "NA",
                                "ansible_board_version": "NA",
                                "ansible_chassis_asset_tag": "NA",
                                "ansible_chassis_serial": "NA",
                                "ansible_chassis_vendor": "NA",
                                "ansible_chassis_version": "NA",
                                "ansible_cmdline": {
                                    "BOOT_IMAGE": "/boot/vmlinuz-5.15.0-130-generic",
                                    "console": "ttyS0",
                                    "ro": true,
                                    "root": "UUID=5a569d86-b935-46dd-ae79-7a72a25b6a4c"
                                },
                                "ansible_date_time": {
                                    "date": "2026-02-28",
                                    "day": "28",
                                    "epoch": "1772238963",
                                    "epoch_int": "1772238963",
                                    "hour": "00",
                                    "iso8601": "2026-02-28T00:36:03Z",
                                    "iso8601_basic": "20260228T003603012886",
                                    "iso8601_basic_short": "20260228T003603",
                                    "iso8601_micro": "2026-02-28T00:36:03.012886Z",
                                    "minute": "36",
                                    "month": "02",
                                    "second": "03",
                                    "time": "00:36:03",
                                    "tz": "UTC",
                                    "tz_dst": "UTC",
                                    "tz_offset": "+0000",
                                    "weekday": "Saturday",
                                    "weekday_number": "6",
                                    "weeknumber": "08",
                                    "year": "2026"
                                },
                                "ansible_devices": {},
                                "ansible_distribution": "Debian",
                                "ansible_distribution_major_version": "12",
                                "ansible_distribution_release": "bookworm",
                                "ansible_distribution_version": "12",
                                "ansible_dns": {
                                    "nameservers": [
                                        "127.0.0.11"
                                    ],
                                    "options": {
                                        "edns0": true,
                                        "ndots": "0",
                                        "trust-ad": true
                                    },
                                    "search": [
                                        "openstacklocal"
                                    ]
                                },
                                "ansible_domain": "",
                                "ansible_effective_group_id": 0,
                                "ansible_effective_user_id": 0,
                                "ansible_env": {
                                    "ANSIBLE_CONFIG": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/ansible/pre_playbook_0/ansible.cfg",
                                    "DEBIAN_FRONTEND": "noninteractive",
                                    "GPG_KEY": "A035C8C19219BA821ECEA86B64E628F8D684696D",
                                    "HOME": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work",
                                    "HOSTNAME": "0a8996d2b663",
                                    "LANG": "C.UTF-8",
                                    "PATH": "/usr/local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin",
                                    "PWD": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/trusted/project_0/github.com/vexxhost/zuul-config/playbooks/base",
                                    "PYTHONPATH": "/var/lib/zuul/ansible/9",
                                    "PYTHON_SHA256": "8d3ed8ec5c88c1c95f5e558612a725450d2452813ddad5e58fdb1a53b1209b78",
                                    "PYTHON_VERSION": "3.11.14",
                                    "SSH_AGENT_PID": "1692994",
                                    "SSH_AUTH_SOCK": "/tmp/ssh-91VnYZQoFW9K/agent.1692993",
                                    "TMP": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/tmp",
                                    "ZUUL_ANSIBLE_SPLIT_STREAMS": "False",
                                    "ZUUL_JOBDIR": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a",
                                    "ZUUL_JOB_FAILURE_OUTPUT": "[]",
                                    "ZUUL_JOB_LOG_CONFIG": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/ansible/logging.json",
                                    "ZUUL_OUTPUT_MAX_BYTES": "1073741824"
                                },
                                "ansible_fibre_channel_wwn": [],
                                "ansible_fips": false,
                                "ansible_form_factor": "NA",
                                "ansible_fqdn": "0a8996d2b663",
                                "ansible_hostname": "0a8996d2b663",
                                "ansible_hostnqn": "",
                                "ansible_is_chroot": false,
                                "ansible_iscsi_iqn": "",
                                "ansible_kernel": "5.15.0-130-generic",
                                "ansible_kernel_version": "#140-Ubuntu SMP Wed Dec 18 17:59:53 UTC 2024",
                                "ansible_loadavg": {
                                    "15m": 2.193359375,
                                    "1m": 3.07861328125,
                                    "5m": 2.3681640625
                                },
                                "ansible_local": {},
                                "ansible_lsb": {},
                                "ansible_lvm": "N/A",
                                "ansible_machine": "x86_64",
                                "ansible_memfree_mb": 6476,
                                "ansible_memory_mb": {
                                    "nocache": {
                                        "free": 18400,
                                        "used": 13690
                                    },
                                    "real": {
                                        "free": 6476,
                                        "total": 32090,
                                        "used": 25614
                                    },
                                    "swap": {
                                        "cached": 0,
                                        "free": 0,
                                        "total": 0,
                                        "used": 0
                                    }
                                },
                                "ansible_memtotal_mb": 32090,
                                "ansible_mounts": [
                                    {
                                        "block_available": 9159870,
                                        "block_size": 4096,
                                        "block_total": 40601580,
                                        "block_used": 31441710,
                                        "device": "/dev/vda1",
                                        "fstype": "ext4",
                                        "inode_available": 16747020,
                                        "inode_total": 20643840,
                                        "inode_used": 3896820,
                                        "mount": "/etc/resolv.conf",
                                        "options": "ro,nosuid,nodev,relatime,discard,errors=remount-ro,bind",
                                        "size_available": 37518827520,
                                        "size_total": 166304071680,
                                        "uuid": "N/A"
                                    },
                                    {
                                        "block_available": 9159870,
                                        "block_size": 4096,
                                        "block_total": 40601580,
                                        "block_used": 31441710,
                                        "device": "/dev/vda1",
                                        "fstype": "ext4",
                                        "inode_available": 16747020,
                                        "inode_total": 20643840,
                                        "inode_used": 3896820,
                                        "mount": "/etc/hosts",
                                        "options": "ro,nosuid,nodev,relatime,discard,errors=remount-ro,bind",
                                        "size_available": 37518827520,
                                        "size_total": 166304071680,
                                        "uuid": "N/A"
                                    },
                                    {
                                        "block_available": 9159866,
                                        "block_size": 4096,
                                        "block_total": 40601580,
                                        "block_used": 31441714,
                                        "device": "/dev/vda1",
                                        "fstype": "ext4",
                                        "inode_available": 16747017,
                                        "inode_total": 20643840,
                                        "inode_used": 3896823,
                                        "mount": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work",
                                        "options": "rw,nosuid,nodev,relatime,discard,errors=remount-ro,bind",
                                        "size_available": 37518811136,
                                        "size_total": 166304071680,
                                        "uuid": "N/A"
                                    },
                                    {
                                        "block_available": 9159865,
                                        "block_size": 4096,
                                        "block_total": 40601580,
                                        "block_used": 31441715,
                                        "device": "/dev/vda1",
                                        "fstype": "ext4",
                                        "inode_available": 16747016,
                                        "inode_total": 20643840,
                                        "inode_used": 3896824,
                                        "mount": "/var/lib/zuul/ansible/9",
                                        "options": "ro,nosuid,nodev,relatime,discard,errors=remount-ro,bind",
                                        "size_available": 37518807040,
                                        "size_total": 166304071680,
                                        "uuid": "N/A"
                                    },
                                    {
                                        "block_available": 9159865,
                                        "block_size": 4096,
                                        "block_total": 40601580,
                                        "block_used": 31441715,
                                        "device": "/dev/vda1",
                                        "fstype": "ext4",
                                        "inode_available": 16747016,
                                        "inode_total": 20643840,
                                        "inode_used": 3896824,
                                        "mount": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/ansible",
                                        "options": "ro,nosuid,nodev,relatime,discard,errors=remount-ro,bind",
                                        "size_available": 37518807040,
                                        "size_total": 166304071680,
                                        "uuid": "N/A"
                                    },
                                    {
                                        "block_available": 9159865,
                                        "block_size": 4096,
                                        "block_total": 40601580,
                                        "block_used": 31441715,
                                        "device": "/dev/vda1",
                                        "fstype": "ext4",
                                        "inode_available": 16747016,
                                        "inode_total": 20643840,
                                        "inode_used": 3896824,
                                        "mount": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/trusted",
                                        "options": "ro,nosuid,nodev,relatime,discard,errors=remount-ro,bind",
                                        "size_available": 37518807040,
                                        "size_total": 166304071680,
                                        "uuid": "N/A"
                                    },
                                    {
                                        "block_available": 9159865,
                                        "block_size": 4096,
                                        "block_total": 40601580,
                                        "block_used": 31441715,
                                        "device": "/dev/vda1",
                                        "fstype": "ext4",
                                        "inode_available": 16747016,
                                        "inode_total": 20643840,
                                        "inode_used": 3896824,
                                        "mount": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/untrusted",
                                        "options": "ro,nosuid,nodev,relatime,discard,errors=remount-ro,bind",
                                        "size_available": 37518807040,
                                        "size_total": 166304071680,
                                        "uuid": "N/A"
                                    },
                                    {
                                        "block_available": 9159865,
                                        "block_size": 4096,
                                        "block_total": 40601580,
                                        "block_used": 31441715,
                                        "device": "/dev/vda1",
                                        "fstype": "ext4",
                                        "inode_available": 16747016,
                                        "inode_total": 20643840,
                                        "inode_used": 3896824,
                                        "mount": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/ansible/pre_playbook_0",
                                        "options": "ro,nosuid,nodev,relatime,discard,errors=remount-ro,bind",
                                        "size_available": 37518807040,
                                        "size_total": 166304071680,
                                        "uuid": "N/A"
                                    },
                                    {
                                        "block_available": 9159860,
                                        "block_size": 4096,
                                        "block_total": 40601580,
                                        "block_used": 31441720,
                                        "device": "/dev/vda1",
                                        "fstype": "ext4",
                                        "inode_available": 16747010,
                                        "inode_total": 20643840,
                                        "inode_used": 3896830,
                                        "mount": "/etc/zuul/site-variables.yaml",
                                        "options": "ro,nosuid,nodev,relatime,discard,errors=remount-ro,bind",
                                        "size_available": 37518786560,
                                        "size_total": 166304071680,
                                        "uuid": "N/A"
                                    },
                                    {
                                        "block_available": 228407357,
                                        "block_size": 4096,
                                        "block_total": 263940717,
                                        "block_used": 35533360,
                                        "device": "/dev/vdb",
                                        "fstype": "ext4",
                                        "inode_available": 64821014,
                                        "inode_total": 67108864,
                                        "inode_used": 2287850,
                                        "mount": "/srv/static/logs",
                                        "options": "rw,nosuid,nodev,relatime,discard",
                                        "size_available": 935556534272,
                                        "size_total": 1081101176832,
                                        "uuid": "N/A"
                                    },
                                    {
                                        "block_available": 9159856,
                                        "block_size": 4096,
                                        "block_total": 40601580,
                                        "block_used": 31441724,
                                        "device": "/dev/vda1",
                                        "fstype": "ext4",
                                        "inode_available": 16747007,
                                        "inode_total": 20643840,
                                        "inode_used": 3896833,
                                        "mount": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/.ansible",
                                        "options": "rw,nosuid,nodev,relatime,discard,errors=remount-ro,bind",
                                        "size_available": 37518770176,
                                        "size_total": 166304071680,
                                        "uuid": "N/A"
                                    }
                                ],
                                "ansible_nodename": "0a8996d2b663",
                                "ansible_os_family": "Debian",
                                "ansible_pkg_mgr": "apt",
                                "ansible_proc_cmdline": {
                                    "BOOT_IMAGE": "/boot/vmlinuz-5.15.0-130-generic",
                                    "console": [
                                        "tty1",
                                        "ttyS0"
                                    ],
                                    "ro": true,
                                    "root": "UUID=5a569d86-b935-46dd-ae79-7a72a25b6a4c"
                                },
                                "ansible_processor": [
                                    "0",
                                    "AuthenticAMD",
                                    "AMD EPYC-Rome Processor",
                                    "1",
                                    "AuthenticAMD",
                                    "AMD EPYC-Rome Processor",
                                    "2",
                                    "AuthenticAMD",
                                    "AMD EPYC-Rome Processor",
                                    "3",
                                    "AuthenticAMD",
                                    "AMD EPYC-Rome Processor",
                                    "4",
                                    "AuthenticAMD",
                                    "AMD EPYC-Rome Processor",
                                    "5",
                                    "AuthenticAMD",
                                    "AMD EPYC-Rome Processor",
                                    "6",
                                    "AuthenticAMD",
                                    "AMD EPYC-Rome Processor",
                                    "7",
                                    "AuthenticAMD",
                                    "AMD EPYC-Rome Processor",
                                    "8",
                                    "AuthenticAMD",
                                    "AMD EPYC-Rome Processor",
                                    "9",
                                    "AuthenticAMD",
                                    "AMD EPYC-Rome Processor",
                                    "10",
                                    "AuthenticAMD",
                                    "AMD EPYC-Rome Processor",
                                    "11",
                                    "AuthenticAMD",
                                    "AMD EPYC-Rome Processor",
                                    "12",
                                    "AuthenticAMD",
                                    "AMD EPYC-Rome Processor",
                                    "13",
                                    "AuthenticAMD",
                                    "AMD EPYC-Rome Processor",
                                    "14",
                                    "AuthenticAMD",
                                    "AMD EPYC-Rome Processor",
                                    "15",
                                    "AuthenticAMD",
                                    "AMD EPYC-Rome Processor"
                                ],
                                "ansible_processor_cores": 1,
                                "ansible_processor_count": 16,
                                "ansible_processor_nproc": 16,
                                "ansible_processor_threads_per_core": 1,
                                "ansible_processor_vcpus": 16,
                                "ansible_product_name": "NA",
                                "ansible_product_serial": "NA",
                                "ansible_product_uuid": "NA",
                                "ansible_product_version": "NA",
                                "ansible_python": {
                                    "executable": "/usr/local/lib/zuul/ansible/9/bin/python",
                                    "has_sslcontext": true,
                                    "type": "cpython",
                                    "version": {
                                        "major": 3,
                                        "micro": 14,
                                        "minor": 11,
                                        "releaselevel": "final",
                                        "serial": 0
                                    },
                                    "version_info": [
                                        3,
                                        11,
                                        14,
                                        "final",
                                        0
                                    ]
                                },
                                "ansible_python_version": "3.11.14",
                                "ansible_real_group_id": 0,
                                "ansible_real_user_id": 0,
                                "ansible_selinux": {
                                    "status": "disabled"
                                },
                                "ansible_selinux_python_present": true,
                                "ansible_service_mgr": "bwrap",
                                "ansible_swapfree_mb": 0,
                                "ansible_swaptotal_mb": 0,
                                "ansible_system": "Linux",
                                "ansible_system_capabilities": "N/A",
                                "ansible_system_capabilities_enforced": "N/A",
                                "ansible_system_vendor": "NA",
                                "ansible_uptime_seconds": 35902692,
                                "ansible_user_dir": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work",
                                "ansible_user_gecos": "root",
                                "ansible_user_gid": 0,
                                "ansible_user_id": "root",
                                "ansible_user_shell": "/bin/bash",
                                "ansible_user_uid": 0,
                                "ansible_userspace_architecture": "x86_64",
                                "ansible_userspace_bits": "64",
                                "ansible_virtualization_role": "host",
                                "ansible_virtualization_tech_guest": [],
                                "ansible_virtualization_tech_host": [
                                    "kvm"
                                ],
                                "ansible_virtualization_type": "kvm",
                                "gather_subset": [
                                    "all"
                                ],
                                "module_setup": true
                            },
                            "changed": false,
                            "deprecations": [],
                            "warnings": []
                        }
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:36:03.421688Z",
                            "start": "2026-02-28T00:36:02.420446Z"
                        },
                        "id": "0242ac17-0011-9e69-e787-00000000002a",
                        "name": "Gathering Facts"
                    }
                },
                {
                    "hosts": {
                        "localhost": {
                            "action": "include_role",
                            "changed": false,
                            "include_args": {
                                "name": "set-zuul-log-path-fact"
                            }
                        }
                    },
                    "role": {
                        "id": "0242ac17-0011-9e69-e787-000000000006",
                        "name": "emit-job-header",
                        "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/emit-job-header"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:36:03.461241Z",
                            "start": "2026-02-28T00:36:03.425971Z"
                        },
                        "id": "0242ac17-0011-9e69-e787-000000000008",
                        "name": "Setup log path fact"
                    }
                },
                {
                    "hosts": {
                        "localhost": {
                            "action": "set_fact",
                            "ansible_facts": {
                                "zuul_log_path": "058/oss/0588ed56b78644ddbc4c81220eec417a"
                            },
                            "changed": false
                        }
                    },
                    "role": {
                        "id": "0242ac17-0011-9e69-e787-000000000054",
                        "name": "set-zuul-log-path-fact",
                        "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/set-zuul-log-path-fact"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:36:03.496718Z",
                            "start": "2026-02-28T00:36:03.472153Z"
                        },
                        "id": "0242ac17-0011-9e69-e787-000000000056",
                        "name": "Set log path for a build"
                    }
                },
                {
                    "hosts": {
                        "localhost": {
                            "action": "debug",
                            "changed": false,
                            "msg": "# Job Information\nAnsible Version: 2.16.16\nJob: ansible-collection-kubernetes-molecule-bgp\nPipeline: check\nExecutor: 0a8996d2b663\nTriggered by: https://github.com/vexxhost/ansible-collection-kubernetes/pull/233\nEvent ID: 42d4a9f0-143d-11f1-8055-a157a4e3b739\n"
                        }
                    },
                    "role": {
                        "id": "0242ac17-0011-9e69-e787-000000000006",
                        "name": "emit-job-header",
                        "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/emit-job-header"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:36:03.552703Z",
                            "start": "2026-02-28T00:36:03.509225Z"
                        },
                        "id": "0242ac17-0011-9e69-e787-000000000009",
                        "name": "Print job information"
                    }
                },
                {
                    "hosts": {
                        "localhost": {
                            "action": "debug",
                            "changed": false,
                            "msg": "All items completed",
                            "results": [
                                {
                                    "ansible_loop_var": "zj_item",
                                    "changed": false,
                                    "failed": false,
                                    "msg": "# Node Information\nInventory Hostname: controller\nHostname: np0000157419\nUsername: zuul\nDistro: Debian 13.3\nProvider: yul1\nRegion: ca-ymq-1\nLabel: debian-trixie\nProduct Name: OpenStack Nova\nInterface IP: 199.204.45.6\n",
                                    "zj_item": "controller"
                                }
                            ]
                        }
                    },
                    "role": {
                        "id": "0242ac17-0011-9e69-e787-000000000006",
                        "name": "emit-job-header",
                        "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/emit-job-header"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:36:03.654107Z",
                            "start": "2026-02-28T00:36:03.556785Z"
                        },
                        "id": "0242ac17-0011-9e69-e787-00000000000a",
                        "name": "Print node information"
                    }
                },
                {
                    "hosts": {
                        "localhost": {
                            "action": "file",
                            "changed": true,
                            "diff": {
                                "after": {
                                    "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/logs/zuul-info",
                                    "state": "directory"
                                },
                                "before": {
                                    "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/logs/zuul-info",
                                    "state": "absent"
                                }
                            },
                            "gid": 0,
                            "group": "root",
                            "invocation": {
                                "module_args": {
                                    "_diff_peek": null,
                                    "_original_basename": null,
                                    "access_time": null,
                                    "access_time_format": "%Y%m%d%H%M.%S",
                                    "attributes": null,
                                    "follow": true,
                                    "force": false,
                                    "group": null,
                                    "mode": 493,
                                    "modification_time": null,
                                    "modification_time_format": "%Y%m%d%H%M.%S",
                                    "owner": null,
                                    "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/logs/zuul-info",
                                    "recurse": false,
                                    "selevel": null,
                                    "serole": null,
                                    "setype": null,
                                    "seuser": null,
                                    "src": null,
                                    "state": "directory",
                                    "unsafe_writes": false
                                }
                            },
                            "mode": "0755",
                            "owner": "root",
                            "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/logs/zuul-info",
                            "size": 4096,
                            "state": "directory",
                            "uid": 0
                        }
                    },
                    "role": {
                        "id": "0242ac17-0011-9e69-e787-00000000000d",
                        "name": "log-inventory",
                        "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/log-inventory"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:36:04.140148Z",
                            "start": "2026-02-28T00:36:03.660000Z"
                        },
                        "id": "0242ac17-0011-9e69-e787-00000000000f",
                        "name": "Ensure Zuul Ansible directory exists"
                    }
                },
                {
                    "hosts": {
                        "localhost": {
                            "action": "copy",
                            "changed": true,
                            "checksum": "9f2e947eb1417d23255a60e11c4fbd04d418e61d",
                            "dest": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/logs/zuul-info/inventory.yaml",
                            "diff": [],
                            "gid": 0,
                            "group": "root",
                            "invocation": {
                                "module_args": {
                                    "_original_basename": "inventory.yaml",
                                    "attributes": null,
                                    "backup": false,
                                    "checksum": "9f2e947eb1417d23255a60e11c4fbd04d418e61d",
                                    "content": null,
                                    "dest": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/logs/zuul-info",
                                    "directory_mode": null,
                                    "follow": false,
                                    "force": true,
                                    "group": null,
                                    "local_follow": null,
                                    "mode": 420,
                                    "owner": null,
                                    "remote_src": null,
                                    "selevel": null,
                                    "serole": null,
                                    "setype": null,
                                    "seuser": null,
                                    "src": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/.ansible/tmp/ansible-tmp-1772238964.1803796-84-85258928869746/source",
                                    "unsafe_writes": false,
                                    "validate": null
                                }
                            },
                            "md5sum": "03e174616ce6e0d01f1ec758980ccb50",
                            "mode": "0644",
                            "owner": "root",
                            "size": 12584,
                            "src": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/.ansible/tmp/ansible-tmp-1772238964.1803796-84-85258928869746/source",
                            "state": "file",
                            "uid": 0
                        }
                    },
                    "role": {
                        "id": "0242ac17-0011-9e69-e787-00000000000d",
                        "name": "log-inventory",
                        "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/log-inventory"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:36:05.120219Z",
                            "start": "2026-02-28T00:36:04.149626Z"
                        },
                        "id": "0242ac17-0011-9e69-e787-000000000010",
                        "name": "Copy ansible inventory to logs dir"
                    }
                }
            ]
        },
        {
            "play": {
                "duration": {
                    "end": "2026-02-28T00:36:11.932129Z",
                    "start": "2026-02-28T00:36:05.131085Z"
                },
                "id": "0242ac17-0011-9e69-e787-000000000011",
                "name": "all"
            },
            "tasks": [
                {
                    "hosts": {
                        "controller": {
                            "action": "stat",
                            "changed": false,
                            "failed_when_result": false,
                            "invocation": {
                                "module_args": {
                                    "checksum_algorithm": "sha1",
                                    "follow": false,
                                    "get_attributes": true,
                                    "get_checksum": true,
                                    "get_mime": true,
                                    "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/0588ed56b78644ddbc4c81220eec417a_id_rsa"
                                }
                            },
                            "stat": {
                                "exists": false
                            }
                        }
                    },
                    "role": {
                        "id": "0242ac17-0011-9e69-e787-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:36:05.417088Z",
                            "start": "2026-02-28T00:36:05.138472Z"
                        },
                        "id": "0242ac17-0011-9e69-e787-000000000018",
                        "name": "Check to see if ssh key was already created for this build"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "include_tasks",
                            "changed": false,
                            "include": "create-key-and-replace.yaml",
                            "include_args": {}
                        }
                    },
                    "role": {
                        "id": "0242ac17-0011-9e69-e787-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:36:05.453260Z",
                            "start": "2026-02-28T00:36:05.422028Z"
                        },
                        "id": "0242ac17-0011-9e69-e787-000000000019",
                        "name": "Create a new key in workspace based on build UUID"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "command",
                            "changed": true,
                            "cmd": [
                                "ssh-keygen",
                                "-t",
                                "rsa",
                                "-N",
                                "",
                                "-C",
                                "zuul-build-sshkey",
                                "-f",
                                "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/0588ed56b78644ddbc4c81220eec417a_id_rsa",
                                "-b",
                                "3072"
                            ],
                            "delta": "0:00:00.263775",
                            "end": "2026-02-28 00:36:06.098554",
                            "invocation": {
                                "module_args": {
                                    "_raw_params": "ssh-keygen -t rsa -N '' -C 'zuul-build-sshkey' -f /var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/0588ed56b78644ddbc4c81220eec417a_id_rsa -b 3072",
                                    "_uses_shell": false,
                                    "argv": null,
                                    "chdir": null,
                                    "creates": null,
                                    "executable": null,
                                    "expand_argument_vars": true,
                                    "removes": null,
                                    "stdin": null,
                                    "stdin_add_newline": true,
                                    "strip_empty_ends": true,
                                    "zuul_ansible_split_streams": false,
                                    "zuul_log_id": "0242ac17-0011-9e69-e787-00000000009c-0-controller",
                                    "zuul_no_log": false,
                                    "zuul_output_max_bytes": 1073741824
                                }
                            },
                            "msg": "",
                            "rc": 0,
                            "start": "2026-02-28 00:36:05.834779",
                            "stderr": "",
                            "stderr_lines": [],
                            "stdout": "Generating public/private rsa key pair.\nYour identification has been saved in /var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/0588ed56b78644ddbc4c81220eec417a_id_rsa\nYour public key has been saved in /var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/0588ed56b78644ddbc4c81220eec417a_id_rsa.pub\nThe key fingerprint is:\nSHA256:Pv/AjGz+LClUMtCN1OQ2GRmnCmBCEDeu4aSLPLPpQkI zuul-build-sshkey\nThe key's randomart image is:\n+---[RSA 3072]----+\n|*o=  o.=+o.      |\n| = o. o.+=       |\n|... ..  *        |\n|+E   .oo..       |\n|+.    .+S        |\n|+o    .o +       |\n|=+   .  *.+      |\n|. =   .oo+ .     |\n|o+     ..o+..    |\n+----[SHA256]-----+",
                            "stdout_lines": [
                                "Generating public/private rsa key pair.",
                                "Your identification has been saved in /var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/0588ed56b78644ddbc4c81220eec417a_id_rsa",
                                "Your public key has been saved in /var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/0588ed56b78644ddbc4c81220eec417a_id_rsa.pub",
                                "The key fingerprint is:",
                                "SHA256:Pv/AjGz+LClUMtCN1OQ2GRmnCmBCEDeu4aSLPLPpQkI zuul-build-sshkey",
                                "The key's randomart image is:",
                                "+---[RSA 3072]----+",
                                "|*o=  o.=+o.      |",
                                "| = o. o.+=       |",
                                "|... ..  *        |",
                                "|+E   .oo..       |",
                                "|+.    .+S        |",
                                "|+o    .o +       |",
                                "|=+   .  *.+      |",
                                "|. =   .oo+ .     |",
                                "|o+     ..o+..    |",
                                "+----[SHA256]-----+"
                            ],
                            "zuul_log_id": "0242ac17-0011-9e69-e787-00000000009c-0-controller"
                        }
                    },
                    "role": {
                        "id": "0242ac17-0011-9e69-e787-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:36:06.136007Z",
                            "start": "2026-02-28T00:36:05.474100Z"
                        },
                        "id": "0242ac17-0011-9e69-e787-00000000009c",
                        "name": "Create Temp SSH key"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "include_tasks",
                            "changed": false,
                            "include": "remote-linux.yaml",
                            "include_args": {}
                        }
                    },
                    "role": {
                        "id": "0242ac17-0011-9e69-e787-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:36:06.173728Z",
                            "start": "2026-02-28T00:36:06.140163Z"
                        },
                        "id": "0242ac17-0011-9e69-e787-00000000009d",
                        "name": "Remote setup ssh keys (linux)"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "lineinfile",
                            "changed": false,
                            "false_condition": "zuul_build_sshkey_cleanup",
                            "skip_reason": "Conditional result was False",
                            "skipped": true
                        }
                    },
                    "role": {
                        "id": "0242ac17-0011-9e69-e787-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:36:06.219208Z",
                            "start": "2026-02-28T00:36:06.193931Z"
                        },
                        "id": "0242ac17-0011-9e69-e787-0000000000bc",
                        "name": "Remove previously added zuul-build-sshkey"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "authorized_key",
                            "changed": true,
                            "comment": null,
                            "exclusive": false,
                            "follow": false,
                            "invocation": {
                                "module_args": {
                                    "changed": true,
                                    "comment": null,
                                    "exclusive": false,
                                    "follow": false,
                                    "key": "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQDc70ckMn+rUuodN5onMkRTQ9w1SmBB1vMuNh4LDfwyXmb3hzRWN5qXAwJ9TSEmTZKtDrxW4u6hAVwIyAGqCV+yAD7GsPcxMry0HWa7ZM3/TVlc9BaSd3PvJhkeqNY1Rq5Jo+4OQrBH0c92JVR8GdN4/ll9VgNascr4LNyQ/xssxBJouH/sWJi7fAt3Ob2UQ4NubEoJLcFRpPg7MR4/sMl3EQrFfmEUawWpvYx5DptyQKIYYuDLn3OxyLccvPgxH5/Mnca5QNDWfJh/54RfYx6yu4fM6c9ujiPxfevK4J2x12XjcFkHy3FublE11kHhuQc1RzoEkaXkPUD8pOaSaOxR3oEZUDucDHAdCXbB2x1GVBp7CVCGRK2Rd6QpkZg29Hs3UaON/hXg8fpaCBTHqUYZltyxgPtcGchY3ch/dQU0eSlkU51VBwsYTK3EPMZ+Ez36WVOHbBNUbM7s+KlRb6S/ddiwrVLLX6jejkRgLSKTLXPmtncdB9yzbnc3hfKMMqk= zuul-build-sshkey",
                                    "key_options": null,
                                    "keyfile": "/home/zuul/.ssh/authorized_keys",
                                    "manage_dir": true,
                                    "path": null,
                                    "state": "present",
                                    "user": "zuul",
                                    "validate_certs": true
                                }
                            },
                            "key": "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQDc70ckMn+rUuodN5onMkRTQ9w1SmBB1vMuNh4LDfwyXmb3hzRWN5qXAwJ9TSEmTZKtDrxW4u6hAVwIyAGqCV+yAD7GsPcxMry0HWa7ZM3/TVlc9BaSd3PvJhkeqNY1Rq5Jo+4OQrBH0c92JVR8GdN4/ll9VgNascr4LNyQ/xssxBJouH/sWJi7fAt3Ob2UQ4NubEoJLcFRpPg7MR4/sMl3EQrFfmEUawWpvYx5DptyQKIYYuDLn3OxyLccvPgxH5/Mnca5QNDWfJh/54RfYx6yu4fM6c9ujiPxfevK4J2x12XjcFkHy3FublE11kHhuQc1RzoEkaXkPUD8pOaSaOxR3oEZUDucDHAdCXbB2x1GVBp7CVCGRK2Rd6QpkZg29Hs3UaON/hXg8fpaCBTHqUYZltyxgPtcGchY3ch/dQU0eSlkU51VBwsYTK3EPMZ+Ez36WVOHbBNUbM7s+KlRb6S/ddiwrVLLX6jejkRgLSKTLXPmtncdB9yzbnc3hfKMMqk= zuul-build-sshkey",
                            "key_options": null,
                            "keyfile": "/home/zuul/.ssh/authorized_keys",
                            "manage_dir": true,
                            "path": null,
                            "state": "present",
                            "user": "zuul",
                            "validate_certs": true
                        }
                    },
                    "role": {
                        "id": "0242ac17-0011-9e69-e787-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:36:06.800748Z",
                            "start": "2026-02-28T00:36:06.227703Z"
                        },
                        "id": "0242ac17-0011-9e69-e787-0000000000bd",
                        "name": "Enable access via build key on all nodes"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "file",
                            "changed": false,
                            "diff": {
                                "after": {
                                    "path": "/home/zuul/.ssh"
                                },
                                "before": {
                                    "path": "/home/zuul/.ssh"
                                }
                            },
                            "gid": 1000,
                            "group": "zuul",
                            "invocation": {
                                "module_args": {
                                    "_diff_peek": null,
                                    "_original_basename": null,
                                    "access_time": null,
                                    "access_time_format": "%Y%m%d%H%M.%S",
                                    "attributes": null,
                                    "follow": true,
                                    "force": false,
                                    "group": null,
                                    "mode": 448,
                                    "modification_time": null,
                                    "modification_time_format": "%Y%m%d%H%M.%S",
                                    "owner": null,
                                    "path": "/home/zuul/.ssh",
                                    "recurse": false,
                                    "selevel": null,
                                    "serole": null,
                                    "setype": null,
                                    "seuser": null,
                                    "src": null,
                                    "state": "directory",
                                    "unsafe_writes": false
                                }
                            },
                            "mode": "0700",
                            "owner": "zuul",
                            "path": "/home/zuul/.ssh",
                            "size": 4096,
                            "state": "directory",
                            "uid": 1000
                        }
                    },
                    "role": {
                        "id": "0242ac17-0011-9e69-e787-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:36:07.032603Z",
                            "start": "2026-02-28T00:36:06.807082Z"
                        },
                        "id": "0242ac17-0011-9e69-e787-0000000000be",
                        "name": "Make sure user has a .ssh"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "copy",
                            "changed": true,
                            "checksum": "042b80e48209861fa351fdc0b380df7c20f06f74",
                            "dest": "/home/zuul/.ssh/id_rsa",
                            "diff": [],
                            "gid": 1000,
                            "group": "zuul",
                            "invocation": {
                                "module_args": {
                                    "_original_basename": "0588ed56b78644ddbc4c81220eec417a_id_rsa",
                                    "attributes": null,
                                    "backup": false,
                                    "checksum": "042b80e48209861fa351fdc0b380df7c20f06f74",
                                    "content": null,
                                    "dest": "/home/zuul/.ssh/id_rsa",
                                    "directory_mode": null,
                                    "follow": false,
                                    "force": false,
                                    "group": null,
                                    "local_follow": null,
                                    "mode": 384,
                                    "owner": null,
                                    "remote_src": null,
                                    "selevel": null,
                                    "serole": null,
                                    "setype": null,
                                    "seuser": null,
                                    "src": "/home/zuul/.ansible/tmp/ansible-tmp-1772238967.0787702-190-109793154121047/source",
                                    "unsafe_writes": false,
                                    "validate": null
                                }
                            },
                            "md5sum": "fef0b736200ad78d99d7579488f2c0bc",
                            "mode": "0600",
                            "owner": "zuul",
                            "size": 2602,
                            "src": "/home/zuul/.ansible/tmp/ansible-tmp-1772238967.0787702-190-109793154121047/source",
                            "state": "file",
                            "uid": 1000
                        }
                    },
                    "role": {
                        "id": "0242ac17-0011-9e69-e787-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:36:07.573330Z",
                            "start": "2026-02-28T00:36:07.037430Z"
                        },
                        "id": "0242ac17-0011-9e69-e787-0000000000bf",
                        "name": "Install build private key as SSH key on all nodes"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "copy",
                            "changed": true,
                            "checksum": "c3683adb8f3d6dd6f970aa592204d82e228f9c34",
                            "dest": "/home/zuul/.ssh/id_rsa.pub",
                            "diff": [],
                            "gid": 1000,
                            "group": "zuul",
                            "invocation": {
                                "module_args": {
                                    "_original_basename": "0588ed56b78644ddbc4c81220eec417a_id_rsa.pub",
                                    "attributes": null,
                                    "backup": false,
                                    "checksum": "c3683adb8f3d6dd6f970aa592204d82e228f9c34",
                                    "content": null,
                                    "dest": "/home/zuul/.ssh/id_rsa.pub",
                                    "directory_mode": null,
                                    "follow": false,
                                    "force": false,
                                    "group": null,
                                    "local_follow": null,
                                    "mode": 420,
                                    "owner": null,
                                    "remote_src": null,
                                    "selevel": null,
                                    "serole": null,
                                    "setype": null,
                                    "seuser": null,
                                    "src": "/home/zuul/.ansible/tmp/ansible-tmp-1772238967.6216726-200-155111450930584/source",
                                    "unsafe_writes": false,
                                    "validate": null
                                }
                            },
                            "md5sum": "2383a18da2bb6483bd37ad5655c7b28b",
                            "mode": "0644",
                            "owner": "zuul",
                            "size": 571,
                            "src": "/home/zuul/.ansible/tmp/ansible-tmp-1772238967.6216726-200-155111450930584/source",
                            "state": "file",
                            "uid": 1000
                        }
                    },
                    "role": {
                        "id": "0242ac17-0011-9e69-e787-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:36:08.120957Z",
                            "start": "2026-02-28T00:36:07.577104Z"
                        },
                        "id": "0242ac17-0011-9e69-e787-0000000000c0",
                        "name": "Install build public key as SSH key on all nodes"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "include_tasks",
                            "changed": false,
                            "false_condition": "ansible_os_family == \"Windows\"",
                            "skip_reason": "Conditional result was False",
                            "skipped": true
                        }
                    },
                    "role": {
                        "id": "0242ac17-0011-9e69-e787-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:36:08.151328Z",
                            "start": "2026-02-28T00:36:08.126170Z"
                        },
                        "id": "0242ac17-0011-9e69-e787-00000000009e",
                        "name": "Remote setup ssh keys (windows)"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "sshagent_remove_keys",
                            "changed": true,
                            "invocation": {
                                "module_args": {
                                    "remove": "^(?!\\(stdin\\)).*"
                                }
                            },
                            "removed": [
                                "/etc/zuul/id_rsa"
                            ]
                        }
                    },
                    "role": {
                        "id": "0242ac17-0011-9e69-e787-0000000000a3",
                        "name": "remove-zuul-sshkey",
                        "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/remove-zuul-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:36:08.533081Z",
                            "start": "2026-02-28T00:36:08.161583Z"
                        },
                        "id": "0242ac17-0011-9e69-e787-0000000000a5",
                        "name": "Remove master key from local agent"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "command",
                            "changed": true,
                            "cmd": [
                                "ssh-add",
                                "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/0588ed56b78644ddbc4c81220eec417a_id_rsa"
                            ],
                            "delta": "0:00:00.014344",
                            "end": "2026-02-28 00:36:08.811226",
                            "invocation": {
                                "module_args": {
                                    "_raw_params": "ssh-add /var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/0588ed56b78644ddbc4c81220eec417a_id_rsa",
                                    "_uses_shell": false,
                                    "argv": null,
                                    "chdir": null,
                                    "creates": null,
                                    "executable": null,
                                    "expand_argument_vars": true,
                                    "removes": null,
                                    "stdin": null,
                                    "stdin_add_newline": true,
                                    "strip_empty_ends": true,
                                    "zuul_ansible_split_streams": false,
                                    "zuul_log_id": "0242ac17-0011-9e69-e787-0000000000ab-0-controller",
                                    "zuul_no_log": false,
                                    "zuul_output_max_bytes": 1073741824
                                }
                            },
                            "msg": "",
                            "rc": 0,
                            "start": "2026-02-28 00:36:08.796882",
                            "stderr": "",
                            "stderr_lines": [],
                            "stdout": "Identity added: /var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/0588ed56b78644ddbc4c81220eec417a_id_rsa (zuul-build-sshkey)",
                            "stdout_lines": [
                                "Identity added: /var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/0588ed56b78644ddbc4c81220eec417a_id_rsa (zuul-build-sshkey)"
                            ],
                            "zuul_log_id": "0242ac17-0011-9e69-e787-0000000000ab-0-controller"
                        }
                    },
                    "role": {
                        "id": "0242ac17-0011-9e69-e787-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:36:08.860828Z",
                            "start": "2026-02-28T00:36:08.541463Z"
                        },
                        "id": "0242ac17-0011-9e69-e787-0000000000ab",
                        "name": "Add back temp key"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "ping",
                            "changed": false,
                            "invocation": {
                                "module_args": {
                                    "data": "pong"
                                }
                            },
                            "ping": "pong"
                        }
                    },
                    "role": {
                        "id": "0242ac17-0011-9e69-e787-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:36:09.225634Z",
                            "start": "2026-02-28T00:36:08.864780Z"
                        },
                        "id": "0242ac17-0011-9e69-e787-0000000000ac",
                        "name": "Verify we can still SSH to all nodes"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "command",
                            "changed": false,
                            "false_condition": "ansible_os_family == \"Windows\"",
                            "skip_reason": "Conditional result was False",
                            "skipped": true
                        }
                    },
                    "role": {
                        "id": "0242ac17-0011-9e69-e787-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:36:09.256206Z",
                            "start": "2026-02-28T00:36:09.230067Z"
                        },
                        "id": "0242ac17-0011-9e69-e787-0000000000ad",
                        "name": "Verify we can still SSH to all nodes (windows)"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "zuul_console",
                            "changed": false,
                            "invocation": {
                                "module_args": {
                                    "path": "/tmp/console-{log_uuid}.log",
                                    "port": 19885,
                                    "state": "present"
                                }
                            }
                        }
                    },
                    "role": {
                        "id": "0242ac17-0011-9e69-e787-00000000001b",
                        "name": "prepare-workspace",
                        "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/prepare-workspace"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:36:09.630114Z",
                            "start": "2026-02-28T00:36:09.267897Z"
                        },
                        "id": "0242ac17-0011-9e69-e787-00000000001d",
                        "name": "Start zuul_console daemon."
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "synchronize",
                            "censored": "the output has been hidden due to the fact that 'no_log: true' was specified for this result",
                            "changed": true
                        }
                    },
                    "role": {
                        "id": "0242ac17-0011-9e69-e787-00000000001b",
                        "name": "prepare-workspace",
                        "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/prepare-workspace"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:36:10.689586Z",
                            "start": "2026-02-28T00:36:09.636979Z"
                        },
                        "id": "0242ac17-0011-9e69-e787-00000000001e",
                        "name": "Synchronize src repos to workspace directory."
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "file",
                            "changed": false,
                            "msg": "All items completed",
                            "results": [
                                {
                                    "ansible_loop_var": "zj_output_dir",
                                    "changed": false,
                                    "failed": false,
                                    "invocation": {
                                        "module_args": {
                                            "_diff_peek": null,
                                            "_original_basename": null,
                                            "access_time": null,
                                            "access_time_format": "%Y%m%d%H%M.%S",
                                            "attributes": null,
                                            "follow": true,
                                            "force": false,
                                            "group": null,
                                            "mode": null,
                                            "modification_time": null,
                                            "modification_time_format": "%Y%m%d%H%M.%S",
                                            "owner": null,
                                            "path": "/home/zuul/zuul-output/logs",
                                            "recurse": false,
                                            "selevel": null,
                                            "serole": null,
                                            "setype": null,
                                            "seuser": null,
                                            "src": null,
                                            "state": "absent",
                                            "unsafe_writes": false
                                        }
                                    },
                                    "path": "/home/zuul/zuul-output/logs",
                                    "state": "absent",
                                    "zj_output_dir": "logs"
                                },
                                {
                                    "ansible_loop_var": "zj_output_dir",
                                    "changed": false,
                                    "failed": false,
                                    "invocation": {
                                        "module_args": {
                                            "_diff_peek": null,
                                            "_original_basename": null,
                                            "access_time": null,
                                            "access_time_format": "%Y%m%d%H%M.%S",
                                            "attributes": null,
                                            "follow": true,
                                            "force": false,
                                            "group": null,
                                            "mode": null,
                                            "modification_time": null,
                                            "modification_time_format": "%Y%m%d%H%M.%S",
                                            "owner": null,
                                            "path": "/home/zuul/zuul-output/artifacts",
                                            "recurse": false,
                                            "selevel": null,
                                            "serole": null,
                                            "setype": null,
                                            "seuser": null,
                                            "src": null,
                                            "state": "absent",
                                            "unsafe_writes": false
                                        }
                                    },
                                    "path": "/home/zuul/zuul-output/artifacts",
                                    "state": "absent",
                                    "zj_output_dir": "artifacts"
                                },
                                {
                                    "ansible_loop_var": "zj_output_dir",
                                    "changed": false,
                                    "failed": false,
                                    "invocation": {
                                        "module_args": {
                                            "_diff_peek": null,
                                            "_original_basename": null,
                                            "access_time": null,
                                            "access_time_format": "%Y%m%d%H%M.%S",
                                            "attributes": null,
                                            "follow": true,
                                            "force": false,
                                            "group": null,
                                            "mode": null,
                                            "modification_time": null,
                                            "modification_time_format": "%Y%m%d%H%M.%S",
                                            "owner": null,
                                            "path": "/home/zuul/zuul-output/docs",
                                            "recurse": false,
                                            "selevel": null,
                                            "serole": null,
                                            "setype": null,
                                            "seuser": null,
                                            "src": null,
                                            "state": "absent",
                                            "unsafe_writes": false
                                        }
                                    },
                                    "path": "/home/zuul/zuul-output/docs",
                                    "state": "absent",
                                    "zj_output_dir": "docs"
                                }
                            ]
                        }
                    },
                    "role": {
                        "id": "0242ac17-0011-9e69-e787-000000000020",
                        "name": "ensure-output-dirs",
                        "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/ensure-output-dirs"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:36:11.307413Z",
                            "start": "2026-02-28T00:36:10.696410Z"
                        },
                        "id": "0242ac17-0011-9e69-e787-000000000022",
                        "name": "Empty Zuul Output directories by removing them"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "file",
                            "changed": true,
                            "msg": "All items completed",
                            "results": [
                                {
                                    "ansible_loop_var": "zj_output_dir",
                                    "changed": true,
                                    "diff": {
                                        "after": {
                                            "mode": "0755",
                                            "path": "/home/zuul/zuul-output/logs",
                                            "state": "directory"
                                        },
                                        "before": {
                                            "mode": "0775",
                                            "path": "/home/zuul/zuul-output/logs",
                                            "state": "absent"
                                        }
                                    },
                                    "failed": false,
                                    "gid": 1000,
                                    "group": "zuul",
                                    "invocation": {
                                        "module_args": {
                                            "_diff_peek": null,
                                            "_original_basename": null,
                                            "access_time": null,
                                            "access_time_format": "%Y%m%d%H%M.%S",
                                            "attributes": null,
                                            "follow": true,
                                            "force": false,
                                            "group": null,
                                            "mode": 493,
                                            "modification_time": null,
                                            "modification_time_format": "%Y%m%d%H%M.%S",
                                            "owner": null,
                                            "path": "/home/zuul/zuul-output/logs",
                                            "recurse": false,
                                            "selevel": null,
                                            "serole": null,
                                            "setype": null,
                                            "seuser": null,
                                            "src": null,
                                            "state": "directory",
                                            "unsafe_writes": false
                                        }
                                    },
                                    "mode": "0755",
                                    "owner": "zuul",
                                    "path": "/home/zuul/zuul-output/logs",
                                    "size": 4096,
                                    "state": "directory",
                                    "uid": 1000,
                                    "zj_output_dir": "logs"
                                },
                                {
                                    "ansible_loop_var": "zj_output_dir",
                                    "changed": true,
                                    "diff": {
                                        "after": {
                                            "mode": "0755",
                                            "path": "/home/zuul/zuul-output/artifacts",
                                            "state": "directory"
                                        },
                                        "before": {
                                            "mode": "0775",
                                            "path": "/home/zuul/zuul-output/artifacts",
                                            "state": "absent"
                                        }
                                    },
                                    "failed": false,
                                    "gid": 1000,
                                    "group": "zuul",
                                    "invocation": {
                                        "module_args": {
                                            "_diff_peek": null,
                                            "_original_basename": null,
                                            "access_time": null,
                                            "access_time_format": "%Y%m%d%H%M.%S",
                                            "attributes": null,
                                            "follow": true,
                                            "force": false,
                                            "group": null,
                                            "mode": 493,
                                            "modification_time": null,
                                            "modification_time_format": "%Y%m%d%H%M.%S",
                                            "owner": null,
                                            "path": "/home/zuul/zuul-output/artifacts",
                                            "recurse": false,
                                            "selevel": null,
                                            "serole": null,
                                            "setype": null,
                                            "seuser": null,
                                            "src": null,
                                            "state": "directory",
                                            "unsafe_writes": false
                                        }
                                    },
                                    "mode": "0755",
                                    "owner": "zuul",
                                    "path": "/home/zuul/zuul-output/artifacts",
                                    "size": 4096,
                                    "state": "directory",
                                    "uid": 1000,
                                    "zj_output_dir": "artifacts"
                                },
                                {
                                    "ansible_loop_var": "zj_output_dir",
                                    "changed": true,
                                    "diff": {
                                        "after": {
                                            "mode": "0755",
                                            "path": "/home/zuul/zuul-output/docs",
                                            "state": "directory"
                                        },
                                        "before": {
                                            "mode": "0775",
                                            "path": "/home/zuul/zuul-output/docs",
                                            "state": "absent"
                                        }
                                    },
                                    "failed": false,
                                    "gid": 1000,
                                    "group": "zuul",
                                    "invocation": {
                                        "module_args": {
                                            "_diff_peek": null,
                                            "_original_basename": null,
                                            "access_time": null,
                                            "access_time_format": "%Y%m%d%H%M.%S",
                                            "attributes": null,
                                            "follow": true,
                                            "force": false,
                                            "group": null,
                                            "mode": 493,
                                            "modification_time": null,
                                            "modification_time_format": "%Y%m%d%H%M.%S",
                                            "owner": null,
                                            "path": "/home/zuul/zuul-output/docs",
                                            "recurse": false,
                                            "selevel": null,
                                            "serole": null,
                                            "setype": null,
                                            "seuser": null,
                                            "src": null,
                                            "state": "directory",
                                            "unsafe_writes": false
                                        }
                                    },
                                    "mode": "0755",
                                    "owner": "zuul",
                                    "path": "/home/zuul/zuul-output/docs",
                                    "size": 4096,
                                    "state": "directory",
                                    "uid": 1000,
                                    "zj_output_dir": "docs"
                                }
                            ]
                        }
                    },
                    "role": {
                        "id": "0242ac17-0011-9e69-e787-000000000020",
                        "name": "ensure-output-dirs",
                        "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/ensure-output-dirs"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:36:11.932129Z",
                            "start": "2026-02-28T00:36:11.316797Z"
                        },
                        "id": "0242ac17-0011-9e69-e787-000000000024",
                        "name": "Ensure Zuul Output directories exist"
                    }
                }
            ]
        }
    ],
    "stats": {
        "controller": {
            "changed": 8,
            "failures": 0,
            "ignored": 0,
            "ok": 15,
            "rescued": 0,
            "skipped": 3,
            "unreachable": 0
        },
        "localhost": {
            "changed": 2,
            "failures": 0,
            "ignored": 0,
            "ok": 6,
            "rescued": 0,
            "skipped": 0,
            "unreachable": 0
        }
    },
    "trusted": true
},
{
    "branch": "main",
    "index": "1",
    "phase": "pre",
    "playbook": "github.com/vexxhost/zuul-jobs/playbooks/molecule/pre.yaml",
    "plays": [
        {
            "play": {
                "duration": {
                    "end": "2026-02-28T00:36:16.251692Z",
                    "start": "2026-02-28T00:36:12.620702Z"
                },
                "id": "0242ac17-0011-c620-ed73-000000000002",
                "name": "all"
            },
            "tasks": [
                {
                    "hosts": {
                        "controller": {
                            "action": "ansible.builtin.unarchive",
                            "changed": true,
                            "dest": "/usr/local/bin",
                            "extract_results": {
                                "cmd": [
                                    "/usr/bin/tar",
                                    "--extract",
                                    "-C",
                                    "/usr/local/bin",
                                    "-z",
                                    "--show-transformed-names",
                                    "--strip-components=1",
                                    "-f",
                                    "/home/zuul/.ansible/tmp/ansible-tmp-1772238972.6706831-5-270654723568867/uv-x86_64-unknown-linux-gnuuzo2_c0p.tar.gz"
                                ],
                                "err": "",
                                "out": "",
                                "rc": 0
                            },
                            "gid": 0,
                            "group": "root",
                            "handler": "TgzArchive",
                            "invocation": {
                                "module_args": {
                                    "attributes": null,
                                    "copy": true,
                                    "creates": "/usr/local/bin/uv",
                                    "decrypt": true,
                                    "dest": "/usr/local/bin",
                                    "exclude": [],
                                    "extra_opts": [
                                        "--strip-components=1"
                                    ],
                                    "group": null,
                                    "include": [],
                                    "io_buffer_size": 65536,
                                    "keep_newer": false,
                                    "list_files": false,
                                    "mode": null,
                                    "owner": null,
                                    "remote_src": true,
                                    "selevel": null,
                                    "serole": null,
                                    "setype": null,
                                    "seuser": null,
                                    "src": "https://github.com/astral-sh/uv/releases/download/0.8.13/uv-x86_64-unknown-linux-gnu.tar.gz",
                                    "unsafe_writes": false,
                                    "validate_certs": true
                                }
                            },
                            "mode": "0755",
                            "owner": "root",
                            "size": 4096,
                            "src": "/home/zuul/.ansible/tmp/ansible-tmp-1772238972.6706831-5-270654723568867/uv-x86_64-unknown-linux-gnuuzo2_c0p.tar.gz",
                            "state": "directory",
                            "uid": 0
                        }
                    },
                    "role": {
                        "id": "0242ac17-0011-c620-ed73-000000000005",
                        "name": "setup-uv",
                        "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/untrusted/project_0/github.com/vexxhost/zuul-jobs/roles/setup-uv"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:36:15.711017Z",
                            "start": "2026-02-28T00:36:12.630902Z"
                        },
                        "id": "0242ac17-0011-c620-ed73-000000000007",
                        "name": "Extract archive"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "ansible.builtin.command",
                            "changed": true,
                            "cmd": [
                                "/usr/local/bin/uv",
                                "--version"
                            ],
                            "delta": "0:00:00.015666",
                            "end": "2026-02-28 00:36:16.048693",
                            "invocation": {
                                "module_args": {
                                    "_raw_params": "/usr/local/bin/uv --version",
                                    "_uses_shell": false,
                                    "argv": null,
                                    "chdir": null,
                                    "creates": null,
                                    "executable": null,
                                    "expand_argument_vars": true,
                                    "removes": null,
                                    "stdin": null,
                                    "stdin_add_newline": true,
                                    "strip_empty_ends": true,
                                    "zuul_ansible_split_streams": false,
                                    "zuul_log_id": "0242ac17-0011-c620-ed73-000000000008-1-controller",
                                    "zuul_no_log": false,
                                    "zuul_output_max_bytes": 1073741824
                                }
                            },
                            "msg": "",
                            "rc": 0,
                            "start": "2026-02-28 00:36:16.033027",
                            "stderr": "",
                            "stderr_lines": [],
                            "stdout": "uv 0.8.13",
                            "stdout_lines": [
                                "uv 0.8.13"
                            ],
                            "zuul_log_id": "0242ac17-0011-c620-ed73-000000000008-1-controller"
                        }
                    },
                    "role": {
                        "id": "0242ac17-0011-c620-ed73-000000000005",
                        "name": "setup-uv",
                        "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/untrusted/project_0/github.com/vexxhost/zuul-jobs/roles/setup-uv"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:36:16.251692Z",
                            "start": "2026-02-28T00:36:15.734359Z"
                        },
                        "id": "0242ac17-0011-c620-ed73-000000000008",
                        "name": "Print version"
                    }
                }
            ]
        }
    ],
    "stats": {
        "controller": {
            "changed": 2,
            "failures": 0,
            "ignored": 0,
            "ok": 2,
            "rescued": 0,
            "skipped": 0,
            "unreachable": 0
        }
    },
    "trusted": false
},
{
    "branch": "main",
    "index": "0",
    "phase": "run",
    "playbook": "github.com/vexxhost/zuul-jobs/playbooks/molecule/run.yaml",
    "plays": [
        {
            "play": {
                "duration": {
                    "end": "2026-02-28T00:40:49.975378Z",
                    "start": "2026-02-28T00:36:16.941015Z"
                },
                "id": "0242ac17-0011-f77d-8d47-000000000002",
                "name": "all"
            },
            "tasks": [
                {
                    "hosts": {
                        "controller": {
                            "action": "ansible.builtin.copy",
                            "changed": true,
                            "checksum": "9f2e947eb1417d23255a60e11c4fbd04d418e61d",
                            "dest": "src/github.com/vexxhost/ansible-collection-kubernetes/inventory.yaml",
                            "diff": [],
                            "gid": 1000,
                            "group": "zuul",
                            "invocation": {
                                "module_args": {
                                    "_original_basename": "inventory.yaml",
                                    "attributes": null,
                                    "backup": false,
                                    "checksum": "9f2e947eb1417d23255a60e11c4fbd04d418e61d",
                                    "content": null,
                                    "dest": "src/github.com/vexxhost/ansible-collection-kubernetes",
                                    "directory_mode": null,
                                    "follow": false,
                                    "force": true,
                                    "group": null,
                                    "local_follow": null,
                                    "mode": 420,
                                    "owner": null,
                                    "remote_src": null,
                                    "selevel": null,
                                    "serole": null,
                                    "setype": null,
                                    "seuser": null,
                                    "src": "/home/zuul/.ansible/tmp/ansible-tmp-1772238976.9979722-5-24958399197943/source",
                                    "unsafe_writes": false,
                                    "validate": null
                                }
                            },
                            "md5sum": "03e174616ce6e0d01f1ec758980ccb50",
                            "mode": "0644",
                            "owner": "zuul",
                            "size": 12584,
                            "src": "/home/zuul/.ansible/tmp/ansible-tmp-1772238976.9979722-5-24958399197943/source",
                            "state": "file",
                            "uid": 1000
                        }
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:36:17.872609Z",
                            "start": "2026-02-28T00:36:16.956237Z"
                        },
                        "id": "0242ac17-0011-f77d-8d47-000000000004",
                        "name": "Copy inventory file for Zuul"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "ansible.builtin.replace",
                            "changed": true,
                            "invocation": {
                                "module_args": {
                                    "after": null,
                                    "attributes": null,
                                    "backup": false,
                                    "before": null,
                                    "encoding": "utf-8",
                                    "group": null,
                                    "mode": null,
                                    "owner": null,
                                    "path": "src/github.com/vexxhost/ansible-collection-kubernetes/inventory.yaml",
                                    "regexp": "(^\\s*ansible_host:\\s*).*$",
                                    "replace": "\\1\"{{ nodepool.private_ipv4 }}\"",
                                    "selevel": null,
                                    "serole": null,
                                    "setype": null,
                                    "seuser": null,
                                    "unsafe_writes": false,
                                    "validate": null
                                }
                            },
                            "msg": "1 replacements made",
                            "rc": 0
                        }
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:36:18.181809Z",
                            "start": "2026-02-28T00:36:17.877746Z"
                        },
                        "id": "0242ac17-0011-f77d-8d47-000000000005",
                        "name": "Switch \"ansible_host\" to private IP"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "ansible.builtin.command",
                            "changed": true,
                            "cmd": [
                                "uv",
                                "run",
                                "molecule",
                                "test",
                                "--destroy",
                                "never",
                                "-s",
                                "bgp"
                            ],
                            "delta": "0:04:31.079416",
                            "end": "2026-02-28 00:40:49.637433",
                            "invocation": {
                                "module_args": {
                                    "_raw_params": "uv run molecule test --destroy never -s bgp",
                                    "_uses_shell": false,
                                    "argv": null,
                                    "chdir": "src/github.com/vexxhost/ansible-collection-kubernetes",
                                    "creates": null,
                                    "executable": null,
                                    "expand_argument_vars": true,
                                    "removes": null,
                                    "stdin": null,
                                    "stdin_add_newline": true,
                                    "strip_empty_ends": true,
                                    "zuul_ansible_split_streams": false,
                                    "zuul_log_id": "0242ac17-0011-f77d-8d47-000000000006-1-controller",
                                    "zuul_no_log": false,
                                    "zuul_output_max_bytes": 1073741824
                                }
                            },
                            "msg": "",
                            "rc": 0,
                            "start": "2026-02-28 00:36:18.558017",
                            "stderr": "",
                            "stderr_lines": [],
                            "stdout": "Using CPython 3.13.5 interpreter at: /usr/bin/python3\nCreating virtual environment at: .venv\nDownloading pygments (1.2MiB)\nDownloading cryptography (4.3MiB)\nDownloading ansible-core (2.3MiB)\n Downloading cryptography\n Downloading pygments\n Downloading ansible-core\nInstalled 36 packages in 50ms\nINFO     Collection 'vexxhost.kubernetes' detected.\nINFO     Scenarios will be used from 'extensions/molecule'\nCRITICAL 'extensions/molecule/default/molecule.yml' glob failed.  Exiting.\nINFO     default scenario not found, disabling shared state.\nINFO     [bgp > discovery] scenario test matrix: dependency, cleanup, destroy, syntax, create, prepare, converge, idempotence, side_effect, verify, cleanup, destroy\nINFO     [bgp > prerun] Performing prerun with role_name_check=0...\nINFO     [bgp > dependency] Executing\nWARNING  [bgp > dependency] Missing roles requirements file: requirements.yml\nWARNING  [bgp > dependency] Missing collections requirements file: collections.yml\nWARNING  [bgp > dependency] Executed: 2 missing (Remove from test_sequence to suppress)\nINFO     [bgp > cleanup] Executing\nWARNING  [bgp > cleanup] Executed: Missing playbook (Remove from test_sequence to suppress)\nINFO     [bgp > destroy] Executing\nWARNING  [bgp > destroy] Skipping, '--destroy=never' requested.\nINFO     [bgp > destroy] Executed: Successful\nINFO     [bgp > syntax] Executing\n\nplaybook: /home/zuul/src/github.com/vexxhost/ansible-collection-kubernetes/extensions/molecule/bgp/converge.yml\nINFO     [bgp > syntax] Executed: Successful\nINFO     [bgp > create] Executing\nWARNING  [bgp > create] Executed: Missing playbook (Remove from test_sequence to suppress)\nINFO     [bgp > prepare] Executing\n\nPLAY [Prepare] *****************************************************************\n\nTASK [Gathering Facts] *********************************************************\nSaturday 28 February 2026  00:36:39 +0000 (0:00:00.037)       0:00:00.037 *****\n[WARNING]: Host 'controller' is using the discovered Python interpreter at '/usr/bin/python3.13', but future installation of another Python interpreter could cause a different interpreter to be discovered. See https://docs.ansible.com/ansible-core/2.20/reference_appendices/interpreter_discovery.html for more information.\nok: [controller]\n\nTASK [Install Debian packages] *************************************************\nSaturday 28 February 2026  00:36:40 +0000 (0:00:01.324)       0:00:01.362 *****\nok: [controller]\n\nPLAY [Prepare BGP] *************************************************************\n\nTASK [Gathering Facts] *********************************************************\nSaturday 28 February 2026  00:36:46 +0000 (0:00:05.906)       0:00:07.268 *****\nok: [controller]\n\nTASK [Enable IP forwarding] ****************************************************\nSaturday 28 February 2026  00:36:47 +0000 (0:00:00.831)       0:00:08.100 *****\nchanged: [controller]\n\nTASK [Add FRR repository] ******************************************************\nSaturday 28 February 2026  00:36:47 +0000 (0:00:00.486)       0:00:08.586 *****\n[WARNING]: Module remote_tmp /root/.ansible/tmp did not exist and was created with a mode of 0700, this may cause issues when running as another user. To avoid this, create the remote_tmp dir with the correct permissions manually\nchanged: [controller]\n\nTASK [Install frr packages] ****************************************************\nSaturday 28 February 2026  00:36:51 +0000 (0:00:04.330)       0:00:12.917 *****\nchanged: [controller]\n\nTASK [Ensure bgpd is enabled] **************************************************\nSaturday 28 February 2026  00:37:01 +0000 (0:00:09.880)       0:00:22.797 *****\nchanged: [controller]\n\nTASK [Update FRR configuration] ************************************************\nSaturday 28 February 2026  00:37:02 +0000 (0:00:00.467)       0:00:23.264 *****\nchanged: [controller]\n\nTASK [Restart service frr] *****************************************************\nSaturday 28 February 2026  00:37:03 +0000 (0:00:01.015)       0:00:24.280 *****\nchanged: [controller]\n\nPLAY RECAP *********************************************************************\ncontroller                 : ok=9    changed=6    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0\n\n\nTASKS RECAP ********************************************************************\nSaturday 28 February 2026  00:37:09 +0000 (0:00:06.292)       0:00:30.572 *****\n===============================================================================\nInstall frr packages ---------------------------------------------------- 9.88s\nRestart service frr ----------------------------------------------------- 6.29s\nInstall Debian packages ------------------------------------------------- 5.91s\nAdd FRR repository ------------------------------------------------------ 4.33s\nGathering Facts --------------------------------------------------------- 1.32s\nUpdate FRR configuration ------------------------------------------------ 1.02s\nGathering Facts --------------------------------------------------------- 0.83s\nEnable IP forwarding ---------------------------------------------------- 0.49s\nEnsure bgpd is enabled -------------------------------------------------- 0.47s\nINFO     [bgp > prepare] Executed: Successful\nINFO     [bgp > converge] Executing\n\nPLAY [Configure Kubernetes VIP] ************************************************\n\nTASK [Gathering Facts] *********************************************************\nSaturday 28 February 2026  00:37:11 +0000 (0:00:00.017)       0:00:00.017 *****\n[WARNING]: Host 'controller' is using the discovered Python interpreter at '/usr/bin/python3.13', but future installation of another Python interpreter could cause a different interpreter to be discovered. See https://docs.ansible.com/ansible-core/2.20/reference_appendices/interpreter_discovery.html for more information.\nok: [controller]\n\nTASK [vexxhost.containers.directory : Create directory (/etc/kubernetes/manifests)] ***\nSaturday 28 February 2026  00:37:12 +0000 (0:00:01.102)       0:00:01.120 *****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Uninstall legacy HA stack] ****************\nSaturday 28 February 2026  00:37:12 +0000 (0:00:00.426)       0:00:01.546 *****\nok: [controller] => (item=/etc/keepalived/keepalived.conf)\nok: [controller] => (item=/etc/keepalived/check_apiserver.sh)\nok: [controller] => (item=/etc/kubernetes/manifests/keepalived.yaml)\nok: [controller] => (item=/etc/haproxy/haproxy.cfg)\nok: [controller] => (item=/etc/kubernetes/manifests/haproxy.yaml)\n\nTASK [vexxhost.kubernetes.kube_vip : Switch API server to run on port 6443] ****\nSaturday 28 February 2026  00:37:14 +0000 (0:00:01.468)       0:00:03.014 *****\n[ERROR]: Task failed: Module failed: Path /etc/kubernetes/manifests/kube-apiserver.yaml does not exist !\nOrigin: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kube_vip/tasks/main.yml:32:3\n\n30     - Restart \"kubelet\" service\n31\n32 - name: Switch API server to run on port 6443\n     ^ column 3\n\nfailed: [controller] (item=/etc/kubernetes/manifests/kube-apiserver.yaml) => {\"ansible_loop_var\": \"item\", \"changed\": false, \"item\": \"/etc/kubernetes/manifests/kube-apiserver.yaml\", \"msg\": \"Path /etc/kubernetes/manifests/kube-apiserver.yaml does not exist !\", \"rc\": 257}\n[ERROR]: Task failed: Module failed: Path /etc/kubernetes/controller-manager.conf does not exist !\nOrigin: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kube_vip/tasks/main.yml:32:3\n\n30     - Restart \"kubelet\" service\n31\n32 - name: Switch API server to run on port 6443\n     ^ column 3\n\nfailed: [controller] (item=/etc/kubernetes/controller-manager.conf) => {\"ansible_loop_var\": \"item\", \"changed\": false, \"item\": \"/etc/kubernetes/controller-manager.conf\", \"msg\": \"Path /etc/kubernetes/controller-manager.conf does not exist !\", \"rc\": 257}\n[ERROR]: Task failed: Module failed: Path /etc/kubernetes/scheduler.conf does not exist !\nOrigin: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kube_vip/tasks/main.yml:32:3\n\n30     - Restart \"kubelet\" service\n31\n32 - name: Switch API server to run on port 6443\n     ^ column 3\n\nfailed: [controller] (item=/etc/kubernetes/scheduler.conf) => {\"ansible_loop_var\": \"item\", \"changed\": false, \"item\": \"/etc/kubernetes/scheduler.conf\", \"msg\": \"Path /etc/kubernetes/scheduler.conf does not exist !\", \"rc\": 257}\n...ignoring\n\nTASK [vexxhost.kubernetes.kube_vip : Check if super-admin.conf exists] *********\nSaturday 28 February 2026  00:37:15 +0000 (0:00:00.954)       0:00:03.969 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Check if kubeadm has already run] *********\nSaturday 28 February 2026  00:37:15 +0000 (0:00:00.461)       0:00:04.430 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Set fact with KUBECONFIG path] ************\nSaturday 28 February 2026  00:37:15 +0000 (0:00:00.297)       0:00:04.728 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Set fact with KUBECONFIG path (with super-admin.conf)] ***\nSaturday 28 February 2026  00:37:15 +0000 (0:00:00.036)       0:00:04.764 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Upload Kubernetes manifest] ***************\nSaturday 28 February 2026  00:37:15 +0000 (0:00:00.042)       0:00:04.806 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Ensure kube-vip configuration file] *******\nSaturday 28 February 2026  00:37:16 +0000 (0:00:00.990)       0:00:05.797 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Flush handlers] ***************************\nSaturday 28 February 2026  00:37:17 +0000 (0:00:00.324)       0:00:06.122 *****\n\nPLAY [Install Kubernetes] ******************************************************\n\nTASK [Gathering Facts] *********************************************************\nSaturday 28 February 2026  00:37:17 +0000 (0:00:00.058)       0:00:06.180 *****\nok: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nSaturday 28 February 2026  00:37:18 +0000 (0:00:00.842)       0:00:07.022 *****\nok: [controller]\n\nTASK [vexxhost.containers.package : Update state for tar] **********************\nSaturday 28 February 2026  00:37:18 +0000 (0:00:00.355)       0:00:07.377 *****\nskipping: [controller]\n\nTASK [vexxhost.containers.directory : Create directory (/var/lib/downloads)] ***\nSaturday 28 February 2026  00:37:18 +0000 (0:00:00.047)       0:00:07.425 *****\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nSaturday 28 February 2026  00:37:18 +0000 (0:00:00.327)       0:00:07.752 *****\nok: [controller] => {\n    \"msg\": \"https://github.com/opencontainers/runc/releases/download/v1.4.0/runc.amd64\"\n}\n\nTASK [vexxhost.containers.download_artifact : Download item] *******************\nSaturday 28 February 2026  00:37:18 +0000 (0:00:00.112)       0:00:07.864 *****\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nSaturday 28 February 2026  00:37:19 +0000 (0:00:00.820)       0:00:08.685 *****\nskipping: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nSaturday 28 February 2026  00:37:19 +0000 (0:00:00.034)       0:00:08.719 *****\nok: [controller]\n\nTASK [vexxhost.containers.package : Update state for tar] **********************\nSaturday 28 February 2026  00:37:20 +0000 (0:00:00.306)       0:00:09.026 *****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nSaturday 28 February 2026  00:37:21 +0000 (0:00:01.206)       0:00:10.233 *****\nok: [controller] => {\n    \"msg\": \"https://github.com/containerd/containerd/releases/download/v2.2.0/containerd-2.2.0-linux-amd64.tar.gz\"\n}\n\nTASK [vexxhost.containers.download_artifact : Download item] *******************\nSaturday 28 February 2026  00:37:21 +0000 (0:00:00.075)       0:00:10.308 *****\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nSaturday 28 February 2026  00:37:22 +0000 (0:00:00.888)       0:00:11.197 *****\nchanged: [controller]\n\nTASK [vexxhost.containers.containerd : Install SELinux packages] ***************\nSaturday 28 February 2026  00:37:25 +0000 (0:00:03.141)       0:00:14.339 *****\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Set SELinux to permissive at runtime] ***\nSaturday 28 February 2026  00:37:25 +0000 (0:00:00.033)       0:00:14.372 *****\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Persist SELinux permissive mode] ********\nSaturday 28 February 2026  00:37:25 +0000 (0:00:00.036)       0:00:14.409 *****\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Install AppArmor packages] **************\nSaturday 28 February 2026  00:37:25 +0000 (0:00:00.036)       0:00:14.445 *****\nchanged: [controller]\n\nTASK [vexxhost.containers.containerd : Create systemd service file for containerd] ***\nSaturday 28 February 2026  00:37:31 +0000 (0:00:05.864)       0:00:20.310 *****\nchanged: [controller]\n\nTASK [vexxhost.containers.containerd : Create folders for configuration] *******\nSaturday 28 February 2026  00:37:32 +0000 (0:00:00.732)       0:00:21.043 *****\nchanged: [controller] => (item={'path': '/etc/containerd'})\nchanged: [controller] => (item={'path': '/var/lib/containerd', 'mode': '0o700'})\nchanged: [controller] => (item={'path': '/run/containerd', 'mode': '0o711'})\nchanged: [controller] => (item={'path': '/run/containerd/io.containerd.grpc.v1.cri', 'mode': '0o700'})\nchanged: [controller] => (item={'path': '/run/containerd/io.containerd.sandbox.controller.v1.shim', 'mode': '0o700'})\n\nTASK [vexxhost.containers.containerd : Create containerd config file] **********\nSaturday 28 February 2026  00:37:33 +0000 (0:00:01.490)       0:00:22.533 *****\nchanged: [controller]\n\nTASK [vexxhost.containers.containerd : Force any restarts if necessary] ********\nSaturday 28 February 2026  00:37:34 +0000 (0:00:00.835)       0:00:23.368 *****\n\nRUNNING HANDLER [vexxhost.containers.containerd : Restart containerd] **********\nSaturday 28 February 2026  00:37:34 +0000 (0:00:00.007)       0:00:23.376 *****\nchanged: [controller]\n\nRUNNING HANDLER [vexxhost.kubernetes.kubelet : Reload systemd] *****************\nSaturday 28 February 2026  00:37:35 +0000 (0:00:00.898)       0:00:24.274 *****\nok: [controller]\n\nTASK [vexxhost.containers.containerd : Enable and start service] ***************\nSaturday 28 February 2026  00:37:36 +0000 (0:00:01.613)       0:00:25.888 *****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes_upgrade_check : Retrieve the \"kubeadm-config\" ConfigMap] ***\nSaturday 28 February 2026  00:37:37 +0000 (0:00:00.768)       0:00:26.656 *****\n[ERROR]: Task failed: Module failed: Failed to import the required Python library (kubernetes) on np0000157419's Python /usr/bin/python3.13. Please read the module documentation and install it in the appropriate location. If the required library is installed, but Ansible is using the wrong Python interpreter, please consult the documentation on ansible_python_interpreter\nOrigin: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubernetes_upgrade_check/tasks/main.yml:16:3\n\n14\n15 ---\n16 - name: Retrieve the \"kubeadm-config\" ConfigMap\n     ^ column 3\n\nfatal: [controller]: FAILED! => {\"changed\": false, \"msg\": \"Failed to import the required Python library (kubernetes) on np0000157419's Python /usr/bin/python3.13. Please read the module documentation and install it in the appropriate location. If the required library is installed, but Ansible is using the wrong Python interpreter, please consult the documentation on ansible_python_interpreter\"}\n...ignoring\n\nTASK [vexxhost.kubernetes.kubernetes_upgrade_check : Parse the ClusterConfiguration] ***\nSaturday 28 February 2026  00:37:38 +0000 (0:00:00.690)       0:00:27.347 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes_upgrade_check : Retrieve the current Kubernetes version] ***\nSaturday 28 February 2026  00:37:38 +0000 (0:00:00.045)       0:00:27.393 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes_upgrade_check : Extract major, minor, and patch versions] ***\nSaturday 28 February 2026  00:37:38 +0000 (0:00:00.040)       0:00:27.433 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes_upgrade_check : Fail if we're jumping more than one minor version] ***\nSaturday 28 February 2026  00:37:38 +0000 (0:00:00.038)       0:00:27.472 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes_upgrade_check : Set fact if we need to upgrade] ***\nSaturday 28 February 2026  00:37:38 +0000 (0:00:00.036)       0:00:27.508 *****\nskipping: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nSaturday 28 February 2026  00:37:38 +0000 (0:00:00.047)       0:00:27.556 *****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nSaturday 28 February 2026  00:37:38 +0000 (0:00:00.317)       0:00:27.874 *****\nok: [controller] => {\n    \"msg\": \"https://dl.k8s.io/release/v1.34.0/bin/linux/amd64/kubeadm\"\n}\n\nTASK [vexxhost.containers.download_artifact : Download item] *******************\nSaturday 28 February 2026  00:37:38 +0000 (0:00:00.046)       0:00:27.920 *****\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nSaturday 28 February 2026  00:37:39 +0000 (0:00:00.994)       0:00:28.914 *****\nskipping: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nSaturday 28 February 2026  00:37:40 +0000 (0:00:00.033)       0:00:28.948 *****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nSaturday 28 February 2026  00:37:40 +0000 (0:00:00.303)       0:00:29.252 *****\nok: [controller] => {\n    \"msg\": \"https://dl.k8s.io/release/v1.34.0/bin/linux/amd64/kubectl\"\n}\n\nTASK [vexxhost.containers.download_artifact : Download item] *******************\nSaturday 28 February 2026  00:37:40 +0000 (0:00:00.049)       0:00:29.301 *****\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nSaturday 28 February 2026  00:37:41 +0000 (0:00:00.934)       0:00:30.236 *****\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Install SELinux packages] ***************\nSaturday 28 February 2026  00:37:41 +0000 (0:00:00.051)       0:00:30.288 *****\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Set SELinux to permissive at runtime] ***\nSaturday 28 February 2026  00:37:41 +0000 (0:00:00.038)       0:00:30.326 *****\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Persist SELinux permissive mode] ********\nSaturday 28 February 2026  00:37:41 +0000 (0:00:00.039)       0:00:30.366 *****\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Install AppArmor packages] **************\nSaturday 28 February 2026  00:37:41 +0000 (0:00:00.035)       0:00:30.402 *****\nok: [controller]\n\nTASK [vexxhost.containers.containerd : Create systemd service file for containerd] ***\nSaturday 28 February 2026  00:37:42 +0000 (0:00:00.965)       0:00:31.367 *****\nok: [controller]\n\nTASK [vexxhost.containers.containerd : Create folders for configuration] *******\nSaturday 28 February 2026  00:37:43 +0000 (0:00:00.697)       0:00:32.064 *****\nok: [controller] => (item={'path': '/etc/containerd'})\nok: [controller] => (item={'path': '/var/lib/containerd', 'mode': '0o700'})\nok: [controller] => (item={'path': '/run/containerd', 'mode': '0o711'})\nok: [controller] => (item={'path': '/run/containerd/io.containerd.grpc.v1.cri', 'mode': '0o700'})\nok: [controller] => (item={'path': '/run/containerd/io.containerd.sandbox.controller.v1.shim', 'mode': '0o700'})\n\nTASK [vexxhost.containers.containerd : Create containerd config file] **********\nSaturday 28 February 2026  00:37:44 +0000 (0:00:01.466)       0:00:33.530 *****\nok: [controller]\n\nTASK [vexxhost.containers.containerd : Force any restarts if necessary] ********\nSaturday 28 February 2026  00:37:45 +0000 (0:00:00.775)       0:00:34.305 *****\n\nTASK [vexxhost.containers.containerd : Enable and start service] ***************\nSaturday 28 February 2026  00:37:45 +0000 (0:00:00.006)       0:00:34.312 *****\nok: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nSaturday 28 February 2026  00:37:45 +0000 (0:00:00.506)       0:00:34.818 *****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nSaturday 28 February 2026  00:37:46 +0000 (0:00:00.310)       0:00:35.128 *****\nok: [controller] => {\n    \"msg\": \"https://github.com/kubernetes-sigs/cri-tools/releases/download/v1.34.0/crictl-v1.34.0-linux-amd64.tar.gz\"\n}\n\nTASK [vexxhost.containers.download_artifact : Download item] *******************\nSaturday 28 February 2026  00:37:46 +0000 (0:00:00.074)       0:00:35.203 *****\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nSaturday 28 February 2026  00:37:47 +0000 (0:00:00.843)       0:00:36.047 *****\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nSaturday 28 February 2026  00:37:48 +0000 (0:00:01.722)       0:00:37.769 *****\nok: [controller] => {\n    \"msg\": \"https://github.com/kubernetes-sigs/cri-tools/releases/download/v1.34.0/critest-v1.34.0-linux-amd64.tar.gz\"\n}\n\nTASK [vexxhost.containers.download_artifact : Download item] *******************\nSaturday 28 February 2026  00:37:48 +0000 (0:00:00.074)       0:00:37.843 *****\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nSaturday 28 February 2026  00:37:49 +0000 (0:00:00.780)       0:00:38.623 *****\nchanged: [controller]\n\nTASK [vexxhost.containers.cri_tools : Create crictl config] ********************\nSaturday 28 February 2026  00:37:51 +0000 (0:00:01.766)       0:00:40.389 *****\nchanged: [controller]\n\nTASK [vexxhost.containers.directory : Create directory (/opt/cni/bin)] *********\nSaturday 28 February 2026  00:37:52 +0000 (0:00:00.704)       0:00:41.094 *****\nchanged: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nSaturday 28 February 2026  00:37:52 +0000 (0:00:00.316)       0:00:41.410 *****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nSaturday 28 February 2026  00:37:52 +0000 (0:00:00.313)       0:00:41.724 *****\nok: [controller] => {\n    \"msg\": \"https://github.com/containernetworking/plugins/releases/download/v1.8.0/cni-plugins-linux-amd64-v1.8.0.tgz\"\n}\n\nTASK [vexxhost.containers.download_artifact : Download item] *******************\nSaturday 28 February 2026  00:37:52 +0000 (0:00:00.070)       0:00:41.794 *****\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nSaturday 28 February 2026  00:37:53 +0000 (0:00:01.055)       0:00:42.850 *****\nchanged: [controller]\n\nTASK [vexxhost.containers.cni_plugins : Gather variables for each operating system] ***\nSaturday 28 February 2026  00:37:56 +0000 (0:00:02.964)       0:00:45.815 *****\nok: [controller] => (item=/home/zuul/.ansible/collections/ansible_collections/vexxhost/containers/roles/cni_plugins/vars/debian.yml)\n\nTASK [vexxhost.containers.cni_plugins : Install additional packages] ***********\nSaturday 28 February 2026  00:37:56 +0000 (0:00:00.057)       0:00:45.872 *****\nok: [controller]\n\nTASK [vexxhost.containers.cni_plugins : Ensure IPv6 is enabled] ****************\nSaturday 28 February 2026  00:37:57 +0000 (0:00:01.014)       0:00:46.887 *****\nchanged: [controller]\n\nTASK [vexxhost.containers.cni_plugins : Enable kernel modules on-boot] *********\nSaturday 28 February 2026  00:37:58 +0000 (0:00:00.463)       0:00:47.350 *****\nchanged: [controller]\n\nTASK [vexxhost.containers.cni_plugins : Enable kernel modules in runtime] ******\nSaturday 28 February 2026  00:37:59 +0000 (0:00:00.694)       0:00:48.045 *****\nchanged: [controller] => (item=br_netfilter)\nok: [controller] => (item=ip_tables)\nchanged: [controller] => (item=ip6_tables)\nchanged: [controller] => (item=nf_conntrack)\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nSaturday 28 February 2026  00:38:00 +0000 (0:00:01.519)       0:00:49.564 *****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nSaturday 28 February 2026  00:38:00 +0000 (0:00:00.328)       0:00:49.893 *****\nok: [controller] => {\n    \"msg\": \"https://dl.k8s.io/release/v1.34.0/bin/linux/amd64/kubelet\"\n}\n\nTASK [vexxhost.containers.download_artifact : Download item] *******************\nSaturday 28 February 2026  00:38:01 +0000 (0:00:00.056)       0:00:49.949 *****\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nSaturday 28 February 2026  00:38:02 +0000 (0:00:01.074)       0:00:51.024 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Gather variables for each operating system] ***\nSaturday 28 February 2026  00:38:02 +0000 (0:00:00.047)       0:00:51.071 *****\nok: [controller] => (item=/home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubelet/vars/debian.yml)\n\nTASK [vexxhost.kubernetes.kubelet : Install coreutils] *************************\nSaturday 28 February 2026  00:38:02 +0000 (0:00:00.053)       0:00:51.125 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Install additional packages] ***************\nSaturday 28 February 2026  00:38:02 +0000 (0:00:00.044)       0:00:51.169 *****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Configure sysctl values] *******************\nSaturday 28 February 2026  00:38:05 +0000 (0:00:03.402)       0:00:54.572 *****\nok: [controller] => (item={'name': 'net.ipv4.ip_forward', 'value': 1})\nchanged: [controller] => (item={'name': 'net.bridge.bridge-nf-call-iptables', 'value': 1})\nchanged: [controller] => (item={'name': 'net.bridge.bridge-nf-call-ip6tables', 'value': 1})\nchanged: [controller] => (item={'name': 'net.ipv4.conf.all.rp_filter', 'value': 0})\nchanged: [controller] => (item={'name': 'fs.inotify.max_queued_events', 'value': 1048576})\nchanged: [controller] => (item={'name': 'fs.inotify.max_user_instances', 'value': 8192})\nchanged: [controller] => (item={'name': 'fs.inotify.max_user_watches', 'value': 1048576})\n\nTASK [vexxhost.kubernetes.kubelet : Create folders for kubernetes configuration] ***\nSaturday 28 February 2026  00:38:07 +0000 (0:00:02.285)       0:00:56.858 *****\nchanged: [controller] => (item=/etc/systemd/system/kubelet.service.d)\nok: [controller] => (item=/etc/kubernetes)\nok: [controller] => (item=/etc/kubernetes/manifests)\n\nTASK [vexxhost.kubernetes.kubelet : Add kubelet systemd service config] ********\nSaturday 28 February 2026  00:38:08 +0000 (0:00:00.885)       0:00:57.744 *****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Add kubeadm dropin for kubelet systemd service config] ***\nSaturday 28 February 2026  00:38:09 +0000 (0:00:00.742)       0:00:58.486 *****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Check swap status] *************************\nSaturday 28 February 2026  00:38:10 +0000 (0:00:00.731)       0:00:59.218 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Disable swap] ******************************\nSaturday 28 February 2026  00:38:10 +0000 (0:00:00.418)       0:00:59.636 *****\n[ERROR]: Task failed: Conditional result (False) was derived from value of type 'str' at '/home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubelet/tasks/main.yml:83:11'. Conditionals must have a boolean result.\n\nTask failed.\nOrigin: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubelet/tasks/main.yml:78:7\n\n76       register: kubelet_swapon\n77\n78     - name: Disable swap\n         ^ column 7\n\n<<< caused by >>>\n\nConditional result (False) was derived from value of type 'str' at '/home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubelet/tasks/main.yml:83:11'. Conditionals must have a boolean result.\nOrigin: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubelet/tasks/main.yml:83:11\n\n81       ignore_errors: \"{{ ansible_check_mode }}\"\n82       when:\n83         - kubelet_swapon.stdout\n             ^ column 11\n\nBroken conditionals can be temporarily allowed with the `ALLOW_BROKEN_CONDITIONALS` configuration option.\n\nfatal: [controller]: FAILED! => {\"changed\": false, \"msg\": \"Task failed: Conditional result (False) was derived from value of type 'str' at '/home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubelet/tasks/main.yml:83:11'. Conditionals must have a boolean result.\"}\n...ignoring\n\nTASK [vexxhost.kubernetes.kubelet : Remove swapfile from /etc/fstab] ***********\nSaturday 28 February 2026  00:38:10 +0000 (0:00:00.039)       0:00:59.675 *****\nok: [controller] => (item=swap)\nok: [controller] => (item=none)\n\nTASK [vexxhost.kubernetes.kubelet : Create noswap systemd service config file] ***\nSaturday 28 February 2026  00:38:11 +0000 (0:00:00.840)       0:01:00.516 *****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Enable noswap service] *********************\nSaturday 28 February 2026  00:38:12 +0000 (0:00:00.691)       0:01:01.207 *****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Force any restarts if necessary] ***********\nSaturday 28 February 2026  00:38:13 +0000 (0:00:00.758)       0:01:01.966 *****\n\nRUNNING HANDLER [vexxhost.kubernetes.kubelet : Reload systemd] *****************\nSaturday 28 February 2026  00:38:13 +0000 (0:00:00.005)       0:01:01.971 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Enable and start kubelet service] **********\nSaturday 28 February 2026  00:38:15 +0000 (0:00:02.039)       0:01:04.011 *****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Ensure availability of dbus on Debian] *****\nSaturday 28 February 2026  00:38:15 +0000 (0:00:00.832)       0:01:04.844 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Configure short hostname] ******************\nSaturday 28 February 2026  00:38:16 +0000 (0:00:01.023)       0:01:05.867 *****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Ensure hostname inside hosts file] *********\nSaturday 28 February 2026  00:38:17 +0000 (0:00:00.927)       0:01:06.794 *****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Remove kubernetes repository] ***********\nSaturday 28 February 2026  00:38:18 +0000 (0:00:00.427)       0:01:07.222 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Setup control plane] ********************\nSaturday 28 February 2026  00:38:18 +0000 (0:00:00.553)       0:01:07.775 *****\nincluded: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubernetes/tasks/control-plane.yml for controller\n\nTASK [vexxhost.kubernetes.kubernetes : Bootstrap cluster] **********************\nSaturday 28 February 2026  00:38:18 +0000 (0:00:00.088)       0:01:07.863 *****\nincluded: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubernetes/tasks/bootstrap-cluster.yml for controller\n\nTASK [vexxhost.kubernetes.kubernetes : Check if any control plane is bootstrapped] ***\nSaturday 28 February 2026  00:38:19 +0000 (0:00:00.088)       0:01:07.952 *****\nok: [controller] => (item=controller)\n\nTASK [vexxhost.kubernetes.kubernetes : Pick node from pre-existing cluster] ****\nSaturday 28 February 2026  00:38:19 +0000 (0:00:00.334)       0:01:08.286 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Select first node to initialize cluster] ***\nSaturday 28 February 2026  00:38:19 +0000 (0:00:00.042)       0:01:08.329 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Print selected bootstrap node] **********\nSaturday 28 February 2026  00:38:19 +0000 (0:00:00.060)       0:01:08.389 *****\nok: [controller] => {\n    \"msg\": \"controller\"\n}\n\nTASK [vexxhost.kubernetes.kubernetes : Upload cluster configuration for bootstrap node] ***\nSaturday 28 February 2026  00:38:19 +0000 (0:00:00.049)       0:01:08.438 *****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create pki folder] **********************\nSaturday 28 February 2026  00:38:20 +0000 (0:00:00.756)       0:01:09.195 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create kubernetes ca key] ***************\nSaturday 28 February 2026  00:38:20 +0000 (0:00:00.035)       0:01:09.230 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create kubernetes ca cert] **************\nSaturday 28 February 2026  00:38:20 +0000 (0:00:00.034)       0:01:09.265 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create etcd-ca key] *********************\nSaturday 28 February 2026  00:38:20 +0000 (0:00:00.038)       0:01:09.303 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create etcd-ca cert] ********************\nSaturday 28 February 2026  00:38:20 +0000 (0:00:00.039)       0:01:09.343 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create front-proxy-ca key] **************\nSaturday 28 February 2026  00:38:20 +0000 (0:00:00.032)       0:01:09.376 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create front-proxy-ca cert] *************\nSaturday 28 February 2026  00:38:20 +0000 (0:00:00.042)       0:01:09.418 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Initialize cluster] *********************\nSaturday 28 February 2026  00:38:20 +0000 (0:00:00.041)       0:01:09.460 *****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Check if the node is already part of the cluster] ***\nSaturday 28 February 2026  00:38:58 +0000 (0:00:38.438)       0:01:47.898 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Join cluster] ***************************\nSaturday 28 February 2026  00:38:59 +0000 (0:00:00.332)       0:01:48.230 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create folder for admin configuration] ***\nSaturday 28 February 2026  00:38:59 +0000 (0:00:00.042)       0:01:48.272 *****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Creating a symlink for admin configuration file] ***\nSaturday 28 February 2026  00:38:59 +0000 (0:00:00.330)       0:01:48.603 *****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Add bash autocomplete for kubectl] ******\nSaturday 28 February 2026  00:38:59 +0000 (0:00:00.320)       0:01:48.923 *****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Install PIP] ****************************\nSaturday 28 February 2026  00:39:00 +0000 (0:00:00.331)       0:01:49.254 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Install Kubernetes Python package using pip on supported systems] ***\nSaturday 28 February 2026  00:39:00 +0000 (0:00:00.046)       0:01:49.301 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Enable EPEL repository] *****************\nSaturday 28 February 2026  00:39:00 +0000 (0:00:00.045)       0:01:49.346 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Install Kubernetes Python package using package manager on supported systems] ***\nSaturday 28 February 2026  00:39:00 +0000 (0:00:00.046)       0:01:49.393 *****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Allow workload on control plane node] ***\nSaturday 28 February 2026  00:39:10 +0000 (0:00:10.441)       0:01:59.834 *****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Remove kube-proxy resources] ************\nSaturday 28 February 2026  00:39:11 +0000 (0:00:00.956)       0:02:00.791 *****\nskipping: [controller] => (item=DaemonSet)\nskipping: [controller] => (item=ConfigMap)\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Start an upgrade] ***********************\nSaturday 28 February 2026  00:39:11 +0000 (0:00:00.039)       0:02:00.830 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Check if the Kubernetes API services is up to date] ***\nSaturday 28 February 2026  00:39:11 +0000 (0:00:00.040)       0:02:00.871 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Trigger an upgrade of the Kubernetes API services] ***\nSaturday 28 February 2026  00:39:11 +0000 (0:00:00.038)       0:02:00.910 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Setup nodes] ****************************\nSaturday 28 February 2026  00:39:12 +0000 (0:00:00.040)       0:02:00.950 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Upgrade & restart Kubelet node for upgrade (if needed)] ***\nSaturday 28 February 2026  00:39:12 +0000 (0:00:00.040)       0:02:00.991 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Set node selector for CoreDNS components] ***\nSaturday 28 February 2026  00:39:12 +0000 (0:00:00.510)       0:02:01.501 *****\nchanged: [controller]\n\nPLAY [Install control-plane components] ****************************************\n\nTASK [Gathering Facts] *********************************************************\nSaturday 28 February 2026  00:39:13 +0000 (0:00:01.088)       0:02:02.589 *****\nok: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nSaturday 28 February 2026  00:39:14 +0000 (0:00:00.853)       0:02:03.443 *****\nok: [controller]\n\nTASK [vexxhost.containers.package : Update state for tar] **********************\nSaturday 28 February 2026  00:39:14 +0000 (0:00:00.306)       0:02:03.750 *****\nok: [controller]\n\nTASK [vexxhost.containers.directory : Create directory (/var/lib/downloads)] ***\nSaturday 28 February 2026  00:39:15 +0000 (0:00:00.975)       0:02:04.725 *****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nSaturday 28 February 2026  00:39:16 +0000 (0:00:00.333)       0:02:05.059 *****\nok: [controller] => {\n    \"msg\": \"https://get.helm.sh/helm-v3.11.2-linux-amd64.tar.gz\"\n}\n\nTASK [vexxhost.containers.download_artifact : Download item] *******************\nSaturday 28 February 2026  00:39:16 +0000 (0:00:00.043)       0:02:05.103 *****\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nSaturday 28 February 2026  00:39:16 +0000 (0:00:00.629)       0:02:05.733 *****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.helm : Remove Helm repository] ***********************\nSaturday 28 February 2026  00:39:18 +0000 (0:00:01.790)       0:02:07.523 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.helm : Add bash autocomplete for helm] ***************\nSaturday 28 February 2026  00:39:18 +0000 (0:00:00.400)       0:02:07.924 *****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.helm : Get Helm plugins dir] *************************\nSaturday 28 February 2026  00:39:19 +0000 (0:00:00.344)       0:02:08.268 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.helm : Create Helm plugins directory if it does not exist] ***\nSaturday 28 February 2026  00:39:19 +0000 (0:00:00.396)       0:02:08.665 *****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.helm : Remove Helm diff plugin installed by kubernetes.core.helm_plugin] ***\nSaturday 28 February 2026  00:39:20 +0000 (0:00:00.319)       0:02:08.984 *****\nok: [controller]\n\nTASK [Install plugin] **********************************************************\nSaturday 28 February 2026  00:39:20 +0000 (0:00:00.293)       0:02:09.278 *****\nincluded: vexxhost.containers.download_artifact for controller\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nSaturday 28 February 2026  00:39:20 +0000 (0:00:00.056)       0:02:09.334 *****\nok: [controller] => {\n    \"msg\": \"https://github.com/databus23/helm-diff/releases/download/v3.8.1/helm-diff-linux-amd64.tgz\"\n}\n\nTASK [vexxhost.containers.download_artifact : Download item] *******************\nSaturday 28 February 2026  00:39:20 +0000 (0:00:00.036)       0:02:09.370 *****\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nSaturday 28 February 2026  00:39:21 +0000 (0:00:00.779)       0:02:10.150 *****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.upload_helm_chart : Include help chart upload method tasks] ***\nSaturday 28 February 2026  00:39:23 +0000 (0:00:02.133)       0:02:12.284 *****\nincluded: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/upload_helm_chart/tasks/synchronize.yml for controller\n\nTASK [vexxhost.kubernetes.upload_helm_chart : Upload Helm chart] ***************\nSaturday 28 February 2026  00:39:23 +0000 (0:00:00.089)       0:02:12.373 *****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.cilium : Get current Kubernetes version] *************\nSaturday 28 February 2026  00:39:24 +0000 (0:00:00.808)       0:02:13.181 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.cilium : Deploy Helm chart] **************************\nSaturday 28 February 2026  00:39:25 +0000 (0:00:00.933)       0:02:14.115 *****\nchanged: [controller]\n\nPLAY RECAP *********************************************************************\ncontroller                 : ok=112  changed=51   unreachable=0    failed=0    skipped=34   rescued=0    ignored=3\n\n\nTASKS RECAP ********************************************************************\nSaturday 28 February 2026  00:39:27 +0000 (0:00:02.162)       0:02:16.277 *****\n===============================================================================\nvexxhost.kubernetes.kubernetes : Initialize cluster -------------------- 38.44s\nvexxhost.kubernetes.kubernetes : Install Kubernetes Python package using package manager on supported systems -- 10.44s\nvexxhost.containers.containerd : Install AppArmor packages -------------- 5.86s\nvexxhost.kubernetes.kubelet : Reload systemd ---------------------------- 3.65s\nvexxhost.kubernetes.kubelet : Install additional packages --------------- 3.40s\nvexxhost.containers.download_artifact : Extract archive ----------------- 3.14s\nvexxhost.containers.download_artifact : Extract archive ----------------- 2.96s\nvexxhost.kubernetes.kubelet : Configure sysctl values ------------------- 2.29s\nvexxhost.kubernetes.cilium : Deploy Helm chart -------------------------- 2.16s\nvexxhost.containers.download_artifact : Extract archive ----------------- 2.13s\nvexxhost.containers.download_artifact : Extract archive ----------------- 1.79s\nvexxhost.containers.download_artifact : Extract archive ----------------- 1.77s\nvexxhost.containers.download_artifact : Extract archive ----------------- 1.72s\nvexxhost.containers.cni_plugins : Enable kernel modules in runtime ------ 1.52s\nvexxhost.containers.containerd : Create folders for configuration ------- 1.49s\nvexxhost.kubernetes.kube_vip : Uninstall legacy HA stack ---------------- 1.47s\nvexxhost.containers.containerd : Create folders for configuration ------- 1.47s\nvexxhost.containers.package : Update state for tar ---------------------- 1.21s\nGathering Facts --------------------------------------------------------- 1.10s\nvexxhost.kubernetes.kubernetes : Set node selector for CoreDNS components --- 1.09s\nINFO     [bgp > converge] Executed: Successful\nINFO     [bgp > idempotence] Executing\n\nPLAY [Configure Kubernetes VIP] ************************************************\n\nTASK [Gathering Facts] *********************************************************\nSaturday 28 February 2026  00:39:28 +0000 (0:00:00.017)       0:00:00.017 *****\n[WARNING]: Host 'controller' is using the discovered Python interpreter at '/usr/bin/python3.13', but future installation of another Python interpreter could cause a different interpreter to be discovered. See https://docs.ansible.com/ansible-core/2.20/reference_appendices/interpreter_discovery.html for more information.\nok: [controller]\n\nTASK [vexxhost.containers.directory : Create directory (/etc/kubernetes/manifests)] ***\nSaturday 28 February 2026  00:39:31 +0000 (0:00:02.575)       0:00:02.593 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Uninstall legacy HA stack] ****************\nSaturday 28 February 2026  00:39:31 +0000 (0:00:00.417)       0:00:03.010 *****\nok: [controller] => (item=/etc/keepalived/keepalived.conf)\nok: [controller] => (item=/etc/keepalived/check_apiserver.sh)\nok: [controller] => (item=/etc/kubernetes/manifests/keepalived.yaml)\nok: [controller] => (item=/etc/haproxy/haproxy.cfg)\nok: [controller] => (item=/etc/kubernetes/manifests/haproxy.yaml)\n\nTASK [vexxhost.kubernetes.kube_vip : Switch API server to run on port 6443] ****\nSaturday 28 February 2026  00:39:33 +0000 (0:00:01.431)       0:00:04.442 *****\nok: [controller] => (item=/etc/kubernetes/manifests/kube-apiserver.yaml)\nok: [controller] => (item=/etc/kubernetes/controller-manager.conf)\nok: [controller] => (item=/etc/kubernetes/scheduler.conf)\n\nTASK [vexxhost.kubernetes.kube_vip : Check if super-admin.conf exists] *********\nSaturday 28 February 2026  00:39:34 +0000 (0:00:00.956)       0:00:05.398 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Check if kubeadm has already run] *********\nSaturday 28 February 2026  00:39:34 +0000 (0:00:00.508)       0:00:05.907 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Set fact with KUBECONFIG path] ************\nSaturday 28 February 2026  00:39:35 +0000 (0:00:00.310)       0:00:06.217 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Set fact with KUBECONFIG path (with super-admin.conf)] ***\nSaturday 28 February 2026  00:39:35 +0000 (0:00:00.033)       0:00:06.251 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Upload Kubernetes manifest] ***************\nSaturday 28 February 2026  00:39:35 +0000 (0:00:00.038)       0:00:06.290 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Ensure kube-vip configuration file] *******\nSaturday 28 February 2026  00:39:35 +0000 (0:00:00.765)       0:00:07.055 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Flush handlers] ***************************\nSaturday 28 February 2026  00:39:36 +0000 (0:00:00.328)       0:00:07.383 *****\n\nPLAY [Install Kubernetes] ******************************************************\n\nTASK [Gathering Facts] *********************************************************\nSaturday 28 February 2026  00:39:36 +0000 (0:00:00.063)       0:00:07.447 *****\nok: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nSaturday 28 February 2026  00:39:37 +0000 (0:00:00.872)       0:00:08.319 *****\nok: [controller]\n\nTASK [vexxhost.containers.package : Update state for tar] **********************\nSaturday 28 February 2026  00:39:37 +0000 (0:00:00.345)       0:00:08.665 *****\nskipping: [controller]\n\nTASK [vexxhost.containers.directory : Create directory (/var/lib/downloads)] ***\nSaturday 28 February 2026  00:39:37 +0000 (0:00:00.041)       0:00:08.707 *****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nSaturday 28 February 2026  00:39:37 +0000 (0:00:00.317)       0:00:09.024 *****\nok: [controller] => {\n    \"msg\": \"https://github.com/opencontainers/runc/releases/download/v1.4.0/runc.amd64\"\n}\n\nTASK [vexxhost.containers.download_artifact : Download item] *******************\nSaturday 28 February 2026  00:39:37 +0000 (0:00:00.068)       0:00:09.092 *****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nSaturday 28 February 2026  00:39:38 +0000 (0:00:00.558)       0:00:09.651 *****\nskipping: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nSaturday 28 February 2026  00:39:38 +0000 (0:00:00.044)       0:00:09.696 *****\nok: [controller]\n\nTASK [vexxhost.containers.package : Update state for tar] **********************\nSaturday 28 February 2026  00:39:38 +0000 (0:00:00.337)       0:00:10.033 *****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nSaturday 28 February 2026  00:39:39 +0000 (0:00:01.114)       0:00:11.147 *****\nok: [controller] => {\n    \"msg\": \"https://github.com/containerd/containerd/releases/download/v2.2.0/containerd-2.2.0-linux-amd64.tar.gz\"\n}\n\nTASK [vexxhost.containers.download_artifact : Download item] *******************\nSaturday 28 February 2026  00:39:40 +0000 (0:00:00.077)       0:00:11.225 *****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nSaturday 28 February 2026  00:39:40 +0000 (0:00:00.512)       0:00:11.738 *****\nok: [controller]\n\nTASK [vexxhost.containers.containerd : Install SELinux packages] ***************\nSaturday 28 February 2026  00:39:43 +0000 (0:00:02.456)       0:00:14.194 *****\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Set SELinux to permissive at runtime] ***\nSaturday 28 February 2026  00:39:43 +0000 (0:00:00.031)       0:00:14.225 *****\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Persist SELinux permissive mode] ********\nSaturday 28 February 2026  00:39:43 +0000 (0:00:00.041)       0:00:14.267 *****\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Install AppArmor packages] **************\nSaturday 28 February 2026  00:39:43 +0000 (0:00:00.033)       0:00:14.300 *****\nok: [controller]\n\nTASK [vexxhost.containers.containerd : Create systemd service file for containerd] ***\nSaturday 28 February 2026  00:39:44 +0000 (0:00:01.032)       0:00:15.333 *****\nok: [controller]\n\nTASK [vexxhost.containers.containerd : Create folders for configuration] *******\nSaturday 28 February 2026  00:39:44 +0000 (0:00:00.674)       0:00:16.007 *****\nok: [controller] => (item={'path': '/etc/containerd'})\nok: [controller] => (item={'path': '/var/lib/containerd', 'mode': '0o700'})\nok: [controller] => (item={'path': '/run/containerd', 'mode': '0o711'})\nok: [controller] => (item={'path': '/run/containerd/io.containerd.grpc.v1.cri', 'mode': '0o700'})\nok: [controller] => (item={'path': '/run/containerd/io.containerd.sandbox.controller.v1.shim', 'mode': '0o700'})\n\nTASK [vexxhost.containers.containerd : Create containerd config file] **********\nSaturday 28 February 2026  00:39:46 +0000 (0:00:01.457)       0:00:17.465 *****\nok: [controller]\n\nTASK [vexxhost.containers.containerd : Force any restarts if necessary] ********\nSaturday 28 February 2026  00:39:47 +0000 (0:00:00.809)       0:00:18.274 *****\n\nTASK [vexxhost.containers.containerd : Enable and start service] ***************\nSaturday 28 February 2026  00:39:47 +0000 (0:00:00.007)       0:00:18.281 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes_upgrade_check : Retrieve the \"kubeadm-config\" ConfigMap] ***\nSaturday 28 February 2026  00:39:47 +0000 (0:00:00.855)       0:00:19.136 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes_upgrade_check : Parse the ClusterConfiguration] ***\nSaturday 28 February 2026  00:39:48 +0000 (0:00:00.915)       0:00:20.052 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes_upgrade_check : Retrieve the current Kubernetes version] ***\nSaturday 28 February 2026  00:39:48 +0000 (0:00:00.046)       0:00:20.099 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes_upgrade_check : Extract major, minor, and patch versions] ***\nSaturday 28 February 2026  00:39:48 +0000 (0:00:00.045)       0:00:20.144 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes_upgrade_check : Fail if we're jumping more than one minor version] ***\nSaturday 28 February 2026  00:39:49 +0000 (0:00:00.052)       0:00:20.196 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes_upgrade_check : Set fact if we need to upgrade] ***\nSaturday 28 February 2026  00:39:49 +0000 (0:00:00.043)       0:00:20.239 *****\nok: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nSaturday 28 February 2026  00:39:49 +0000 (0:00:00.047)       0:00:20.287 *****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nSaturday 28 February 2026  00:39:49 +0000 (0:00:00.314)       0:00:20.601 *****\nok: [controller] => {\n    \"msg\": \"https://dl.k8s.io/release/v1.34.0/bin/linux/amd64/kubeadm\"\n}\n\nTASK [vexxhost.containers.download_artifact : Download item] *******************\nSaturday 28 February 2026  00:39:49 +0000 (0:00:00.042)       0:00:20.644 *****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nSaturday 28 February 2026  00:39:49 +0000 (0:00:00.452)       0:00:21.097 *****\nskipping: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nSaturday 28 February 2026  00:39:49 +0000 (0:00:00.040)       0:00:21.137 *****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nSaturday 28 February 2026  00:39:50 +0000 (0:00:00.316)       0:00:21.454 *****\nok: [controller] => {\n    \"msg\": \"https://dl.k8s.io/release/v1.34.0/bin/linux/amd64/kubectl\"\n}\n\nTASK [vexxhost.containers.download_artifact : Download item] *******************\nSaturday 28 February 2026  00:39:50 +0000 (0:00:00.043)       0:00:21.498 *****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nSaturday 28 February 2026  00:39:50 +0000 (0:00:00.478)       0:00:21.977 *****\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Install SELinux packages] ***************\nSaturday 28 February 2026  00:39:50 +0000 (0:00:00.055)       0:00:22.032 *****\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Set SELinux to permissive at runtime] ***\nSaturday 28 February 2026  00:39:50 +0000 (0:00:00.035)       0:00:22.067 *****\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Persist SELinux permissive mode] ********\nSaturday 28 February 2026  00:39:50 +0000 (0:00:00.033)       0:00:22.100 *****\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Install AppArmor packages] **************\nSaturday 28 February 2026  00:39:50 +0000 (0:00:00.030)       0:00:22.131 *****\nok: [controller]\n\nTASK [vexxhost.containers.containerd : Create systemd service file for containerd] ***\nSaturday 28 February 2026  00:39:52 +0000 (0:00:01.092)       0:00:23.223 *****\nok: [controller]\n\nTASK [vexxhost.containers.containerd : Create folders for configuration] *******\nSaturday 28 February 2026  00:39:52 +0000 (0:00:00.706)       0:00:23.929 *****\nok: [controller] => (item={'path': '/etc/containerd'})\nok: [controller] => (item={'path': '/var/lib/containerd', 'mode': '0o700'})\nok: [controller] => (item={'path': '/run/containerd', 'mode': '0o711'})\nok: [controller] => (item={'path': '/run/containerd/io.containerd.grpc.v1.cri', 'mode': '0o700'})\nok: [controller] => (item={'path': '/run/containerd/io.containerd.sandbox.controller.v1.shim', 'mode': '0o700'})\n\nTASK [vexxhost.containers.containerd : Create containerd config file] **********\nSaturday 28 February 2026  00:39:54 +0000 (0:00:01.518)       0:00:25.448 *****\nok: [controller]\n\nTASK [vexxhost.containers.containerd : Force any restarts if necessary] ********\nSaturday 28 February 2026  00:39:55 +0000 (0:00:00.837)       0:00:26.286 *****\n\nTASK [vexxhost.containers.containerd : Enable and start service] ***************\nSaturday 28 February 2026  00:39:55 +0000 (0:00:00.005)       0:00:26.292 *****\nok: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nSaturday 28 February 2026  00:39:55 +0000 (0:00:00.554)       0:00:26.846 *****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nSaturday 28 February 2026  00:39:56 +0000 (0:00:00.317)       0:00:27.163 *****\nok: [controller] => {\n    \"msg\": \"https://github.com/kubernetes-sigs/cri-tools/releases/download/v1.34.0/crictl-v1.34.0-linux-amd64.tar.gz\"\n}\n\nTASK [vexxhost.containers.download_artifact : Download item] *******************\nSaturday 28 February 2026  00:39:56 +0000 (0:00:00.075)       0:00:27.239 *****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nSaturday 28 February 2026  00:39:56 +0000 (0:00:00.440)       0:00:27.679 *****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nSaturday 28 February 2026  00:39:57 +0000 (0:00:01.392)       0:00:29.071 *****\nok: [controller] => {\n    \"msg\": \"https://github.com/kubernetes-sigs/cri-tools/releases/download/v1.34.0/critest-v1.34.0-linux-amd64.tar.gz\"\n}\n\nTASK [vexxhost.containers.download_artifact : Download item] *******************\nSaturday 28 February 2026  00:39:57 +0000 (0:00:00.074)       0:00:29.146 *****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nSaturday 28 February 2026  00:39:58 +0000 (0:00:00.447)       0:00:29.594 *****\nok: [controller]\n\nTASK [vexxhost.containers.cri_tools : Create crictl config] ********************\nSaturday 28 February 2026  00:39:59 +0000 (0:00:01.435)       0:00:31.030 *****\nok: [controller]\n\nTASK [vexxhost.containers.directory : Create directory (/opt/cni/bin)] *********\nSaturday 28 February 2026  00:40:00 +0000 (0:00:00.678)       0:00:31.708 *****\nok: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nSaturday 28 February 2026  00:40:00 +0000 (0:00:00.329)       0:00:32.038 *****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nSaturday 28 February 2026  00:40:01 +0000 (0:00:00.371)       0:00:32.410 *****\nok: [controller] => {\n    \"msg\": \"https://github.com/containernetworking/plugins/releases/download/v1.8.0/cni-plugins-linux-amd64-v1.8.0.tgz\"\n}\n\nTASK [vexxhost.containers.download_artifact : Download item] *******************\nSaturday 28 February 2026  00:40:01 +0000 (0:00:00.076)       0:00:32.486 *****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nSaturday 28 February 2026  00:40:01 +0000 (0:00:00.491)       0:00:32.978 *****\nok: [controller]\n\nTASK [vexxhost.containers.cni_plugins : Gather variables for each operating system] ***\nSaturday 28 February 2026  00:40:04 +0000 (0:00:02.295)       0:00:35.273 *****\nok: [controller] => (item=/home/zuul/.ansible/collections/ansible_collections/vexxhost/containers/roles/cni_plugins/vars/debian.yml)\n\nTASK [vexxhost.containers.cni_plugins : Install additional packages] ***********\nSaturday 28 February 2026  00:40:04 +0000 (0:00:00.064)       0:00:35.338 *****\nok: [controller]\n\nTASK [vexxhost.containers.cni_plugins : Ensure IPv6 is enabled] ****************\nSaturday 28 February 2026  00:40:05 +0000 (0:00:00.959)       0:00:36.297 *****\nok: [controller]\n\nTASK [vexxhost.containers.cni_plugins : Enable kernel modules on-boot] *********\nSaturday 28 February 2026  00:40:05 +0000 (0:00:00.478)       0:00:36.775 *****\nok: [controller]\n\nTASK [vexxhost.containers.cni_plugins : Enable kernel modules in runtime] ******\nSaturday 28 February 2026  00:40:06 +0000 (0:00:00.718)       0:00:37.494 *****\nok: [controller] => (item=br_netfilter)\nok: [controller] => (item=ip_tables)\nok: [controller] => (item=ip6_tables)\nok: [controller] => (item=nf_conntrack)\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nSaturday 28 February 2026  00:40:07 +0000 (0:00:01.264)       0:00:38.759 *****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nSaturday 28 February 2026  00:40:07 +0000 (0:00:00.311)       0:00:39.070 *****\nok: [controller] => {\n    \"msg\": \"https://dl.k8s.io/release/v1.34.0/bin/linux/amd64/kubelet\"\n}\n\nTASK [vexxhost.containers.download_artifact : Download item] *******************\nSaturday 28 February 2026  00:40:07 +0000 (0:00:00.047)       0:00:39.118 *****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nSaturday 28 February 2026  00:40:08 +0000 (0:00:00.481)       0:00:39.599 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Gather variables for each operating system] ***\nSaturday 28 February 2026  00:40:08 +0000 (0:00:00.040)       0:00:39.639 *****\nok: [controller] => (item=/home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubelet/vars/debian.yml)\n\nTASK [vexxhost.kubernetes.kubelet : Install coreutils] *************************\nSaturday 28 February 2026  00:40:08 +0000 (0:00:00.057)       0:00:39.696 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Install additional packages] ***************\nSaturday 28 February 2026  00:40:08 +0000 (0:00:00.036)       0:00:39.733 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Configure sysctl values] *******************\nSaturday 28 February 2026  00:40:09 +0000 (0:00:00.914)       0:00:40.647 *****\nok: [controller] => (item={'name': 'net.ipv4.ip_forward', 'value': 1})\nok: [controller] => (item={'name': 'net.bridge.bridge-nf-call-iptables', 'value': 1})\nok: [controller] => (item={'name': 'net.bridge.bridge-nf-call-ip6tables', 'value': 1})\nok: [controller] => (item={'name': 'net.ipv4.conf.all.rp_filter', 'value': 0})\nok: [controller] => (item={'name': 'fs.inotify.max_queued_events', 'value': 1048576})\nok: [controller] => (item={'name': 'fs.inotify.max_user_instances', 'value': 8192})\nok: [controller] => (item={'name': 'fs.inotify.max_user_watches', 'value': 1048576})\n\nTASK [vexxhost.kubernetes.kubelet : Create folders for kubernetes configuration] ***\nSaturday 28 February 2026  00:40:11 +0000 (0:00:02.181)       0:00:42.829 *****\nok: [controller] => (item=/etc/systemd/system/kubelet.service.d)\nok: [controller] => (item=/etc/kubernetes)\nok: [controller] => (item=/etc/kubernetes/manifests)\n\nTASK [vexxhost.kubernetes.kubelet : Add kubelet systemd service config] ********\nSaturday 28 February 2026  00:40:12 +0000 (0:00:00.882)       0:00:43.711 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Add kubeadm dropin for kubelet systemd service config] ***\nSaturday 28 February 2026  00:40:13 +0000 (0:00:00.650)       0:00:44.362 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Check swap status] *************************\nSaturday 28 February 2026  00:40:13 +0000 (0:00:00.675)       0:00:45.037 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Disable swap] ******************************\nSaturday 28 February 2026  00:40:14 +0000 (0:00:00.439)       0:00:45.476 *****\n[ERROR]: Task failed: Conditional result (False) was derived from value of type 'str' at '/home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubelet/tasks/main.yml:83:11'. Conditionals must have a boolean result.\n\nTask failed.\nOrigin: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubelet/tasks/main.yml:78:7\n\n76       register: kubelet_swapon\n77\n78     - name: Disable swap\n         ^ column 7\n\n<<< caused by >>>\n\nConditional result (False) was derived from value of type 'str' at '/home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubelet/tasks/main.yml:83:11'. Conditionals must have a boolean result.\nOrigin: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubelet/tasks/main.yml:83:11\n\n81       ignore_errors: \"{{ ansible_check_mode }}\"\n82       when:\n83         - kubelet_swapon.stdout\n             ^ column 11\n\nBroken conditionals can be temporarily allowed with the `ALLOW_BROKEN_CONDITIONALS` configuration option.\n\nfatal: [controller]: FAILED! => {\"changed\": false, \"msg\": \"Task failed: Conditional result (False) was derived from value of type 'str' at '/home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubelet/tasks/main.yml:83:11'. Conditionals must have a boolean result.\"}\n...ignoring\n\nTASK [vexxhost.kubernetes.kubelet : Remove swapfile from /etc/fstab] ***********\nSaturday 28 February 2026  00:40:14 +0000 (0:00:00.032)       0:00:45.509 *****\nok: [controller] => (item=swap)\nok: [controller] => (item=none)\n\nTASK [vexxhost.kubernetes.kubelet : Create noswap systemd service config file] ***\nSaturday 28 February 2026  00:40:15 +0000 (0:00:00.808)       0:00:46.317 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Enable noswap service] *********************\nSaturday 28 February 2026  00:40:15 +0000 (0:00:00.718)       0:00:47.036 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Force any restarts if necessary] ***********\nSaturday 28 February 2026  00:40:16 +0000 (0:00:00.493)       0:00:47.530 *****\n\nTASK [vexxhost.kubernetes.kubelet : Enable and start kubelet service] **********\nSaturday 28 February 2026  00:40:16 +0000 (0:00:00.007)       0:00:47.538 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Ensure availability of dbus on Debian] *****\nSaturday 28 February 2026  00:40:16 +0000 (0:00:00.523)       0:00:48.061 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Configure short hostname] ******************\nSaturday 28 February 2026  00:40:17 +0000 (0:00:00.924)       0:00:48.985 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Ensure hostname inside hosts file] *********\nSaturday 28 February 2026  00:40:18 +0000 (0:00:00.918)       0:00:49.903 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Remove kubernetes repository] ***********\nSaturday 28 February 2026  00:40:19 +0000 (0:00:00.429)       0:00:50.332 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Setup control plane] ********************\nSaturday 28 February 2026  00:40:19 +0000 (0:00:00.520)       0:00:50.853 *****\nincluded: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubernetes/tasks/control-plane.yml for controller\n\nTASK [vexxhost.kubernetes.kubernetes : Bootstrap cluster] **********************\nSaturday 28 February 2026  00:40:19 +0000 (0:00:00.080)       0:00:50.934 *****\nincluded: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubernetes/tasks/bootstrap-cluster.yml for controller\n\nTASK [vexxhost.kubernetes.kubernetes : Check if any control plane is bootstrapped] ***\nSaturday 28 February 2026  00:40:19 +0000 (0:00:00.078)       0:00:51.012 *****\nok: [controller] => (item=controller)\n\nTASK [vexxhost.kubernetes.kubernetes : Pick node from pre-existing cluster] ****\nSaturday 28 February 2026  00:40:20 +0000 (0:00:00.329)       0:00:51.342 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Select first node to initialize cluster] ***\nSaturday 28 February 2026  00:40:20 +0000 (0:00:00.050)       0:00:51.392 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Print selected bootstrap node] **********\nSaturday 28 February 2026  00:40:20 +0000 (0:00:00.042)       0:00:51.434 *****\nok: [controller] => {\n    \"msg\": \"controller\"\n}\n\nTASK [vexxhost.kubernetes.kubernetes : Upload cluster configuration for bootstrap node] ***\nSaturday 28 February 2026  00:40:20 +0000 (0:00:00.043)       0:00:51.477 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create pki folder] **********************\nSaturday 28 February 2026  00:40:21 +0000 (0:00:00.716)       0:00:52.194 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create kubernetes ca key] ***************\nSaturday 28 February 2026  00:40:21 +0000 (0:00:00.033)       0:00:52.228 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create kubernetes ca cert] **************\nSaturday 28 February 2026  00:40:21 +0000 (0:00:00.033)       0:00:52.261 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create etcd-ca key] *********************\nSaturday 28 February 2026  00:40:21 +0000 (0:00:00.034)       0:00:52.296 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create etcd-ca cert] ********************\nSaturday 28 February 2026  00:40:21 +0000 (0:00:00.033)       0:00:52.329 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create front-proxy-ca key] **************\nSaturday 28 February 2026  00:40:21 +0000 (0:00:00.031)       0:00:52.361 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create front-proxy-ca cert] *************\nSaturday 28 February 2026  00:40:21 +0000 (0:00:00.034)       0:00:52.395 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Initialize cluster] *********************\nSaturday 28 February 2026  00:40:21 +0000 (0:00:00.035)       0:00:52.430 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Check if the node is already part of the cluster] ***\nSaturday 28 February 2026  00:40:21 +0000 (0:00:00.297)       0:00:52.728 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Join cluster] ***************************\nSaturday 28 February 2026  00:40:21 +0000 (0:00:00.323)       0:00:53.052 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create folder for admin configuration] ***\nSaturday 28 February 2026  00:40:21 +0000 (0:00:00.035)       0:00:53.087 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Creating a symlink for admin configuration file] ***\nSaturday 28 February 2026  00:40:22 +0000 (0:00:00.307)       0:00:53.395 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Add bash autocomplete for kubectl] ******\nSaturday 28 February 2026  00:40:22 +0000 (0:00:00.303)       0:00:53.698 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Install PIP] ****************************\nSaturday 28 February 2026  00:40:22 +0000 (0:00:00.302)       0:00:54.001 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Install Kubernetes Python package using pip on supported systems] ***\nSaturday 28 February 2026  00:40:22 +0000 (0:00:00.038)       0:00:54.039 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Enable EPEL repository] *****************\nSaturday 28 February 2026  00:40:22 +0000 (0:00:00.036)       0:00:54.076 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Install Kubernetes Python package using package manager on supported systems] ***\nSaturday 28 February 2026  00:40:22 +0000 (0:00:00.039)       0:00:54.115 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Allow workload on control plane node] ***\nSaturday 28 February 2026  00:40:23 +0000 (0:00:00.887)       0:00:55.003 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Remove kube-proxy resources] ************\nSaturday 28 February 2026  00:40:24 +0000 (0:00:00.828)       0:00:55.831 *****\nskipping: [controller] => (item=DaemonSet)\nskipping: [controller] => (item=ConfigMap)\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Start an upgrade] ***********************\nSaturday 28 February 2026  00:40:24 +0000 (0:00:00.040)       0:00:55.872 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Check if the Kubernetes API services is up to date] ***\nSaturday 28 February 2026  00:40:24 +0000 (0:00:00.037)       0:00:55.909 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Trigger an upgrade of the Kubernetes API services] ***\nSaturday 28 February 2026  00:40:24 +0000 (0:00:00.032)       0:00:55.942 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Setup nodes] ****************************\nSaturday 28 February 2026  00:40:24 +0000 (0:00:00.037)       0:00:55.979 *****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Upgrade & restart Kubelet node for upgrade (if needed)] ***\nSaturday 28 February 2026  00:40:24 +0000 (0:00:00.034)       0:00:56.014 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Set node selector for CoreDNS components] ***\nSaturday 28 February 2026  00:40:25 +0000 (0:00:00.538)       0:00:56.553 *****\nok: [controller]\n\nPLAY [Install control-plane components] ****************************************\n\nTASK [Gathering Facts] *********************************************************\nSaturday 28 February 2026  00:40:26 +0000 (0:00:01.036)       0:00:57.590 *****\nok: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nSaturday 28 February 2026  00:40:27 +0000 (0:00:01.025)       0:00:58.616 *****\nok: [controller]\n\nTASK [vexxhost.containers.package : Update state for tar] **********************\nSaturday 28 February 2026  00:40:27 +0000 (0:00:00.310)       0:00:58.926 *****\nok: [controller]\n\nTASK [vexxhost.containers.directory : Create directory (/var/lib/downloads)] ***\nSaturday 28 February 2026  00:40:28 +0000 (0:00:01.037)       0:00:59.963 *****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nSaturday 28 February 2026  00:40:29 +0000 (0:00:00.318)       0:01:00.282 *****\nok: [controller] => {\n    \"msg\": \"https://get.helm.sh/helm-v3.11.2-linux-amd64.tar.gz\"\n}\n\nTASK [vexxhost.containers.download_artifact : Download item] *******************\nSaturday 28 February 2026  00:40:29 +0000 (0:00:00.043)       0:01:00.325 *****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nSaturday 28 February 2026  00:40:29 +0000 (0:00:00.429)       0:01:00.755 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.helm : Remove Helm repository] ***********************\nSaturday 28 February 2026  00:40:31 +0000 (0:00:01.487)       0:01:02.244 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.helm : Add bash autocomplete for helm] ***************\nSaturday 28 February 2026  00:40:31 +0000 (0:00:00.457)       0:01:02.701 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.helm : Get Helm plugins dir] *************************\nSaturday 28 February 2026  00:40:31 +0000 (0:00:00.348)       0:01:03.049 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.helm : Create Helm plugins directory if it does not exist] ***\nSaturday 28 February 2026  00:40:32 +0000 (0:00:00.373)       0:01:03.423 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.helm : Remove Helm diff plugin installed by kubernetes.core.helm_plugin] ***\nSaturday 28 February 2026  00:40:32 +0000 (0:00:00.327)       0:01:03.750 *****\nok: [controller]\n\nTASK [Install plugin] **********************************************************\nSaturday 28 February 2026  00:40:32 +0000 (0:00:00.352)       0:01:04.102 *****\nincluded: vexxhost.containers.download_artifact for controller\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nSaturday 28 February 2026  00:40:33 +0000 (0:00:00.065)       0:01:04.167 *****\nok: [controller] => {\n    \"msg\": \"https://github.com/databus23/helm-diff/releases/download/v3.8.1/helm-diff-linux-amd64.tgz\"\n}\n\nTASK [vexxhost.containers.download_artifact : Download item] *******************\nSaturday 28 February 2026  00:40:33 +0000 (0:00:00.044)       0:01:04.212 *****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nSaturday 28 February 2026  00:40:33 +0000 (0:00:00.447)       0:01:04.660 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.upload_helm_chart : Include help chart upload method tasks] ***\nSaturday 28 February 2026  00:40:35 +0000 (0:00:01.732)       0:01:06.392 *****\nincluded: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/upload_helm_chart/tasks/synchronize.yml for controller\n\nTASK [vexxhost.kubernetes.upload_helm_chart : Upload Helm chart] ***************\nSaturday 28 February 2026  00:40:35 +0000 (0:00:00.093)       0:01:06.486 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.cilium : Get current Kubernetes version] *************\nSaturday 28 February 2026  00:40:36 +0000 (0:00:00.724)       0:01:07.210 *****\nok: [controller]\n\nTASK [vexxhost.kubernetes.cilium : Deploy Helm chart] **************************\nSaturday 28 February 2026  00:40:37 +0000 (0:00:01.059)       0:01:08.269 *****\nok: [controller]\n\nPLAY RECAP *********************************************************************\ncontroller                 : ok=113  changed=0    unreachable=0    failed=0    skipped=30   rescued=0    ignored=1\n\n\nTASKS RECAP ********************************************************************\nSaturday 28 February 2026  00:40:39 +0000 (0:00:02.374)       0:01:10.644 *****\n===============================================================================\nGathering Facts --------------------------------------------------------- 2.58s\nvexxhost.containers.download_artifact : Extract archive ----------------- 2.46s\nvexxhost.kubernetes.cilium : Deploy Helm chart -------------------------- 2.37s\nvexxhost.containers.download_artifact : Extract archive ----------------- 2.30s\nvexxhost.kubernetes.kubelet : Configure sysctl values ------------------- 2.18s\nvexxhost.containers.download_artifact : Extract archive ----------------- 1.73s\nvexxhost.containers.containerd : Create folders for configuration ------- 1.52s\nvexxhost.containers.download_artifact : Extract archive ----------------- 1.49s\nvexxhost.containers.containerd : Create folders for configuration ------- 1.46s\nvexxhost.containers.download_artifact : Extract archive ----------------- 1.44s\nvexxhost.kubernetes.kube_vip : Uninstall legacy HA stack ---------------- 1.43s\nvexxhost.containers.download_artifact : Extract archive ----------------- 1.39s\nvexxhost.containers.cni_plugins : Enable kernel modules in runtime ------ 1.26s\nvexxhost.containers.package : Update state for tar ---------------------- 1.11s\nvexxhost.containers.containerd : Install AppArmor packages -------------- 1.09s\nvexxhost.kubernetes.cilium : Get current Kubernetes version ------------- 1.06s\nvexxhost.containers.package : Update state for tar ---------------------- 1.04s\nvexxhost.kubernetes.kubernetes : Set node selector for CoreDNS components --- 1.04s\nvexxhost.containers.containerd : Install AppArmor packages -------------- 1.03s\nGathering Facts --------------------------------------------------------- 1.03s\nINFO     [bgp > idempotence] Executed: Successful\nINFO     [bgp > side_effect] Executing\nWARNING  [bgp > side_effect] Executed: Missing playbook (Remove from test_sequence to suppress)\nINFO     [bgp > verify] Executing\n\nPLAY [Verify] ******************************************************************\n\nTASK [Gathering Facts] *********************************************************\nSaturday 28 February 2026  00:40:40 +0000 (0:00:00.009)       0:00:00.009 *****\n[WARNING]: Host 'controller' is using the discovered Python interpreter at '/usr/bin/python3.13', but future installation of another Python interpreter could cause a different interpreter to be discovered. See https://docs.ansible.com/ansible-core/2.20/reference_appendices/interpreter_discovery.html for more information.\nok: [controller]\n\nTASK [Gather service facts] ****************************************************\nSaturday 28 February 2026  00:40:42 +0000 (0:00:02.285)       0:00:02.295 *****\nok: [controller]\n\nTASK [Make sure kubelet service is running] ************************************\nSaturday 28 February 2026  00:40:47 +0000 (0:00:04.455)       0:00:06.750 *****\nok: [controller] => {\n    \"changed\": false,\n    \"msg\": \"All assertions passed\"\n}\n\nTASK [Make sure kubelet service is enabled] ************************************\nSaturday 28 February 2026  00:40:47 +0000 (0:00:00.037)       0:00:06.787 *****\nok: [controller] => {\n    \"changed\": false,\n    \"msg\": \"All assertions passed\"\n}\n\nTASK [Get all nodes] ***********************************************************\nSaturday 28 February 2026  00:40:47 +0000 (0:00:00.039)       0:00:06.827 *****\nchanged: [controller]\n\nTASK [Print node list] *********************************************************\nSaturday 28 February 2026  00:40:47 +0000 (0:00:00.541)       0:00:07.368 *****\nok: [controller] => {\n    \"msg\": [\n        \"NAME         STATUS   ROLES           AGE    VERSION\",\n        \"controller   Ready    control-plane   111s   v1.34.0\"\n    ]\n}\n\nTASK [Assert no nody is not ready] *********************************************\nSaturday 28 February 2026  00:40:47 +0000 (0:00:00.039)       0:00:07.408 *****\nok: [controller] => {\n    \"changed\": false,\n    \"msg\": \"All assertions passed\"\n}\n\nPLAY [verify BGP] **************************************************************\n\nTASK [Gathering Facts] *********************************************************\nSaturday 28 February 2026  00:40:48 +0000 (0:00:00.044)       0:00:07.452 *****\nok: [controller]\n\nTASK [Get all nodes] ***********************************************************\nSaturday 28 February 2026  00:40:49 +0000 (0:00:01.009)       0:00:08.461 *****\nchanged: [controller]\n\nTASK [Print bgp neighbors received-routes] *************************************\nSaturday 28 February 2026  00:40:49 +0000 (0:00:00.350)       0:00:08.812 *****\nok: [controller] => {\n    \"msg\": [\n        \"BGP table version is 0, local router ID is 199.204.45.6, vrf id 0\",\n        \"Default local pref 100, local AS 65000\",\n        \"Status codes:  s suppressed, d damped, h history, u unsorted, * valid, > best, = multipath,\",\n        \"               i internal, r RIB-failure, S Stale, R Removed\",\n        \"Nexthop codes: @NNN nexthop's vrf id, < announce-nh-self\",\n        \"Origin codes:  i - IGP, e - EGP, ? - incomplete\",\n        \"RPKI validation codes: V valid, I invalid, N Not found\",\n        \"\",\n        \"     Network          Next Hop            Metric LocPrf Weight Path\",\n        \" *> 172.17.0.100/32  172.17.0.100                  100      0 i\",\n        \"\",\n        \"Total number of prefixes 1\"\n    ]\n}\n\nPLAY RECAP *********************************************************************\ncontroller                 : ok=10   changed=2    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0\n\n\nTASKS RECAP ********************************************************************\nSaturday 28 February 2026  00:40:49 +0000 (0:00:00.030)       0:00:08.842 *****\n===============================================================================\nGather service facts ---------------------------------------------------- 4.46s\nGathering Facts --------------------------------------------------------- 2.29s\nGathering Facts --------------------------------------------------------- 1.01s\nGet all nodes ----------------------------------------------------------- 0.54s\nGet all nodes ----------------------------------------------------------- 0.35s\nAssert no nody is not ready --------------------------------------------- 0.04s\nMake sure kubelet service is enabled ------------------------------------ 0.04s\nPrint node list --------------------------------------------------------- 0.04s\nMake sure kubelet service is running ------------------------------------ 0.04s\nPrint bgp neighbors received-routes ------------------------------------- 0.03s\nINFO     [bgp > verify] Executed: Successful\nINFO     [bgp > cleanup] Executing\nWARNING  [bgp > cleanup] Executed: Missing playbook (Remove from test_sequence to suppress)\nINFO     [bgp > destroy] Executing\nWARNING  [bgp > destroy] Skipping, '--destroy=never' requested.\nINFO     [bgp > destroy] Executed: Successful\nWARNING  Molecule executed 1 scenario (1 missing files)",
                            "stdout_lines": [
                                "Using CPython 3.13.5 interpreter at: /usr/bin/python3",
                                "Creating virtual environment at: .venv",
                                "Downloading pygments (1.2MiB)",
                                "Downloading cryptography (4.3MiB)",
                                "Downloading ansible-core (2.3MiB)",
                                " Downloading cryptography",
                                " Downloading pygments",
                                " Downloading ansible-core",
                                "Installed 36 packages in 50ms",
                                "INFO     Collection 'vexxhost.kubernetes' detected.",
                                "INFO     Scenarios will be used from 'extensions/molecule'",
                                "CRITICAL 'extensions/molecule/default/molecule.yml' glob failed.  Exiting.",
                                "INFO     default scenario not found, disabling shared state.",
                                "INFO     [bgp > discovery] scenario test matrix: dependency, cleanup, destroy, syntax, create, prepare, converge, idempotence, side_effect, verify, cleanup, destroy",
                                "INFO     [bgp > prerun] Performing prerun with role_name_check=0...",
                                "INFO     [bgp > dependency] Executing",
                                "WARNING  [bgp > dependency] Missing roles requirements file: requirements.yml",
                                "WARNING  [bgp > dependency] Missing collections requirements file: collections.yml",
                                "WARNING  [bgp > dependency] Executed: 2 missing (Remove from test_sequence to suppress)",
                                "INFO     [bgp > cleanup] Executing",
                                "WARNING  [bgp > cleanup] Executed: Missing playbook (Remove from test_sequence to suppress)",
                                "INFO     [bgp > destroy] Executing",
                                "WARNING  [bgp > destroy] Skipping, '--destroy=never' requested.",
                                "INFO     [bgp > destroy] Executed: Successful",
                                "INFO     [bgp > syntax] Executing",
                                "",
                                "playbook: /home/zuul/src/github.com/vexxhost/ansible-collection-kubernetes/extensions/molecule/bgp/converge.yml",
                                "INFO     [bgp > syntax] Executed: Successful",
                                "INFO     [bgp > create] Executing",
                                "WARNING  [bgp > create] Executed: Missing playbook (Remove from test_sequence to suppress)",
                                "INFO     [bgp > prepare] Executing",
                                "",
                                "PLAY [Prepare] *****************************************************************",
                                "",
                                "TASK [Gathering Facts] *********************************************************",
                                "Saturday 28 February 2026  00:36:39 +0000 (0:00:00.037)       0:00:00.037 *****",
                                "[WARNING]: Host 'controller' is using the discovered Python interpreter at '/usr/bin/python3.13', but future installation of another Python interpreter could cause a different interpreter to be discovered. See https://docs.ansible.com/ansible-core/2.20/reference_appendices/interpreter_discovery.html for more information.",
                                "ok: [controller]",
                                "",
                                "TASK [Install Debian packages] *************************************************",
                                "Saturday 28 February 2026  00:36:40 +0000 (0:00:01.324)       0:00:01.362 *****",
                                "ok: [controller]",
                                "",
                                "PLAY [Prepare BGP] *************************************************************",
                                "",
                                "TASK [Gathering Facts] *********************************************************",
                                "Saturday 28 February 2026  00:36:46 +0000 (0:00:05.906)       0:00:07.268 *****",
                                "ok: [controller]",
                                "",
                                "TASK [Enable IP forwarding] ****************************************************",
                                "Saturday 28 February 2026  00:36:47 +0000 (0:00:00.831)       0:00:08.100 *****",
                                "changed: [controller]",
                                "",
                                "TASK [Add FRR repository] ******************************************************",
                                "Saturday 28 February 2026  00:36:47 +0000 (0:00:00.486)       0:00:08.586 *****",
                                "[WARNING]: Module remote_tmp /root/.ansible/tmp did not exist and was created with a mode of 0700, this may cause issues when running as another user. To avoid this, create the remote_tmp dir with the correct permissions manually",
                                "changed: [controller]",
                                "",
                                "TASK [Install frr packages] ****************************************************",
                                "Saturday 28 February 2026  00:36:51 +0000 (0:00:04.330)       0:00:12.917 *****",
                                "changed: [controller]",
                                "",
                                "TASK [Ensure bgpd is enabled] **************************************************",
                                "Saturday 28 February 2026  00:37:01 +0000 (0:00:09.880)       0:00:22.797 *****",
                                "changed: [controller]",
                                "",
                                "TASK [Update FRR configuration] ************************************************",
                                "Saturday 28 February 2026  00:37:02 +0000 (0:00:00.467)       0:00:23.264 *****",
                                "changed: [controller]",
                                "",
                                "TASK [Restart service frr] *****************************************************",
                                "Saturday 28 February 2026  00:37:03 +0000 (0:00:01.015)       0:00:24.280 *****",
                                "changed: [controller]",
                                "",
                                "PLAY RECAP *********************************************************************",
                                "controller                 : ok=9    changed=6    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0",
                                "",
                                "",
                                "TASKS RECAP ********************************************************************",
                                "Saturday 28 February 2026  00:37:09 +0000 (0:00:06.292)       0:00:30.572 *****",
                                "===============================================================================",
                                "Install frr packages ---------------------------------------------------- 9.88s",
                                "Restart service frr ----------------------------------------------------- 6.29s",
                                "Install Debian packages ------------------------------------------------- 5.91s",
                                "Add FRR repository ------------------------------------------------------ 4.33s",
                                "Gathering Facts --------------------------------------------------------- 1.32s",
                                "Update FRR configuration ------------------------------------------------ 1.02s",
                                "Gathering Facts --------------------------------------------------------- 0.83s",
                                "Enable IP forwarding ---------------------------------------------------- 0.49s",
                                "Ensure bgpd is enabled -------------------------------------------------- 0.47s",
                                "INFO     [bgp > prepare] Executed: Successful",
                                "INFO     [bgp > converge] Executing",
                                "",
                                "PLAY [Configure Kubernetes VIP] ************************************************",
                                "",
                                "TASK [Gathering Facts] *********************************************************",
                                "Saturday 28 February 2026  00:37:11 +0000 (0:00:00.017)       0:00:00.017 *****",
                                "[WARNING]: Host 'controller' is using the discovered Python interpreter at '/usr/bin/python3.13', but future installation of another Python interpreter could cause a different interpreter to be discovered. See https://docs.ansible.com/ansible-core/2.20/reference_appendices/interpreter_discovery.html for more information.",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.directory : Create directory (/etc/kubernetes/manifests)] ***",
                                "Saturday 28 February 2026  00:37:12 +0000 (0:00:01.102)       0:00:01.120 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Uninstall legacy HA stack] ****************",
                                "Saturday 28 February 2026  00:37:12 +0000 (0:00:00.426)       0:00:01.546 *****",
                                "ok: [controller] => (item=/etc/keepalived/keepalived.conf)",
                                "ok: [controller] => (item=/etc/keepalived/check_apiserver.sh)",
                                "ok: [controller] => (item=/etc/kubernetes/manifests/keepalived.yaml)",
                                "ok: [controller] => (item=/etc/haproxy/haproxy.cfg)",
                                "ok: [controller] => (item=/etc/kubernetes/manifests/haproxy.yaml)",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Switch API server to run on port 6443] ****",
                                "Saturday 28 February 2026  00:37:14 +0000 (0:00:01.468)       0:00:03.014 *****",
                                "[ERROR]: Task failed: Module failed: Path /etc/kubernetes/manifests/kube-apiserver.yaml does not exist !",
                                "Origin: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kube_vip/tasks/main.yml:32:3",
                                "",
                                "30     - Restart \"kubelet\" service",
                                "31",
                                "32 - name: Switch API server to run on port 6443",
                                "     ^ column 3",
                                "",
                                "failed: [controller] (item=/etc/kubernetes/manifests/kube-apiserver.yaml) => {\"ansible_loop_var\": \"item\", \"changed\": false, \"item\": \"/etc/kubernetes/manifests/kube-apiserver.yaml\", \"msg\": \"Path /etc/kubernetes/manifests/kube-apiserver.yaml does not exist !\", \"rc\": 257}",
                                "[ERROR]: Task failed: Module failed: Path /etc/kubernetes/controller-manager.conf does not exist !",
                                "Origin: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kube_vip/tasks/main.yml:32:3",
                                "",
                                "30     - Restart \"kubelet\" service",
                                "31",
                                "32 - name: Switch API server to run on port 6443",
                                "     ^ column 3",
                                "",
                                "failed: [controller] (item=/etc/kubernetes/controller-manager.conf) => {\"ansible_loop_var\": \"item\", \"changed\": false, \"item\": \"/etc/kubernetes/controller-manager.conf\", \"msg\": \"Path /etc/kubernetes/controller-manager.conf does not exist !\", \"rc\": 257}",
                                "[ERROR]: Task failed: Module failed: Path /etc/kubernetes/scheduler.conf does not exist !",
                                "Origin: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kube_vip/tasks/main.yml:32:3",
                                "",
                                "30     - Restart \"kubelet\" service",
                                "31",
                                "32 - name: Switch API server to run on port 6443",
                                "     ^ column 3",
                                "",
                                "failed: [controller] (item=/etc/kubernetes/scheduler.conf) => {\"ansible_loop_var\": \"item\", \"changed\": false, \"item\": \"/etc/kubernetes/scheduler.conf\", \"msg\": \"Path /etc/kubernetes/scheduler.conf does not exist !\", \"rc\": 257}",
                                "...ignoring",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Check if super-admin.conf exists] *********",
                                "Saturday 28 February 2026  00:37:15 +0000 (0:00:00.954)       0:00:03.969 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Check if kubeadm has already run] *********",
                                "Saturday 28 February 2026  00:37:15 +0000 (0:00:00.461)       0:00:04.430 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Set fact with KUBECONFIG path] ************",
                                "Saturday 28 February 2026  00:37:15 +0000 (0:00:00.297)       0:00:04.728 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Set fact with KUBECONFIG path (with super-admin.conf)] ***",
                                "Saturday 28 February 2026  00:37:15 +0000 (0:00:00.036)       0:00:04.764 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Upload Kubernetes manifest] ***************",
                                "Saturday 28 February 2026  00:37:15 +0000 (0:00:00.042)       0:00:04.806 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Ensure kube-vip configuration file] *******",
                                "Saturday 28 February 2026  00:37:16 +0000 (0:00:00.990)       0:00:05.797 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Flush handlers] ***************************",
                                "Saturday 28 February 2026  00:37:17 +0000 (0:00:00.324)       0:00:06.122 *****",
                                "",
                                "PLAY [Install Kubernetes] ******************************************************",
                                "",
                                "TASK [Gathering Facts] *********************************************************",
                                "Saturday 28 February 2026  00:37:17 +0000 (0:00:00.058)       0:00:06.180 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Saturday 28 February 2026  00:37:18 +0000 (0:00:00.842)       0:00:07.022 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.package : Update state for tar] **********************",
                                "Saturday 28 February 2026  00:37:18 +0000 (0:00:00.355)       0:00:07.377 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.directory : Create directory (/var/lib/downloads)] ***",
                                "Saturday 28 February 2026  00:37:18 +0000 (0:00:00.047)       0:00:07.425 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Saturday 28 February 2026  00:37:18 +0000 (0:00:00.327)       0:00:07.752 *****",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://github.com/opencontainers/runc/releases/download/v1.4.0/runc.amd64\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Saturday 28 February 2026  00:37:18 +0000 (0:00:00.112)       0:00:07.864 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Saturday 28 February 2026  00:37:19 +0000 (0:00:00.820)       0:00:08.685 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Saturday 28 February 2026  00:37:19 +0000 (0:00:00.034)       0:00:08.719 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.package : Update state for tar] **********************",
                                "Saturday 28 February 2026  00:37:20 +0000 (0:00:00.306)       0:00:09.026 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Saturday 28 February 2026  00:37:21 +0000 (0:00:01.206)       0:00:10.233 *****",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://github.com/containerd/containerd/releases/download/v2.2.0/containerd-2.2.0-linux-amd64.tar.gz\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Saturday 28 February 2026  00:37:21 +0000 (0:00:00.075)       0:00:10.308 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Saturday 28 February 2026  00:37:22 +0000 (0:00:00.888)       0:00:11.197 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Install SELinux packages] ***************",
                                "Saturday 28 February 2026  00:37:25 +0000 (0:00:03.141)       0:00:14.339 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Set SELinux to permissive at runtime] ***",
                                "Saturday 28 February 2026  00:37:25 +0000 (0:00:00.033)       0:00:14.372 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Persist SELinux permissive mode] ********",
                                "Saturday 28 February 2026  00:37:25 +0000 (0:00:00.036)       0:00:14.409 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Install AppArmor packages] **************",
                                "Saturday 28 February 2026  00:37:25 +0000 (0:00:00.036)       0:00:14.445 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Create systemd service file for containerd] ***",
                                "Saturday 28 February 2026  00:37:31 +0000 (0:00:05.864)       0:00:20.310 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Create folders for configuration] *******",
                                "Saturday 28 February 2026  00:37:32 +0000 (0:00:00.732)       0:00:21.043 *****",
                                "changed: [controller] => (item={'path': '/etc/containerd'})",
                                "changed: [controller] => (item={'path': '/var/lib/containerd', 'mode': '0o700'})",
                                "changed: [controller] => (item={'path': '/run/containerd', 'mode': '0o711'})",
                                "changed: [controller] => (item={'path': '/run/containerd/io.containerd.grpc.v1.cri', 'mode': '0o700'})",
                                "changed: [controller] => (item={'path': '/run/containerd/io.containerd.sandbox.controller.v1.shim', 'mode': '0o700'})",
                                "",
                                "TASK [vexxhost.containers.containerd : Create containerd config file] **********",
                                "Saturday 28 February 2026  00:37:33 +0000 (0:00:01.490)       0:00:22.533 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Force any restarts if necessary] ********",
                                "Saturday 28 February 2026  00:37:34 +0000 (0:00:00.835)       0:00:23.368 *****",
                                "",
                                "RUNNING HANDLER [vexxhost.containers.containerd : Restart containerd] **********",
                                "Saturday 28 February 2026  00:37:34 +0000 (0:00:00.007)       0:00:23.376 *****",
                                "changed: [controller]",
                                "",
                                "RUNNING HANDLER [vexxhost.kubernetes.kubelet : Reload systemd] *****************",
                                "Saturday 28 February 2026  00:37:35 +0000 (0:00:00.898)       0:00:24.274 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Enable and start service] ***************",
                                "Saturday 28 February 2026  00:37:36 +0000 (0:00:01.613)       0:00:25.888 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes_upgrade_check : Retrieve the \"kubeadm-config\" ConfigMap] ***",
                                "Saturday 28 February 2026  00:37:37 +0000 (0:00:00.768)       0:00:26.656 *****",
                                "[ERROR]: Task failed: Module failed: Failed to import the required Python library (kubernetes) on np0000157419's Python /usr/bin/python3.13. Please read the module documentation and install it in the appropriate location. If the required library is installed, but Ansible is using the wrong Python interpreter, please consult the documentation on ansible_python_interpreter",
                                "Origin: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubernetes_upgrade_check/tasks/main.yml:16:3",
                                "",
                                "14",
                                "15 ---",
                                "16 - name: Retrieve the \"kubeadm-config\" ConfigMap",
                                "     ^ column 3",
                                "",
                                "fatal: [controller]: FAILED! => {\"changed\": false, \"msg\": \"Failed to import the required Python library (kubernetes) on np0000157419's Python /usr/bin/python3.13. Please read the module documentation and install it in the appropriate location. If the required library is installed, but Ansible is using the wrong Python interpreter, please consult the documentation on ansible_python_interpreter\"}",
                                "...ignoring",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes_upgrade_check : Parse the ClusterConfiguration] ***",
                                "Saturday 28 February 2026  00:37:38 +0000 (0:00:00.690)       0:00:27.347 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes_upgrade_check : Retrieve the current Kubernetes version] ***",
                                "Saturday 28 February 2026  00:37:38 +0000 (0:00:00.045)       0:00:27.393 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes_upgrade_check : Extract major, minor, and patch versions] ***",
                                "Saturday 28 February 2026  00:37:38 +0000 (0:00:00.040)       0:00:27.433 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes_upgrade_check : Fail if we're jumping more than one minor version] ***",
                                "Saturday 28 February 2026  00:37:38 +0000 (0:00:00.038)       0:00:27.472 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes_upgrade_check : Set fact if we need to upgrade] ***",
                                "Saturday 28 February 2026  00:37:38 +0000 (0:00:00.036)       0:00:27.508 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Saturday 28 February 2026  00:37:38 +0000 (0:00:00.047)       0:00:27.556 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Saturday 28 February 2026  00:37:38 +0000 (0:00:00.317)       0:00:27.874 *****",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://dl.k8s.io/release/v1.34.0/bin/linux/amd64/kubeadm\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Saturday 28 February 2026  00:37:38 +0000 (0:00:00.046)       0:00:27.920 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Saturday 28 February 2026  00:37:39 +0000 (0:00:00.994)       0:00:28.914 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Saturday 28 February 2026  00:37:40 +0000 (0:00:00.033)       0:00:28.948 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Saturday 28 February 2026  00:37:40 +0000 (0:00:00.303)       0:00:29.252 *****",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://dl.k8s.io/release/v1.34.0/bin/linux/amd64/kubectl\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Saturday 28 February 2026  00:37:40 +0000 (0:00:00.049)       0:00:29.301 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Saturday 28 February 2026  00:37:41 +0000 (0:00:00.934)       0:00:30.236 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Install SELinux packages] ***************",
                                "Saturday 28 February 2026  00:37:41 +0000 (0:00:00.051)       0:00:30.288 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Set SELinux to permissive at runtime] ***",
                                "Saturday 28 February 2026  00:37:41 +0000 (0:00:00.038)       0:00:30.326 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Persist SELinux permissive mode] ********",
                                "Saturday 28 February 2026  00:37:41 +0000 (0:00:00.039)       0:00:30.366 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Install AppArmor packages] **************",
                                "Saturday 28 February 2026  00:37:41 +0000 (0:00:00.035)       0:00:30.402 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Create systemd service file for containerd] ***",
                                "Saturday 28 February 2026  00:37:42 +0000 (0:00:00.965)       0:00:31.367 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Create folders for configuration] *******",
                                "Saturday 28 February 2026  00:37:43 +0000 (0:00:00.697)       0:00:32.064 *****",
                                "ok: [controller] => (item={'path': '/etc/containerd'})",
                                "ok: [controller] => (item={'path': '/var/lib/containerd', 'mode': '0o700'})",
                                "ok: [controller] => (item={'path': '/run/containerd', 'mode': '0o711'})",
                                "ok: [controller] => (item={'path': '/run/containerd/io.containerd.grpc.v1.cri', 'mode': '0o700'})",
                                "ok: [controller] => (item={'path': '/run/containerd/io.containerd.sandbox.controller.v1.shim', 'mode': '0o700'})",
                                "",
                                "TASK [vexxhost.containers.containerd : Create containerd config file] **********",
                                "Saturday 28 February 2026  00:37:44 +0000 (0:00:01.466)       0:00:33.530 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Force any restarts if necessary] ********",
                                "Saturday 28 February 2026  00:37:45 +0000 (0:00:00.775)       0:00:34.305 *****",
                                "",
                                "TASK [vexxhost.containers.containerd : Enable and start service] ***************",
                                "Saturday 28 February 2026  00:37:45 +0000 (0:00:00.006)       0:00:34.312 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Saturday 28 February 2026  00:37:45 +0000 (0:00:00.506)       0:00:34.818 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Saturday 28 February 2026  00:37:46 +0000 (0:00:00.310)       0:00:35.128 *****",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://github.com/kubernetes-sigs/cri-tools/releases/download/v1.34.0/crictl-v1.34.0-linux-amd64.tar.gz\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Saturday 28 February 2026  00:37:46 +0000 (0:00:00.074)       0:00:35.203 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Saturday 28 February 2026  00:37:47 +0000 (0:00:00.843)       0:00:36.047 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Saturday 28 February 2026  00:37:48 +0000 (0:00:01.722)       0:00:37.769 *****",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://github.com/kubernetes-sigs/cri-tools/releases/download/v1.34.0/critest-v1.34.0-linux-amd64.tar.gz\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Saturday 28 February 2026  00:37:48 +0000 (0:00:00.074)       0:00:37.843 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Saturday 28 February 2026  00:37:49 +0000 (0:00:00.780)       0:00:38.623 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.cri_tools : Create crictl config] ********************",
                                "Saturday 28 February 2026  00:37:51 +0000 (0:00:01.766)       0:00:40.389 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.directory : Create directory (/opt/cni/bin)] *********",
                                "Saturday 28 February 2026  00:37:52 +0000 (0:00:00.704)       0:00:41.094 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Saturday 28 February 2026  00:37:52 +0000 (0:00:00.316)       0:00:41.410 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Saturday 28 February 2026  00:37:52 +0000 (0:00:00.313)       0:00:41.724 *****",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://github.com/containernetworking/plugins/releases/download/v1.8.0/cni-plugins-linux-amd64-v1.8.0.tgz\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Saturday 28 February 2026  00:37:52 +0000 (0:00:00.070)       0:00:41.794 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Saturday 28 February 2026  00:37:53 +0000 (0:00:01.055)       0:00:42.850 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.cni_plugins : Gather variables for each operating system] ***",
                                "Saturday 28 February 2026  00:37:56 +0000 (0:00:02.964)       0:00:45.815 *****",
                                "ok: [controller] => (item=/home/zuul/.ansible/collections/ansible_collections/vexxhost/containers/roles/cni_plugins/vars/debian.yml)",
                                "",
                                "TASK [vexxhost.containers.cni_plugins : Install additional packages] ***********",
                                "Saturday 28 February 2026  00:37:56 +0000 (0:00:00.057)       0:00:45.872 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.cni_plugins : Ensure IPv6 is enabled] ****************",
                                "Saturday 28 February 2026  00:37:57 +0000 (0:00:01.014)       0:00:46.887 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.cni_plugins : Enable kernel modules on-boot] *********",
                                "Saturday 28 February 2026  00:37:58 +0000 (0:00:00.463)       0:00:47.350 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.cni_plugins : Enable kernel modules in runtime] ******",
                                "Saturday 28 February 2026  00:37:59 +0000 (0:00:00.694)       0:00:48.045 *****",
                                "changed: [controller] => (item=br_netfilter)",
                                "ok: [controller] => (item=ip_tables)",
                                "changed: [controller] => (item=ip6_tables)",
                                "changed: [controller] => (item=nf_conntrack)",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Saturday 28 February 2026  00:38:00 +0000 (0:00:01.519)       0:00:49.564 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Saturday 28 February 2026  00:38:00 +0000 (0:00:00.328)       0:00:49.893 *****",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://dl.k8s.io/release/v1.34.0/bin/linux/amd64/kubelet\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Saturday 28 February 2026  00:38:01 +0000 (0:00:00.056)       0:00:49.949 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Saturday 28 February 2026  00:38:02 +0000 (0:00:01.074)       0:00:51.024 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Gather variables for each operating system] ***",
                                "Saturday 28 February 2026  00:38:02 +0000 (0:00:00.047)       0:00:51.071 *****",
                                "ok: [controller] => (item=/home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubelet/vars/debian.yml)",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Install coreutils] *************************",
                                "Saturday 28 February 2026  00:38:02 +0000 (0:00:00.053)       0:00:51.125 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Install additional packages] ***************",
                                "Saturday 28 February 2026  00:38:02 +0000 (0:00:00.044)       0:00:51.169 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Configure sysctl values] *******************",
                                "Saturday 28 February 2026  00:38:05 +0000 (0:00:03.402)       0:00:54.572 *****",
                                "ok: [controller] => (item={'name': 'net.ipv4.ip_forward', 'value': 1})",
                                "changed: [controller] => (item={'name': 'net.bridge.bridge-nf-call-iptables', 'value': 1})",
                                "changed: [controller] => (item={'name': 'net.bridge.bridge-nf-call-ip6tables', 'value': 1})",
                                "changed: [controller] => (item={'name': 'net.ipv4.conf.all.rp_filter', 'value': 0})",
                                "changed: [controller] => (item={'name': 'fs.inotify.max_queued_events', 'value': 1048576})",
                                "changed: [controller] => (item={'name': 'fs.inotify.max_user_instances', 'value': 8192})",
                                "changed: [controller] => (item={'name': 'fs.inotify.max_user_watches', 'value': 1048576})",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Create folders for kubernetes configuration] ***",
                                "Saturday 28 February 2026  00:38:07 +0000 (0:00:02.285)       0:00:56.858 *****",
                                "changed: [controller] => (item=/etc/systemd/system/kubelet.service.d)",
                                "ok: [controller] => (item=/etc/kubernetes)",
                                "ok: [controller] => (item=/etc/kubernetes/manifests)",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Add kubelet systemd service config] ********",
                                "Saturday 28 February 2026  00:38:08 +0000 (0:00:00.885)       0:00:57.744 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Add kubeadm dropin for kubelet systemd service config] ***",
                                "Saturday 28 February 2026  00:38:09 +0000 (0:00:00.742)       0:00:58.486 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Check swap status] *************************",
                                "Saturday 28 February 2026  00:38:10 +0000 (0:00:00.731)       0:00:59.218 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Disable swap] ******************************",
                                "Saturday 28 February 2026  00:38:10 +0000 (0:00:00.418)       0:00:59.636 *****",
                                "[ERROR]: Task failed: Conditional result (False) was derived from value of type 'str' at '/home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubelet/tasks/main.yml:83:11'. Conditionals must have a boolean result.",
                                "",
                                "Task failed.",
                                "Origin: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubelet/tasks/main.yml:78:7",
                                "",
                                "76       register: kubelet_swapon",
                                "77",
                                "78     - name: Disable swap",
                                "         ^ column 7",
                                "",
                                "<<< caused by >>>",
                                "",
                                "Conditional result (False) was derived from value of type 'str' at '/home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubelet/tasks/main.yml:83:11'. Conditionals must have a boolean result.",
                                "Origin: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubelet/tasks/main.yml:83:11",
                                "",
                                "81       ignore_errors: \"{{ ansible_check_mode }}\"",
                                "82       when:",
                                "83         - kubelet_swapon.stdout",
                                "             ^ column 11",
                                "",
                                "Broken conditionals can be temporarily allowed with the `ALLOW_BROKEN_CONDITIONALS` configuration option.",
                                "",
                                "fatal: [controller]: FAILED! => {\"changed\": false, \"msg\": \"Task failed: Conditional result (False) was derived from value of type 'str' at '/home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubelet/tasks/main.yml:83:11'. Conditionals must have a boolean result.\"}",
                                "...ignoring",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Remove swapfile from /etc/fstab] ***********",
                                "Saturday 28 February 2026  00:38:10 +0000 (0:00:00.039)       0:00:59.675 *****",
                                "ok: [controller] => (item=swap)",
                                "ok: [controller] => (item=none)",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Create noswap systemd service config file] ***",
                                "Saturday 28 February 2026  00:38:11 +0000 (0:00:00.840)       0:01:00.516 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Enable noswap service] *********************",
                                "Saturday 28 February 2026  00:38:12 +0000 (0:00:00.691)       0:01:01.207 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Force any restarts if necessary] ***********",
                                "Saturday 28 February 2026  00:38:13 +0000 (0:00:00.758)       0:01:01.966 *****",
                                "",
                                "RUNNING HANDLER [vexxhost.kubernetes.kubelet : Reload systemd] *****************",
                                "Saturday 28 February 2026  00:38:13 +0000 (0:00:00.005)       0:01:01.971 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Enable and start kubelet service] **********",
                                "Saturday 28 February 2026  00:38:15 +0000 (0:00:02.039)       0:01:04.011 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Ensure availability of dbus on Debian] *****",
                                "Saturday 28 February 2026  00:38:15 +0000 (0:00:00.832)       0:01:04.844 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Configure short hostname] ******************",
                                "Saturday 28 February 2026  00:38:16 +0000 (0:00:01.023)       0:01:05.867 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Ensure hostname inside hosts file] *********",
                                "Saturday 28 February 2026  00:38:17 +0000 (0:00:00.927)       0:01:06.794 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Remove kubernetes repository] ***********",
                                "Saturday 28 February 2026  00:38:18 +0000 (0:00:00.427)       0:01:07.222 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Setup control plane] ********************",
                                "Saturday 28 February 2026  00:38:18 +0000 (0:00:00.553)       0:01:07.775 *****",
                                "included: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubernetes/tasks/control-plane.yml for controller",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Bootstrap cluster] **********************",
                                "Saturday 28 February 2026  00:38:18 +0000 (0:00:00.088)       0:01:07.863 *****",
                                "included: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubernetes/tasks/bootstrap-cluster.yml for controller",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Check if any control plane is bootstrapped] ***",
                                "Saturday 28 February 2026  00:38:19 +0000 (0:00:00.088)       0:01:07.952 *****",
                                "ok: [controller] => (item=controller)",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Pick node from pre-existing cluster] ****",
                                "Saturday 28 February 2026  00:38:19 +0000 (0:00:00.334)       0:01:08.286 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Select first node to initialize cluster] ***",
                                "Saturday 28 February 2026  00:38:19 +0000 (0:00:00.042)       0:01:08.329 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Print selected bootstrap node] **********",
                                "Saturday 28 February 2026  00:38:19 +0000 (0:00:00.060)       0:01:08.389 *****",
                                "ok: [controller] => {",
                                "    \"msg\": \"controller\"",
                                "}",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Upload cluster configuration for bootstrap node] ***",
                                "Saturday 28 February 2026  00:38:19 +0000 (0:00:00.049)       0:01:08.438 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create pki folder] **********************",
                                "Saturday 28 February 2026  00:38:20 +0000 (0:00:00.756)       0:01:09.195 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create kubernetes ca key] ***************",
                                "Saturday 28 February 2026  00:38:20 +0000 (0:00:00.035)       0:01:09.230 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create kubernetes ca cert] **************",
                                "Saturday 28 February 2026  00:38:20 +0000 (0:00:00.034)       0:01:09.265 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create etcd-ca key] *********************",
                                "Saturday 28 February 2026  00:38:20 +0000 (0:00:00.038)       0:01:09.303 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create etcd-ca cert] ********************",
                                "Saturday 28 February 2026  00:38:20 +0000 (0:00:00.039)       0:01:09.343 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create front-proxy-ca key] **************",
                                "Saturday 28 February 2026  00:38:20 +0000 (0:00:00.032)       0:01:09.376 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create front-proxy-ca cert] *************",
                                "Saturday 28 February 2026  00:38:20 +0000 (0:00:00.042)       0:01:09.418 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Initialize cluster] *********************",
                                "Saturday 28 February 2026  00:38:20 +0000 (0:00:00.041)       0:01:09.460 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Check if the node is already part of the cluster] ***",
                                "Saturday 28 February 2026  00:38:58 +0000 (0:00:38.438)       0:01:47.898 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Join cluster] ***************************",
                                "Saturday 28 February 2026  00:38:59 +0000 (0:00:00.332)       0:01:48.230 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create folder for admin configuration] ***",
                                "Saturday 28 February 2026  00:38:59 +0000 (0:00:00.042)       0:01:48.272 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Creating a symlink for admin configuration file] ***",
                                "Saturday 28 February 2026  00:38:59 +0000 (0:00:00.330)       0:01:48.603 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Add bash autocomplete for kubectl] ******",
                                "Saturday 28 February 2026  00:38:59 +0000 (0:00:00.320)       0:01:48.923 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Install PIP] ****************************",
                                "Saturday 28 February 2026  00:39:00 +0000 (0:00:00.331)       0:01:49.254 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Install Kubernetes Python package using pip on supported systems] ***",
                                "Saturday 28 February 2026  00:39:00 +0000 (0:00:00.046)       0:01:49.301 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Enable EPEL repository] *****************",
                                "Saturday 28 February 2026  00:39:00 +0000 (0:00:00.045)       0:01:49.346 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Install Kubernetes Python package using package manager on supported systems] ***",
                                "Saturday 28 February 2026  00:39:00 +0000 (0:00:00.046)       0:01:49.393 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Allow workload on control plane node] ***",
                                "Saturday 28 February 2026  00:39:10 +0000 (0:00:10.441)       0:01:59.834 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Remove kube-proxy resources] ************",
                                "Saturday 28 February 2026  00:39:11 +0000 (0:00:00.956)       0:02:00.791 *****",
                                "skipping: [controller] => (item=DaemonSet)",
                                "skipping: [controller] => (item=ConfigMap)",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Start an upgrade] ***********************",
                                "Saturday 28 February 2026  00:39:11 +0000 (0:00:00.039)       0:02:00.830 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Check if the Kubernetes API services is up to date] ***",
                                "Saturday 28 February 2026  00:39:11 +0000 (0:00:00.040)       0:02:00.871 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Trigger an upgrade of the Kubernetes API services] ***",
                                "Saturday 28 February 2026  00:39:11 +0000 (0:00:00.038)       0:02:00.910 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Setup nodes] ****************************",
                                "Saturday 28 February 2026  00:39:12 +0000 (0:00:00.040)       0:02:00.950 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Upgrade & restart Kubelet node for upgrade (if needed)] ***",
                                "Saturday 28 February 2026  00:39:12 +0000 (0:00:00.040)       0:02:00.991 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Set node selector for CoreDNS components] ***",
                                "Saturday 28 February 2026  00:39:12 +0000 (0:00:00.510)       0:02:01.501 *****",
                                "changed: [controller]",
                                "",
                                "PLAY [Install control-plane components] ****************************************",
                                "",
                                "TASK [Gathering Facts] *********************************************************",
                                "Saturday 28 February 2026  00:39:13 +0000 (0:00:01.088)       0:02:02.589 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Saturday 28 February 2026  00:39:14 +0000 (0:00:00.853)       0:02:03.443 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.package : Update state for tar] **********************",
                                "Saturday 28 February 2026  00:39:14 +0000 (0:00:00.306)       0:02:03.750 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.directory : Create directory (/var/lib/downloads)] ***",
                                "Saturday 28 February 2026  00:39:15 +0000 (0:00:00.975)       0:02:04.725 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Saturday 28 February 2026  00:39:16 +0000 (0:00:00.333)       0:02:05.059 *****",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://get.helm.sh/helm-v3.11.2-linux-amd64.tar.gz\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Saturday 28 February 2026  00:39:16 +0000 (0:00:00.043)       0:02:05.103 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Saturday 28 February 2026  00:39:16 +0000 (0:00:00.629)       0:02:05.733 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.helm : Remove Helm repository] ***********************",
                                "Saturday 28 February 2026  00:39:18 +0000 (0:00:01.790)       0:02:07.523 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.helm : Add bash autocomplete for helm] ***************",
                                "Saturday 28 February 2026  00:39:18 +0000 (0:00:00.400)       0:02:07.924 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.helm : Get Helm plugins dir] *************************",
                                "Saturday 28 February 2026  00:39:19 +0000 (0:00:00.344)       0:02:08.268 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.helm : Create Helm plugins directory if it does not exist] ***",
                                "Saturday 28 February 2026  00:39:19 +0000 (0:00:00.396)       0:02:08.665 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.helm : Remove Helm diff plugin installed by kubernetes.core.helm_plugin] ***",
                                "Saturday 28 February 2026  00:39:20 +0000 (0:00:00.319)       0:02:08.984 *****",
                                "ok: [controller]",
                                "",
                                "TASK [Install plugin] **********************************************************",
                                "Saturday 28 February 2026  00:39:20 +0000 (0:00:00.293)       0:02:09.278 *****",
                                "included: vexxhost.containers.download_artifact for controller",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Saturday 28 February 2026  00:39:20 +0000 (0:00:00.056)       0:02:09.334 *****",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://github.com/databus23/helm-diff/releases/download/v3.8.1/helm-diff-linux-amd64.tgz\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Saturday 28 February 2026  00:39:20 +0000 (0:00:00.036)       0:02:09.370 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Saturday 28 February 2026  00:39:21 +0000 (0:00:00.779)       0:02:10.150 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.upload_helm_chart : Include help chart upload method tasks] ***",
                                "Saturday 28 February 2026  00:39:23 +0000 (0:00:02.133)       0:02:12.284 *****",
                                "included: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/upload_helm_chart/tasks/synchronize.yml for controller",
                                "",
                                "TASK [vexxhost.kubernetes.upload_helm_chart : Upload Helm chart] ***************",
                                "Saturday 28 February 2026  00:39:23 +0000 (0:00:00.089)       0:02:12.373 *****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.cilium : Get current Kubernetes version] *************",
                                "Saturday 28 February 2026  00:39:24 +0000 (0:00:00.808)       0:02:13.181 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.cilium : Deploy Helm chart] **************************",
                                "Saturday 28 February 2026  00:39:25 +0000 (0:00:00.933)       0:02:14.115 *****",
                                "changed: [controller]",
                                "",
                                "PLAY RECAP *********************************************************************",
                                "controller                 : ok=112  changed=51   unreachable=0    failed=0    skipped=34   rescued=0    ignored=3",
                                "",
                                "",
                                "TASKS RECAP ********************************************************************",
                                "Saturday 28 February 2026  00:39:27 +0000 (0:00:02.162)       0:02:16.277 *****",
                                "===============================================================================",
                                "vexxhost.kubernetes.kubernetes : Initialize cluster -------------------- 38.44s",
                                "vexxhost.kubernetes.kubernetes : Install Kubernetes Python package using package manager on supported systems -- 10.44s",
                                "vexxhost.containers.containerd : Install AppArmor packages -------------- 5.86s",
                                "vexxhost.kubernetes.kubelet : Reload systemd ---------------------------- 3.65s",
                                "vexxhost.kubernetes.kubelet : Install additional packages --------------- 3.40s",
                                "vexxhost.containers.download_artifact : Extract archive ----------------- 3.14s",
                                "vexxhost.containers.download_artifact : Extract archive ----------------- 2.96s",
                                "vexxhost.kubernetes.kubelet : Configure sysctl values ------------------- 2.29s",
                                "vexxhost.kubernetes.cilium : Deploy Helm chart -------------------------- 2.16s",
                                "vexxhost.containers.download_artifact : Extract archive ----------------- 2.13s",
                                "vexxhost.containers.download_artifact : Extract archive ----------------- 1.79s",
                                "vexxhost.containers.download_artifact : Extract archive ----------------- 1.77s",
                                "vexxhost.containers.download_artifact : Extract archive ----------------- 1.72s",
                                "vexxhost.containers.cni_plugins : Enable kernel modules in runtime ------ 1.52s",
                                "vexxhost.containers.containerd : Create folders for configuration ------- 1.49s",
                                "vexxhost.kubernetes.kube_vip : Uninstall legacy HA stack ---------------- 1.47s",
                                "vexxhost.containers.containerd : Create folders for configuration ------- 1.47s",
                                "vexxhost.containers.package : Update state for tar ---------------------- 1.21s",
                                "Gathering Facts --------------------------------------------------------- 1.10s",
                                "vexxhost.kubernetes.kubernetes : Set node selector for CoreDNS components --- 1.09s",
                                "INFO     [bgp > converge] Executed: Successful",
                                "INFO     [bgp > idempotence] Executing",
                                "",
                                "PLAY [Configure Kubernetes VIP] ************************************************",
                                "",
                                "TASK [Gathering Facts] *********************************************************",
                                "Saturday 28 February 2026  00:39:28 +0000 (0:00:00.017)       0:00:00.017 *****",
                                "[WARNING]: Host 'controller' is using the discovered Python interpreter at '/usr/bin/python3.13', but future installation of another Python interpreter could cause a different interpreter to be discovered. See https://docs.ansible.com/ansible-core/2.20/reference_appendices/interpreter_discovery.html for more information.",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.directory : Create directory (/etc/kubernetes/manifests)] ***",
                                "Saturday 28 February 2026  00:39:31 +0000 (0:00:02.575)       0:00:02.593 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Uninstall legacy HA stack] ****************",
                                "Saturday 28 February 2026  00:39:31 +0000 (0:00:00.417)       0:00:03.010 *****",
                                "ok: [controller] => (item=/etc/keepalived/keepalived.conf)",
                                "ok: [controller] => (item=/etc/keepalived/check_apiserver.sh)",
                                "ok: [controller] => (item=/etc/kubernetes/manifests/keepalived.yaml)",
                                "ok: [controller] => (item=/etc/haproxy/haproxy.cfg)",
                                "ok: [controller] => (item=/etc/kubernetes/manifests/haproxy.yaml)",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Switch API server to run on port 6443] ****",
                                "Saturday 28 February 2026  00:39:33 +0000 (0:00:01.431)       0:00:04.442 *****",
                                "ok: [controller] => (item=/etc/kubernetes/manifests/kube-apiserver.yaml)",
                                "ok: [controller] => (item=/etc/kubernetes/controller-manager.conf)",
                                "ok: [controller] => (item=/etc/kubernetes/scheduler.conf)",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Check if super-admin.conf exists] *********",
                                "Saturday 28 February 2026  00:39:34 +0000 (0:00:00.956)       0:00:05.398 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Check if kubeadm has already run] *********",
                                "Saturday 28 February 2026  00:39:34 +0000 (0:00:00.508)       0:00:05.907 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Set fact with KUBECONFIG path] ************",
                                "Saturday 28 February 2026  00:39:35 +0000 (0:00:00.310)       0:00:06.217 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Set fact with KUBECONFIG path (with super-admin.conf)] ***",
                                "Saturday 28 February 2026  00:39:35 +0000 (0:00:00.033)       0:00:06.251 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Upload Kubernetes manifest] ***************",
                                "Saturday 28 February 2026  00:39:35 +0000 (0:00:00.038)       0:00:06.290 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Ensure kube-vip configuration file] *******",
                                "Saturday 28 February 2026  00:39:35 +0000 (0:00:00.765)       0:00:07.055 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Flush handlers] ***************************",
                                "Saturday 28 February 2026  00:39:36 +0000 (0:00:00.328)       0:00:07.383 *****",
                                "",
                                "PLAY [Install Kubernetes] ******************************************************",
                                "",
                                "TASK [Gathering Facts] *********************************************************",
                                "Saturday 28 February 2026  00:39:36 +0000 (0:00:00.063)       0:00:07.447 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Saturday 28 February 2026  00:39:37 +0000 (0:00:00.872)       0:00:08.319 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.package : Update state for tar] **********************",
                                "Saturday 28 February 2026  00:39:37 +0000 (0:00:00.345)       0:00:08.665 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.directory : Create directory (/var/lib/downloads)] ***",
                                "Saturday 28 February 2026  00:39:37 +0000 (0:00:00.041)       0:00:08.707 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Saturday 28 February 2026  00:39:37 +0000 (0:00:00.317)       0:00:09.024 *****",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://github.com/opencontainers/runc/releases/download/v1.4.0/runc.amd64\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Saturday 28 February 2026  00:39:37 +0000 (0:00:00.068)       0:00:09.092 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Saturday 28 February 2026  00:39:38 +0000 (0:00:00.558)       0:00:09.651 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Saturday 28 February 2026  00:39:38 +0000 (0:00:00.044)       0:00:09.696 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.package : Update state for tar] **********************",
                                "Saturday 28 February 2026  00:39:38 +0000 (0:00:00.337)       0:00:10.033 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Saturday 28 February 2026  00:39:39 +0000 (0:00:01.114)       0:00:11.147 *****",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://github.com/containerd/containerd/releases/download/v2.2.0/containerd-2.2.0-linux-amd64.tar.gz\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Saturday 28 February 2026  00:39:40 +0000 (0:00:00.077)       0:00:11.225 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Saturday 28 February 2026  00:39:40 +0000 (0:00:00.512)       0:00:11.738 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Install SELinux packages] ***************",
                                "Saturday 28 February 2026  00:39:43 +0000 (0:00:02.456)       0:00:14.194 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Set SELinux to permissive at runtime] ***",
                                "Saturday 28 February 2026  00:39:43 +0000 (0:00:00.031)       0:00:14.225 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Persist SELinux permissive mode] ********",
                                "Saturday 28 February 2026  00:39:43 +0000 (0:00:00.041)       0:00:14.267 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Install AppArmor packages] **************",
                                "Saturday 28 February 2026  00:39:43 +0000 (0:00:00.033)       0:00:14.300 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Create systemd service file for containerd] ***",
                                "Saturday 28 February 2026  00:39:44 +0000 (0:00:01.032)       0:00:15.333 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Create folders for configuration] *******",
                                "Saturday 28 February 2026  00:39:44 +0000 (0:00:00.674)       0:00:16.007 *****",
                                "ok: [controller] => (item={'path': '/etc/containerd'})",
                                "ok: [controller] => (item={'path': '/var/lib/containerd', 'mode': '0o700'})",
                                "ok: [controller] => (item={'path': '/run/containerd', 'mode': '0o711'})",
                                "ok: [controller] => (item={'path': '/run/containerd/io.containerd.grpc.v1.cri', 'mode': '0o700'})",
                                "ok: [controller] => (item={'path': '/run/containerd/io.containerd.sandbox.controller.v1.shim', 'mode': '0o700'})",
                                "",
                                "TASK [vexxhost.containers.containerd : Create containerd config file] **********",
                                "Saturday 28 February 2026  00:39:46 +0000 (0:00:01.457)       0:00:17.465 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Force any restarts if necessary] ********",
                                "Saturday 28 February 2026  00:39:47 +0000 (0:00:00.809)       0:00:18.274 *****",
                                "",
                                "TASK [vexxhost.containers.containerd : Enable and start service] ***************",
                                "Saturday 28 February 2026  00:39:47 +0000 (0:00:00.007)       0:00:18.281 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes_upgrade_check : Retrieve the \"kubeadm-config\" ConfigMap] ***",
                                "Saturday 28 February 2026  00:39:47 +0000 (0:00:00.855)       0:00:19.136 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes_upgrade_check : Parse the ClusterConfiguration] ***",
                                "Saturday 28 February 2026  00:39:48 +0000 (0:00:00.915)       0:00:20.052 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes_upgrade_check : Retrieve the current Kubernetes version] ***",
                                "Saturday 28 February 2026  00:39:48 +0000 (0:00:00.046)       0:00:20.099 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes_upgrade_check : Extract major, minor, and patch versions] ***",
                                "Saturday 28 February 2026  00:39:48 +0000 (0:00:00.045)       0:00:20.144 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes_upgrade_check : Fail if we're jumping more than one minor version] ***",
                                "Saturday 28 February 2026  00:39:49 +0000 (0:00:00.052)       0:00:20.196 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes_upgrade_check : Set fact if we need to upgrade] ***",
                                "Saturday 28 February 2026  00:39:49 +0000 (0:00:00.043)       0:00:20.239 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Saturday 28 February 2026  00:39:49 +0000 (0:00:00.047)       0:00:20.287 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Saturday 28 February 2026  00:39:49 +0000 (0:00:00.314)       0:00:20.601 *****",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://dl.k8s.io/release/v1.34.0/bin/linux/amd64/kubeadm\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Saturday 28 February 2026  00:39:49 +0000 (0:00:00.042)       0:00:20.644 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Saturday 28 February 2026  00:39:49 +0000 (0:00:00.452)       0:00:21.097 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Saturday 28 February 2026  00:39:49 +0000 (0:00:00.040)       0:00:21.137 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Saturday 28 February 2026  00:39:50 +0000 (0:00:00.316)       0:00:21.454 *****",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://dl.k8s.io/release/v1.34.0/bin/linux/amd64/kubectl\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Saturday 28 February 2026  00:39:50 +0000 (0:00:00.043)       0:00:21.498 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Saturday 28 February 2026  00:39:50 +0000 (0:00:00.478)       0:00:21.977 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Install SELinux packages] ***************",
                                "Saturday 28 February 2026  00:39:50 +0000 (0:00:00.055)       0:00:22.032 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Set SELinux to permissive at runtime] ***",
                                "Saturday 28 February 2026  00:39:50 +0000 (0:00:00.035)       0:00:22.067 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Persist SELinux permissive mode] ********",
                                "Saturday 28 February 2026  00:39:50 +0000 (0:00:00.033)       0:00:22.100 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Install AppArmor packages] **************",
                                "Saturday 28 February 2026  00:39:50 +0000 (0:00:00.030)       0:00:22.131 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Create systemd service file for containerd] ***",
                                "Saturday 28 February 2026  00:39:52 +0000 (0:00:01.092)       0:00:23.223 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Create folders for configuration] *******",
                                "Saturday 28 February 2026  00:39:52 +0000 (0:00:00.706)       0:00:23.929 *****",
                                "ok: [controller] => (item={'path': '/etc/containerd'})",
                                "ok: [controller] => (item={'path': '/var/lib/containerd', 'mode': '0o700'})",
                                "ok: [controller] => (item={'path': '/run/containerd', 'mode': '0o711'})",
                                "ok: [controller] => (item={'path': '/run/containerd/io.containerd.grpc.v1.cri', 'mode': '0o700'})",
                                "ok: [controller] => (item={'path': '/run/containerd/io.containerd.sandbox.controller.v1.shim', 'mode': '0o700'})",
                                "",
                                "TASK [vexxhost.containers.containerd : Create containerd config file] **********",
                                "Saturday 28 February 2026  00:39:54 +0000 (0:00:01.518)       0:00:25.448 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Force any restarts if necessary] ********",
                                "Saturday 28 February 2026  00:39:55 +0000 (0:00:00.837)       0:00:26.286 *****",
                                "",
                                "TASK [vexxhost.containers.containerd : Enable and start service] ***************",
                                "Saturday 28 February 2026  00:39:55 +0000 (0:00:00.005)       0:00:26.292 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Saturday 28 February 2026  00:39:55 +0000 (0:00:00.554)       0:00:26.846 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Saturday 28 February 2026  00:39:56 +0000 (0:00:00.317)       0:00:27.163 *****",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://github.com/kubernetes-sigs/cri-tools/releases/download/v1.34.0/crictl-v1.34.0-linux-amd64.tar.gz\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Saturday 28 February 2026  00:39:56 +0000 (0:00:00.075)       0:00:27.239 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Saturday 28 February 2026  00:39:56 +0000 (0:00:00.440)       0:00:27.679 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Saturday 28 February 2026  00:39:57 +0000 (0:00:01.392)       0:00:29.071 *****",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://github.com/kubernetes-sigs/cri-tools/releases/download/v1.34.0/critest-v1.34.0-linux-amd64.tar.gz\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Saturday 28 February 2026  00:39:57 +0000 (0:00:00.074)       0:00:29.146 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Saturday 28 February 2026  00:39:58 +0000 (0:00:00.447)       0:00:29.594 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.cri_tools : Create crictl config] ********************",
                                "Saturday 28 February 2026  00:39:59 +0000 (0:00:01.435)       0:00:31.030 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.directory : Create directory (/opt/cni/bin)] *********",
                                "Saturday 28 February 2026  00:40:00 +0000 (0:00:00.678)       0:00:31.708 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Saturday 28 February 2026  00:40:00 +0000 (0:00:00.329)       0:00:32.038 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Saturday 28 February 2026  00:40:01 +0000 (0:00:00.371)       0:00:32.410 *****",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://github.com/containernetworking/plugins/releases/download/v1.8.0/cni-plugins-linux-amd64-v1.8.0.tgz\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Saturday 28 February 2026  00:40:01 +0000 (0:00:00.076)       0:00:32.486 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Saturday 28 February 2026  00:40:01 +0000 (0:00:00.491)       0:00:32.978 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.cni_plugins : Gather variables for each operating system] ***",
                                "Saturday 28 February 2026  00:40:04 +0000 (0:00:02.295)       0:00:35.273 *****",
                                "ok: [controller] => (item=/home/zuul/.ansible/collections/ansible_collections/vexxhost/containers/roles/cni_plugins/vars/debian.yml)",
                                "",
                                "TASK [vexxhost.containers.cni_plugins : Install additional packages] ***********",
                                "Saturday 28 February 2026  00:40:04 +0000 (0:00:00.064)       0:00:35.338 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.cni_plugins : Ensure IPv6 is enabled] ****************",
                                "Saturday 28 February 2026  00:40:05 +0000 (0:00:00.959)       0:00:36.297 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.cni_plugins : Enable kernel modules on-boot] *********",
                                "Saturday 28 February 2026  00:40:05 +0000 (0:00:00.478)       0:00:36.775 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.cni_plugins : Enable kernel modules in runtime] ******",
                                "Saturday 28 February 2026  00:40:06 +0000 (0:00:00.718)       0:00:37.494 *****",
                                "ok: [controller] => (item=br_netfilter)",
                                "ok: [controller] => (item=ip_tables)",
                                "ok: [controller] => (item=ip6_tables)",
                                "ok: [controller] => (item=nf_conntrack)",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Saturday 28 February 2026  00:40:07 +0000 (0:00:01.264)       0:00:38.759 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Saturday 28 February 2026  00:40:07 +0000 (0:00:00.311)       0:00:39.070 *****",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://dl.k8s.io/release/v1.34.0/bin/linux/amd64/kubelet\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Saturday 28 February 2026  00:40:07 +0000 (0:00:00.047)       0:00:39.118 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Saturday 28 February 2026  00:40:08 +0000 (0:00:00.481)       0:00:39.599 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Gather variables for each operating system] ***",
                                "Saturday 28 February 2026  00:40:08 +0000 (0:00:00.040)       0:00:39.639 *****",
                                "ok: [controller] => (item=/home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubelet/vars/debian.yml)",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Install coreutils] *************************",
                                "Saturday 28 February 2026  00:40:08 +0000 (0:00:00.057)       0:00:39.696 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Install additional packages] ***************",
                                "Saturday 28 February 2026  00:40:08 +0000 (0:00:00.036)       0:00:39.733 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Configure sysctl values] *******************",
                                "Saturday 28 February 2026  00:40:09 +0000 (0:00:00.914)       0:00:40.647 *****",
                                "ok: [controller] => (item={'name': 'net.ipv4.ip_forward', 'value': 1})",
                                "ok: [controller] => (item={'name': 'net.bridge.bridge-nf-call-iptables', 'value': 1})",
                                "ok: [controller] => (item={'name': 'net.bridge.bridge-nf-call-ip6tables', 'value': 1})",
                                "ok: [controller] => (item={'name': 'net.ipv4.conf.all.rp_filter', 'value': 0})",
                                "ok: [controller] => (item={'name': 'fs.inotify.max_queued_events', 'value': 1048576})",
                                "ok: [controller] => (item={'name': 'fs.inotify.max_user_instances', 'value': 8192})",
                                "ok: [controller] => (item={'name': 'fs.inotify.max_user_watches', 'value': 1048576})",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Create folders for kubernetes configuration] ***",
                                "Saturday 28 February 2026  00:40:11 +0000 (0:00:02.181)       0:00:42.829 *****",
                                "ok: [controller] => (item=/etc/systemd/system/kubelet.service.d)",
                                "ok: [controller] => (item=/etc/kubernetes)",
                                "ok: [controller] => (item=/etc/kubernetes/manifests)",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Add kubelet systemd service config] ********",
                                "Saturday 28 February 2026  00:40:12 +0000 (0:00:00.882)       0:00:43.711 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Add kubeadm dropin for kubelet systemd service config] ***",
                                "Saturday 28 February 2026  00:40:13 +0000 (0:00:00.650)       0:00:44.362 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Check swap status] *************************",
                                "Saturday 28 February 2026  00:40:13 +0000 (0:00:00.675)       0:00:45.037 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Disable swap] ******************************",
                                "Saturday 28 February 2026  00:40:14 +0000 (0:00:00.439)       0:00:45.476 *****",
                                "[ERROR]: Task failed: Conditional result (False) was derived from value of type 'str' at '/home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubelet/tasks/main.yml:83:11'. Conditionals must have a boolean result.",
                                "",
                                "Task failed.",
                                "Origin: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubelet/tasks/main.yml:78:7",
                                "",
                                "76       register: kubelet_swapon",
                                "77",
                                "78     - name: Disable swap",
                                "         ^ column 7",
                                "",
                                "<<< caused by >>>",
                                "",
                                "Conditional result (False) was derived from value of type 'str' at '/home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubelet/tasks/main.yml:83:11'. Conditionals must have a boolean result.",
                                "Origin: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubelet/tasks/main.yml:83:11",
                                "",
                                "81       ignore_errors: \"{{ ansible_check_mode }}\"",
                                "82       when:",
                                "83         - kubelet_swapon.stdout",
                                "             ^ column 11",
                                "",
                                "Broken conditionals can be temporarily allowed with the `ALLOW_BROKEN_CONDITIONALS` configuration option.",
                                "",
                                "fatal: [controller]: FAILED! => {\"changed\": false, \"msg\": \"Task failed: Conditional result (False) was derived from value of type 'str' at '/home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubelet/tasks/main.yml:83:11'. Conditionals must have a boolean result.\"}",
                                "...ignoring",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Remove swapfile from /etc/fstab] ***********",
                                "Saturday 28 February 2026  00:40:14 +0000 (0:00:00.032)       0:00:45.509 *****",
                                "ok: [controller] => (item=swap)",
                                "ok: [controller] => (item=none)",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Create noswap systemd service config file] ***",
                                "Saturday 28 February 2026  00:40:15 +0000 (0:00:00.808)       0:00:46.317 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Enable noswap service] *********************",
                                "Saturday 28 February 2026  00:40:15 +0000 (0:00:00.718)       0:00:47.036 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Force any restarts if necessary] ***********",
                                "Saturday 28 February 2026  00:40:16 +0000 (0:00:00.493)       0:00:47.530 *****",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Enable and start kubelet service] **********",
                                "Saturday 28 February 2026  00:40:16 +0000 (0:00:00.007)       0:00:47.538 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Ensure availability of dbus on Debian] *****",
                                "Saturday 28 February 2026  00:40:16 +0000 (0:00:00.523)       0:00:48.061 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Configure short hostname] ******************",
                                "Saturday 28 February 2026  00:40:17 +0000 (0:00:00.924)       0:00:48.985 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Ensure hostname inside hosts file] *********",
                                "Saturday 28 February 2026  00:40:18 +0000 (0:00:00.918)       0:00:49.903 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Remove kubernetes repository] ***********",
                                "Saturday 28 February 2026  00:40:19 +0000 (0:00:00.429)       0:00:50.332 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Setup control plane] ********************",
                                "Saturday 28 February 2026  00:40:19 +0000 (0:00:00.520)       0:00:50.853 *****",
                                "included: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubernetes/tasks/control-plane.yml for controller",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Bootstrap cluster] **********************",
                                "Saturday 28 February 2026  00:40:19 +0000 (0:00:00.080)       0:00:50.934 *****",
                                "included: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubernetes/tasks/bootstrap-cluster.yml for controller",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Check if any control plane is bootstrapped] ***",
                                "Saturday 28 February 2026  00:40:19 +0000 (0:00:00.078)       0:00:51.012 *****",
                                "ok: [controller] => (item=controller)",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Pick node from pre-existing cluster] ****",
                                "Saturday 28 February 2026  00:40:20 +0000 (0:00:00.329)       0:00:51.342 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Select first node to initialize cluster] ***",
                                "Saturday 28 February 2026  00:40:20 +0000 (0:00:00.050)       0:00:51.392 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Print selected bootstrap node] **********",
                                "Saturday 28 February 2026  00:40:20 +0000 (0:00:00.042)       0:00:51.434 *****",
                                "ok: [controller] => {",
                                "    \"msg\": \"controller\"",
                                "}",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Upload cluster configuration for bootstrap node] ***",
                                "Saturday 28 February 2026  00:40:20 +0000 (0:00:00.043)       0:00:51.477 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create pki folder] **********************",
                                "Saturday 28 February 2026  00:40:21 +0000 (0:00:00.716)       0:00:52.194 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create kubernetes ca key] ***************",
                                "Saturday 28 February 2026  00:40:21 +0000 (0:00:00.033)       0:00:52.228 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create kubernetes ca cert] **************",
                                "Saturday 28 February 2026  00:40:21 +0000 (0:00:00.033)       0:00:52.261 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create etcd-ca key] *********************",
                                "Saturday 28 February 2026  00:40:21 +0000 (0:00:00.034)       0:00:52.296 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create etcd-ca cert] ********************",
                                "Saturday 28 February 2026  00:40:21 +0000 (0:00:00.033)       0:00:52.329 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create front-proxy-ca key] **************",
                                "Saturday 28 February 2026  00:40:21 +0000 (0:00:00.031)       0:00:52.361 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create front-proxy-ca cert] *************",
                                "Saturday 28 February 2026  00:40:21 +0000 (0:00:00.034)       0:00:52.395 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Initialize cluster] *********************",
                                "Saturday 28 February 2026  00:40:21 +0000 (0:00:00.035)       0:00:52.430 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Check if the node is already part of the cluster] ***",
                                "Saturday 28 February 2026  00:40:21 +0000 (0:00:00.297)       0:00:52.728 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Join cluster] ***************************",
                                "Saturday 28 February 2026  00:40:21 +0000 (0:00:00.323)       0:00:53.052 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create folder for admin configuration] ***",
                                "Saturday 28 February 2026  00:40:21 +0000 (0:00:00.035)       0:00:53.087 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Creating a symlink for admin configuration file] ***",
                                "Saturday 28 February 2026  00:40:22 +0000 (0:00:00.307)       0:00:53.395 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Add bash autocomplete for kubectl] ******",
                                "Saturday 28 February 2026  00:40:22 +0000 (0:00:00.303)       0:00:53.698 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Install PIP] ****************************",
                                "Saturday 28 February 2026  00:40:22 +0000 (0:00:00.302)       0:00:54.001 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Install Kubernetes Python package using pip on supported systems] ***",
                                "Saturday 28 February 2026  00:40:22 +0000 (0:00:00.038)       0:00:54.039 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Enable EPEL repository] *****************",
                                "Saturday 28 February 2026  00:40:22 +0000 (0:00:00.036)       0:00:54.076 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Install Kubernetes Python package using package manager on supported systems] ***",
                                "Saturday 28 February 2026  00:40:22 +0000 (0:00:00.039)       0:00:54.115 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Allow workload on control plane node] ***",
                                "Saturday 28 February 2026  00:40:23 +0000 (0:00:00.887)       0:00:55.003 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Remove kube-proxy resources] ************",
                                "Saturday 28 February 2026  00:40:24 +0000 (0:00:00.828)       0:00:55.831 *****",
                                "skipping: [controller] => (item=DaemonSet)",
                                "skipping: [controller] => (item=ConfigMap)",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Start an upgrade] ***********************",
                                "Saturday 28 February 2026  00:40:24 +0000 (0:00:00.040)       0:00:55.872 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Check if the Kubernetes API services is up to date] ***",
                                "Saturday 28 February 2026  00:40:24 +0000 (0:00:00.037)       0:00:55.909 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Trigger an upgrade of the Kubernetes API services] ***",
                                "Saturday 28 February 2026  00:40:24 +0000 (0:00:00.032)       0:00:55.942 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Setup nodes] ****************************",
                                "Saturday 28 February 2026  00:40:24 +0000 (0:00:00.037)       0:00:55.979 *****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Upgrade & restart Kubelet node for upgrade (if needed)] ***",
                                "Saturday 28 February 2026  00:40:24 +0000 (0:00:00.034)       0:00:56.014 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Set node selector for CoreDNS components] ***",
                                "Saturday 28 February 2026  00:40:25 +0000 (0:00:00.538)       0:00:56.553 *****",
                                "ok: [controller]",
                                "",
                                "PLAY [Install control-plane components] ****************************************",
                                "",
                                "TASK [Gathering Facts] *********************************************************",
                                "Saturday 28 February 2026  00:40:26 +0000 (0:00:01.036)       0:00:57.590 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Saturday 28 February 2026  00:40:27 +0000 (0:00:01.025)       0:00:58.616 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.package : Update state for tar] **********************",
                                "Saturday 28 February 2026  00:40:27 +0000 (0:00:00.310)       0:00:58.926 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.directory : Create directory (/var/lib/downloads)] ***",
                                "Saturday 28 February 2026  00:40:28 +0000 (0:00:01.037)       0:00:59.963 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Saturday 28 February 2026  00:40:29 +0000 (0:00:00.318)       0:01:00.282 *****",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://get.helm.sh/helm-v3.11.2-linux-amd64.tar.gz\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Saturday 28 February 2026  00:40:29 +0000 (0:00:00.043)       0:01:00.325 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Saturday 28 February 2026  00:40:29 +0000 (0:00:00.429)       0:01:00.755 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.helm : Remove Helm repository] ***********************",
                                "Saturday 28 February 2026  00:40:31 +0000 (0:00:01.487)       0:01:02.244 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.helm : Add bash autocomplete for helm] ***************",
                                "Saturday 28 February 2026  00:40:31 +0000 (0:00:00.457)       0:01:02.701 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.helm : Get Helm plugins dir] *************************",
                                "Saturday 28 February 2026  00:40:31 +0000 (0:00:00.348)       0:01:03.049 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.helm : Create Helm plugins directory if it does not exist] ***",
                                "Saturday 28 February 2026  00:40:32 +0000 (0:00:00.373)       0:01:03.423 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.helm : Remove Helm diff plugin installed by kubernetes.core.helm_plugin] ***",
                                "Saturday 28 February 2026  00:40:32 +0000 (0:00:00.327)       0:01:03.750 *****",
                                "ok: [controller]",
                                "",
                                "TASK [Install plugin] **********************************************************",
                                "Saturday 28 February 2026  00:40:32 +0000 (0:00:00.352)       0:01:04.102 *****",
                                "included: vexxhost.containers.download_artifact for controller",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Saturday 28 February 2026  00:40:33 +0000 (0:00:00.065)       0:01:04.167 *****",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://github.com/databus23/helm-diff/releases/download/v3.8.1/helm-diff-linux-amd64.tgz\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Saturday 28 February 2026  00:40:33 +0000 (0:00:00.044)       0:01:04.212 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Saturday 28 February 2026  00:40:33 +0000 (0:00:00.447)       0:01:04.660 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.upload_helm_chart : Include help chart upload method tasks] ***",
                                "Saturday 28 February 2026  00:40:35 +0000 (0:00:01.732)       0:01:06.392 *****",
                                "included: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/upload_helm_chart/tasks/synchronize.yml for controller",
                                "",
                                "TASK [vexxhost.kubernetes.upload_helm_chart : Upload Helm chart] ***************",
                                "Saturday 28 February 2026  00:40:35 +0000 (0:00:00.093)       0:01:06.486 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.cilium : Get current Kubernetes version] *************",
                                "Saturday 28 February 2026  00:40:36 +0000 (0:00:00.724)       0:01:07.210 *****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.cilium : Deploy Helm chart] **************************",
                                "Saturday 28 February 2026  00:40:37 +0000 (0:00:01.059)       0:01:08.269 *****",
                                "ok: [controller]",
                                "",
                                "PLAY RECAP *********************************************************************",
                                "controller                 : ok=113  changed=0    unreachable=0    failed=0    skipped=30   rescued=0    ignored=1",
                                "",
                                "",
                                "TASKS RECAP ********************************************************************",
                                "Saturday 28 February 2026  00:40:39 +0000 (0:00:02.374)       0:01:10.644 *****",
                                "===============================================================================",
                                "Gathering Facts --------------------------------------------------------- 2.58s",
                                "vexxhost.containers.download_artifact : Extract archive ----------------- 2.46s",
                                "vexxhost.kubernetes.cilium : Deploy Helm chart -------------------------- 2.37s",
                                "vexxhost.containers.download_artifact : Extract archive ----------------- 2.30s",
                                "vexxhost.kubernetes.kubelet : Configure sysctl values ------------------- 2.18s",
                                "vexxhost.containers.download_artifact : Extract archive ----------------- 1.73s",
                                "vexxhost.containers.containerd : Create folders for configuration ------- 1.52s",
                                "vexxhost.containers.download_artifact : Extract archive ----------------- 1.49s",
                                "vexxhost.containers.containerd : Create folders for configuration ------- 1.46s",
                                "vexxhost.containers.download_artifact : Extract archive ----------------- 1.44s",
                                "vexxhost.kubernetes.kube_vip : Uninstall legacy HA stack ---------------- 1.43s",
                                "vexxhost.containers.download_artifact : Extract archive ----------------- 1.39s",
                                "vexxhost.containers.cni_plugins : Enable kernel modules in runtime ------ 1.26s",
                                "vexxhost.containers.package : Update state for tar ---------------------- 1.11s",
                                "vexxhost.containers.containerd : Install AppArmor packages -------------- 1.09s",
                                "vexxhost.kubernetes.cilium : Get current Kubernetes version ------------- 1.06s",
                                "vexxhost.containers.package : Update state for tar ---------------------- 1.04s",
                                "vexxhost.kubernetes.kubernetes : Set node selector for CoreDNS components --- 1.04s",
                                "vexxhost.containers.containerd : Install AppArmor packages -------------- 1.03s",
                                "Gathering Facts --------------------------------------------------------- 1.03s",
                                "INFO     [bgp > idempotence] Executed: Successful",
                                "INFO     [bgp > side_effect] Executing",
                                "WARNING  [bgp > side_effect] Executed: Missing playbook (Remove from test_sequence to suppress)",
                                "INFO     [bgp > verify] Executing",
                                "",
                                "PLAY [Verify] ******************************************************************",
                                "",
                                "TASK [Gathering Facts] *********************************************************",
                                "Saturday 28 February 2026  00:40:40 +0000 (0:00:00.009)       0:00:00.009 *****",
                                "[WARNING]: Host 'controller' is using the discovered Python interpreter at '/usr/bin/python3.13', but future installation of another Python interpreter could cause a different interpreter to be discovered. See https://docs.ansible.com/ansible-core/2.20/reference_appendices/interpreter_discovery.html for more information.",
                                "ok: [controller]",
                                "",
                                "TASK [Gather service facts] ****************************************************",
                                "Saturday 28 February 2026  00:40:42 +0000 (0:00:02.285)       0:00:02.295 *****",
                                "ok: [controller]",
                                "",
                                "TASK [Make sure kubelet service is running] ************************************",
                                "Saturday 28 February 2026  00:40:47 +0000 (0:00:04.455)       0:00:06.750 *****",
                                "ok: [controller] => {",
                                "    \"changed\": false,",
                                "    \"msg\": \"All assertions passed\"",
                                "}",
                                "",
                                "TASK [Make sure kubelet service is enabled] ************************************",
                                "Saturday 28 February 2026  00:40:47 +0000 (0:00:00.037)       0:00:06.787 *****",
                                "ok: [controller] => {",
                                "    \"changed\": false,",
                                "    \"msg\": \"All assertions passed\"",
                                "}",
                                "",
                                "TASK [Get all nodes] ***********************************************************",
                                "Saturday 28 February 2026  00:40:47 +0000 (0:00:00.039)       0:00:06.827 *****",
                                "changed: [controller]",
                                "",
                                "TASK [Print node list] *********************************************************",
                                "Saturday 28 February 2026  00:40:47 +0000 (0:00:00.541)       0:00:07.368 *****",
                                "ok: [controller] => {",
                                "    \"msg\": [",
                                "        \"NAME         STATUS   ROLES           AGE    VERSION\",",
                                "        \"controller   Ready    control-plane   111s   v1.34.0\"",
                                "    ]",
                                "}",
                                "",
                                "TASK [Assert no nody is not ready] *********************************************",
                                "Saturday 28 February 2026  00:40:47 +0000 (0:00:00.039)       0:00:07.408 *****",
                                "ok: [controller] => {",
                                "    \"changed\": false,",
                                "    \"msg\": \"All assertions passed\"",
                                "}",
                                "",
                                "PLAY [verify BGP] **************************************************************",
                                "",
                                "TASK [Gathering Facts] *********************************************************",
                                "Saturday 28 February 2026  00:40:48 +0000 (0:00:00.044)       0:00:07.452 *****",
                                "ok: [controller]",
                                "",
                                "TASK [Get all nodes] ***********************************************************",
                                "Saturday 28 February 2026  00:40:49 +0000 (0:00:01.009)       0:00:08.461 *****",
                                "changed: [controller]",
                                "",
                                "TASK [Print bgp neighbors received-routes] *************************************",
                                "Saturday 28 February 2026  00:40:49 +0000 (0:00:00.350)       0:00:08.812 *****",
                                "ok: [controller] => {",
                                "    \"msg\": [",
                                "        \"BGP table version is 0, local router ID is 199.204.45.6, vrf id 0\",",
                                "        \"Default local pref 100, local AS 65000\",",
                                "        \"Status codes:  s suppressed, d damped, h history, u unsorted, * valid, > best, = multipath,\",",
                                "        \"               i internal, r RIB-failure, S Stale, R Removed\",",
                                "        \"Nexthop codes: @NNN nexthop's vrf id, < announce-nh-self\",",
                                "        \"Origin codes:  i - IGP, e - EGP, ? - incomplete\",",
                                "        \"RPKI validation codes: V valid, I invalid, N Not found\",",
                                "        \"\",",
                                "        \"     Network          Next Hop            Metric LocPrf Weight Path\",",
                                "        \" *> 172.17.0.100/32  172.17.0.100                  100      0 i\",",
                                "        \"\",",
                                "        \"Total number of prefixes 1\"",
                                "    ]",
                                "}",
                                "",
                                "PLAY RECAP *********************************************************************",
                                "controller                 : ok=10   changed=2    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0",
                                "",
                                "",
                                "TASKS RECAP ********************************************************************",
                                "Saturday 28 February 2026  00:40:49 +0000 (0:00:00.030)       0:00:08.842 *****",
                                "===============================================================================",
                                "Gather service facts ---------------------------------------------------- 4.46s",
                                "Gathering Facts --------------------------------------------------------- 2.29s",
                                "Gathering Facts --------------------------------------------------------- 1.01s",
                                "Get all nodes ----------------------------------------------------------- 0.54s",
                                "Get all nodes ----------------------------------------------------------- 0.35s",
                                "Assert no nody is not ready --------------------------------------------- 0.04s",
                                "Make sure kubelet service is enabled ------------------------------------ 0.04s",
                                "Print node list --------------------------------------------------------- 0.04s",
                                "Make sure kubelet service is running ------------------------------------ 0.04s",
                                "Print bgp neighbors received-routes ------------------------------------- 0.03s",
                                "INFO     [bgp > verify] Executed: Successful",
                                "INFO     [bgp > cleanup] Executing",
                                "WARNING  [bgp > cleanup] Executed: Missing playbook (Remove from test_sequence to suppress)",
                                "INFO     [bgp > destroy] Executing",
                                "WARNING  [bgp > destroy] Skipping, '--destroy=never' requested.",
                                "INFO     [bgp > destroy] Executed: Successful",
                                "WARNING  Molecule executed 1 scenario (1 missing files)"
                            ],
                            "zuul_log_id": "0242ac17-0011-f77d-8d47-000000000006-1-controller"
                        }
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:40:49.975378Z",
                            "start": "2026-02-28T00:36:18.200475Z"
                        },
                        "id": "0242ac17-0011-f77d-8d47-000000000006",
                        "name": "Run Molecule scenario"
                    }
                }
            ]
        }
    ],
    "stats": {
        "controller": {
            "changed": 3,
            "failures": 0,
            "ignored": 0,
            "ok": 3,
            "rescued": 0,
            "skipped": 0,
            "unreachable": 0
        }
    },
    "trusted": false
},
{
    "branch": "main",
    "index": "0",
    "phase": "post",
    "playbook": "github.com/vexxhost/zuul-config/playbooks/base/post.yaml",
    "plays": [
        {
            "play": {
                "duration": {
                    "end": "2026-02-28T00:40:53.841860Z",
                    "start": "2026-02-28T00:40:50.647069Z"
                },
                "id": "0242ac17-0011-0132-3815-000000000002",
                "name": "all"
            },
            "tasks": [
                {
                    "hosts": {
                        "controller": {
                            "action": "set_fact",
                            "changed": false,
                            "false_condition": "groups['all'] | length > 1",
                            "skip_reason": "Conditional result was False",
                            "skipped": true
                        }
                    },
                    "role": {
                        "id": "0242ac17-0011-0132-3815-000000000006",
                        "name": "fetch-output",
                        "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/fetch-output"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:40:50.702426Z",
                            "start": "2026-02-28T00:40:50.656715Z"
                        },
                        "id": "0242ac17-0011-0132-3815-000000000008",
                        "name": "Set log path for multiple nodes"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "set_fact",
                            "ansible_facts": {
                                "log_path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/logs"
                            },
                            "changed": false
                        }
                    },
                    "role": {
                        "id": "0242ac17-0011-0132-3815-000000000006",
                        "name": "fetch-output",
                        "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/fetch-output"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:40:50.756058Z",
                            "start": "2026-02-28T00:40:50.711105Z"
                        },
                        "id": "0242ac17-0011-0132-3815-000000000009",
                        "name": "Set log path for single node"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "file",
                            "changed": true,
                            "msg": "All items completed",
                            "results": [
                                {
                                    "ansible_loop_var": "zj_output_dir",
                                    "changed": false,
                                    "diff": {
                                        "after": {
                                            "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/logs"
                                        },
                                        "before": {
                                            "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/logs"
                                        }
                                    },
                                    "failed": false,
                                    "gid": 0,
                                    "group": "root",
                                    "invocation": {
                                        "module_args": {
                                            "_diff_peek": null,
                                            "_original_basename": null,
                                            "access_time": null,
                                            "access_time_format": "%Y%m%d%H%M.%S",
                                            "attributes": null,
                                            "follow": true,
                                            "force": false,
                                            "group": null,
                                            "mode": 493,
                                            "modification_time": null,
                                            "modification_time_format": "%Y%m%d%H%M.%S",
                                            "owner": null,
                                            "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/logs",
                                            "recurse": false,
                                            "selevel": null,
                                            "serole": null,
                                            "setype": null,
                                            "seuser": null,
                                            "src": null,
                                            "state": "directory",
                                            "unsafe_writes": false
                                        }
                                    },
                                    "mode": "0755",
                                    "owner": "root",
                                    "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/logs",
                                    "size": 4096,
                                    "state": "directory",
                                    "uid": 0,
                                    "zj_output_dir": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/logs"
                                },
                                {
                                    "ansible_loop_var": "zj_output_dir",
                                    "changed": true,
                                    "diff": {
                                        "after": {
                                            "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/artifacts",
                                            "state": "directory"
                                        },
                                        "before": {
                                            "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/artifacts",
                                            "state": "absent"
                                        }
                                    },
                                    "failed": false,
                                    "gid": 0,
                                    "group": "root",
                                    "invocation": {
                                        "module_args": {
                                            "_diff_peek": null,
                                            "_original_basename": null,
                                            "access_time": null,
                                            "access_time_format": "%Y%m%d%H%M.%S",
                                            "attributes": null,
                                            "follow": true,
                                            "force": false,
                                            "group": null,
                                            "mode": 493,
                                            "modification_time": null,
                                            "modification_time_format": "%Y%m%d%H%M.%S",
                                            "owner": null,
                                            "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/artifacts",
                                            "recurse": false,
                                            "selevel": null,
                                            "serole": null,
                                            "setype": null,
                                            "seuser": null,
                                            "src": null,
                                            "state": "directory",
                                            "unsafe_writes": false
                                        }
                                    },
                                    "mode": "0755",
                                    "owner": "root",
                                    "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/artifacts",
                                    "size": 4096,
                                    "state": "directory",
                                    "uid": 0,
                                    "zj_output_dir": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/artifacts"
                                },
                                {
                                    "ansible_loop_var": "zj_output_dir",
                                    "changed": true,
                                    "diff": {
                                        "after": {
                                            "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/docs",
                                            "state": "directory"
                                        },
                                        "before": {
                                            "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/docs",
                                            "state": "absent"
                                        }
                                    },
                                    "failed": false,
                                    "gid": 0,
                                    "group": "root",
                                    "invocation": {
                                        "module_args": {
                                            "_diff_peek": null,
                                            "_original_basename": null,
                                            "access_time": null,
                                            "access_time_format": "%Y%m%d%H%M.%S",
                                            "attributes": null,
                                            "follow": true,
                                            "force": false,
                                            "group": null,
                                            "mode": 493,
                                            "modification_time": null,
                                            "modification_time_format": "%Y%m%d%H%M.%S",
                                            "owner": null,
                                            "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/docs",
                                            "recurse": false,
                                            "selevel": null,
                                            "serole": null,
                                            "setype": null,
                                            "seuser": null,
                                            "src": null,
                                            "state": "directory",
                                            "unsafe_writes": false
                                        }
                                    },
                                    "mode": "0755",
                                    "owner": "root",
                                    "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/docs",
                                    "size": 4096,
                                    "state": "directory",
                                    "uid": 0,
                                    "zj_output_dir": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/docs"
                                }
                            ]
                        }
                    },
                    "role": {
                        "id": "0242ac17-0011-0132-3815-000000000006",
                        "name": "fetch-output",
                        "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/fetch-output"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:40:51.627134Z",
                            "start": "2026-02-28T00:40:50.760096Z"
                        },
                        "id": "0242ac17-0011-0132-3815-00000000000a",
                        "name": "Ensure local output dirs"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "synchronize",
                            "changed": true,
                            "msg": "All items completed",
                            "results": [
                                {
                                    "ansible_loop_var": "zj_output",
                                    "changed": false,
                                    "cmd": "/usr/bin/rsync --delay-updates -F --compress --archive --no-owner --no-group --rsh='/usr/bin/ssh -S none -o Port=22' --out-format='<<CHANGED>>%i %n%L' zuul@199.204.45.6:/home/zuul/zuul-output/logs/ /var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/logs/",
                                    "failed": false,
                                    "invocation": {
                                        "module_args": {
                                            "_local_rsync_password": null,
                                            "_local_rsync_path": "rsync",
                                            "_ssh_args": null,
                                            "_substitute_controller": false,
                                            "archive": true,
                                            "checksum": false,
                                            "compress": true,
                                            "copy_links": false,
                                            "delay_updates": true,
                                            "delete": false,
                                            "dest": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/logs/",
                                            "dest_port": 22,
                                            "dirs": false,
                                            "existing_only": false,
                                            "group": false,
                                            "link_dest": null,
                                            "links": null,
                                            "mode": "pull",
                                            "owner": false,
                                            "partial": false,
                                            "perms": null,
                                            "private_key": null,
                                            "recursive": null,
                                            "rsync_opts": [],
                                            "rsync_path": null,
                                            "rsync_timeout": 0,
                                            "set_remote_user": true,
                                            "src": "zuul@199.204.45.6:/home/zuul/zuul-output/logs/",
                                            "ssh_connection_multiplexing": false,
                                            "times": null,
                                            "use_ssh_args": false,
                                            "verify_host": true
                                        }
                                    },
                                    "msg": "",
                                    "rc": 0,
                                    "stdout_lines": [],
                                    "zj_output": {
                                        "dest": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/logs",
                                        "src": "logs"
                                    }
                                },
                                {
                                    "ansible_loop_var": "zj_output",
                                    "changed": true,
                                    "cmd": "/usr/bin/rsync --delay-updates -F --compress --archive --no-owner --no-group --rsh='/usr/bin/ssh -S none -o Port=22' --out-format='<<CHANGED>>%i %n%L' zuul@199.204.45.6:/home/zuul/zuul-output/artifacts/ /var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/artifacts/",
                                    "failed": false,
                                    "invocation": {
                                        "module_args": {
                                            "_local_rsync_password": null,
                                            "_local_rsync_path": "rsync",
                                            "_ssh_args": null,
                                            "_substitute_controller": false,
                                            "archive": true,
                                            "checksum": false,
                                            "compress": true,
                                            "copy_links": false,
                                            "delay_updates": true,
                                            "delete": false,
                                            "dest": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/artifacts/",
                                            "dest_port": 22,
                                            "dirs": false,
                                            "existing_only": false,
                                            "group": false,
                                            "link_dest": null,
                                            "links": null,
                                            "mode": "pull",
                                            "owner": false,
                                            "partial": false,
                                            "perms": null,
                                            "private_key": null,
                                            "recursive": null,
                                            "rsync_opts": [],
                                            "rsync_path": null,
                                            "rsync_timeout": 0,
                                            "set_remote_user": true,
                                            "src": "zuul@199.204.45.6:/home/zuul/zuul-output/artifacts/",
                                            "ssh_connection_multiplexing": false,
                                            "times": null,
                                            "use_ssh_args": false,
                                            "verify_host": true
                                        }
                                    },
                                    "msg": ".d..t...... ./\n",
                                    "rc": 0,
                                    "stdout_lines": [
                                        ".d..t...... ./"
                                    ],
                                    "zj_output": {
                                        "dest": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/artifacts",
                                        "src": "artifacts"
                                    }
                                },
                                {
                                    "ansible_loop_var": "zj_output",
                                    "changed": true,
                                    "cmd": "/usr/bin/rsync --delay-updates -F --compress --archive --no-owner --no-group --rsh='/usr/bin/ssh -S none -o Port=22' --out-format='<<CHANGED>>%i %n%L' zuul@199.204.45.6:/home/zuul/zuul-output/docs/ /var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/docs/",
                                    "failed": false,
                                    "invocation": {
                                        "module_args": {
                                            "_local_rsync_password": null,
                                            "_local_rsync_path": "rsync",
                                            "_ssh_args": null,
                                            "_substitute_controller": false,
                                            "archive": true,
                                            "checksum": false,
                                            "compress": true,
                                            "copy_links": false,
                                            "delay_updates": true,
                                            "delete": false,
                                            "dest": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/docs/",
                                            "dest_port": 22,
                                            "dirs": false,
                                            "existing_only": false,
                                            "group": false,
                                            "link_dest": null,
                                            "links": null,
                                            "mode": "pull",
                                            "owner": false,
                                            "partial": false,
                                            "perms": null,
                                            "private_key": null,
                                            "recursive": null,
                                            "rsync_opts": [],
                                            "rsync_path": null,
                                            "rsync_timeout": 0,
                                            "set_remote_user": true,
                                            "src": "zuul@199.204.45.6:/home/zuul/zuul-output/docs/",
                                            "ssh_connection_multiplexing": false,
                                            "times": null,
                                            "use_ssh_args": false,
                                            "verify_host": true
                                        }
                                    },
                                    "msg": ".d..t...... ./\n",
                                    "rc": 0,
                                    "stdout_lines": [
                                        ".d..t...... ./"
                                    ],
                                    "zj_output": {
                                        "dest": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/docs",
                                        "src": "docs"
                                    }
                                }
                            ]
                        }
                    },
                    "role": {
                        "id": "0242ac17-0011-0132-3815-000000000006",
                        "name": "fetch-output",
                        "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/fetch-output"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:40:53.211293Z",
                            "start": "2026-02-28T00:40:51.632065Z"
                        },
                        "id": "0242ac17-0011-0132-3815-00000000000c",
                        "name": "Collect logs, artifacts and docs"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "shell",
                            "changed": true,
                            "msg": "All items completed",
                            "results": [
                                {
                                    "ansible_loop_var": "zj_item",
                                    "changed": true,
                                    "cmd": "if [ -n \"$(find /var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/artifacts -mindepth 1)\" ] ; then\n  # Only create target directory if it is needed.\n  # Do not fail if it is already there.\n  mkdir -p /var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/logs/artifacts\n  # Leave the original directory behind so that other roles\n  # operating on the interface directories can simply no-op.\n  mv -f /var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/artifacts/* /var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/logs/artifacts\nfi\n",
                                    "delta": "0:00:00.008096",
                                    "end": "2026-02-28 00:40:53.579105",
                                    "failed": false,
                                    "invocation": {
                                        "module_args": {
                                            "_raw_params": "if [ -n \"$(find /var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/artifacts -mindepth 1)\" ] ; then\n  # Only create target directory if it is needed.\n  # Do not fail if it is already there.\n  mkdir -p /var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/logs/artifacts\n  # Leave the original directory behind so that other roles\n  # operating on the interface directories can simply no-op.\n  mv -f /var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/artifacts/* /var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/logs/artifacts\nfi\n",
                                            "_uses_shell": true,
                                            "argv": null,
                                            "chdir": null,
                                            "creates": null,
                                            "executable": null,
                                            "expand_argument_vars": true,
                                            "removes": null,
                                            "stdin": null,
                                            "stdin_add_newline": true,
                                            "strip_empty_ends": true,
                                            "zuul_ansible_split_streams": false,
                                            "zuul_log_id": "in-loop-ignore",
                                            "zuul_no_log": false,
                                            "zuul_output_max_bytes": 1073741824
                                        }
                                    },
                                    "msg": "",
                                    "rc": 0,
                                    "start": "2026-02-28 00:40:53.571009",
                                    "stderr": "",
                                    "stderr_lines": [],
                                    "stdout": "",
                                    "stdout_lines": [],
                                    "zj_item": "artifacts",
                                    "zuul_log_id": "in-loop-ignore"
                                },
                                {
                                    "ansible_loop_var": "zj_item",
                                    "changed": true,
                                    "cmd": "if [ -n \"$(find /var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/docs -mindepth 1)\" ] ; then\n  # Only create target directory if it is needed.\n  # Do not fail if it is already there.\n  mkdir -p /var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/logs/docs\n  # Leave the original directory behind so that other roles\n  # operating on the interface directories can simply no-op.\n  mv -f /var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/docs/* /var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/logs/docs\nfi\n",
                                    "delta": "0:00:00.006121",
                                    "end": "2026-02-28 00:40:53.803627",
                                    "failed": false,
                                    "invocation": {
                                        "module_args": {
                                            "_raw_params": "if [ -n \"$(find /var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/docs -mindepth 1)\" ] ; then\n  # Only create target directory if it is needed.\n  # Do not fail if it is already there.\n  mkdir -p /var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/logs/docs\n  # Leave the original directory behind so that other roles\n  # operating on the interface directories can simply no-op.\n  mv -f /var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/docs/* /var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/work/logs/docs\nfi\n",
                                            "_uses_shell": true,
                                            "argv": null,
                                            "chdir": null,
                                            "creates": null,
                                            "executable": null,
                                            "expand_argument_vars": true,
                                            "removes": null,
                                            "stdin": null,
                                            "stdin_add_newline": true,
                                            "strip_empty_ends": true,
                                            "zuul_ansible_split_streams": false,
                                            "zuul_log_id": "in-loop-ignore",
                                            "zuul_no_log": false,
                                            "zuul_output_max_bytes": 1073741824
                                        }
                                    },
                                    "msg": "",
                                    "rc": 0,
                                    "start": "2026-02-28 00:40:53.797506",
                                    "stderr": "",
                                    "stderr_lines": [],
                                    "stdout": "",
                                    "stdout_lines": [],
                                    "zj_item": "docs",
                                    "zuul_log_id": "in-loop-ignore"
                                }
                            ]
                        }
                    },
                    "role": {
                        "id": "0242ac17-0011-0132-3815-00000000000f",
                        "name": "merge-output-to-logs",
                        "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/merge-output-to-logs"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:40:53.841860Z",
                            "start": "2026-02-28T00:40:53.222797Z"
                        },
                        "id": "0242ac17-0011-0132-3815-000000000011",
                        "name": "Move artifacts and docs to logs dir"
                    }
                }
            ]
        },
        {
            "play": {
                "duration": {
                    "end": "2026-02-28T00:40:54.319170Z",
                    "start": "2026-02-28T00:40:53.851378Z"
                },
                "id": "0242ac17-0011-0132-3815-000000000013",
                "name": "all"
            },
            "tasks": [
                {
                    "hosts": {
                        "controller": {
                            "action": "authorized_key",
                            "changed": true,
                            "comment": null,
                            "exclusive": false,
                            "follow": false,
                            "invocation": {
                                "module_args": {
                                    "changed": true,
                                    "comment": null,
                                    "exclusive": false,
                                    "follow": false,
                                    "key": "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQDc70ckMn+rUuodN5onMkRTQ9w1SmBB1vMuNh4LDfwyXmb3hzRWN5qXAwJ9TSEmTZKtDrxW4u6hAVwIyAGqCV+yAD7GsPcxMry0HWa7ZM3/TVlc9BaSd3PvJhkeqNY1Rq5Jo+4OQrBH0c92JVR8GdN4/ll9VgNascr4LNyQ/xssxBJouH/sWJi7fAt3Ob2UQ4NubEoJLcFRpPg7MR4/sMl3EQrFfmEUawWpvYx5DptyQKIYYuDLn3OxyLccvPgxH5/Mnca5QNDWfJh/54RfYx6yu4fM6c9ujiPxfevK4J2x12XjcFkHy3FublE11kHhuQc1RzoEkaXkPUD8pOaSaOxR3oEZUDucDHAdCXbB2x1GVBp7CVCGRK2Rd6QpkZg29Hs3UaON/hXg8fpaCBTHqUYZltyxgPtcGchY3ch/dQU0eSlkU51VBwsYTK3EPMZ+Ez36WVOHbBNUbM7s+KlRb6S/ddiwrVLLX6jejkRgLSKTLXPmtncdB9yzbnc3hfKMMqk= zuul-build-sshkey",
                                    "key_options": null,
                                    "keyfile": "/home/zuul/.ssh/authorized_keys",
                                    "manage_dir": true,
                                    "path": null,
                                    "state": "absent",
                                    "user": "zuul",
                                    "validate_certs": true
                                }
                            },
                            "key": "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQDc70ckMn+rUuodN5onMkRTQ9w1SmBB1vMuNh4LDfwyXmb3hzRWN5qXAwJ9TSEmTZKtDrxW4u6hAVwIyAGqCV+yAD7GsPcxMry0HWa7ZM3/TVlc9BaSd3PvJhkeqNY1Rq5Jo+4OQrBH0c92JVR8GdN4/ll9VgNascr4LNyQ/xssxBJouH/sWJi7fAt3Ob2UQ4NubEoJLcFRpPg7MR4/sMl3EQrFfmEUawWpvYx5DptyQKIYYuDLn3OxyLccvPgxH5/Mnca5QNDWfJh/54RfYx6yu4fM6c9ujiPxfevK4J2x12XjcFkHy3FublE11kHhuQc1RzoEkaXkPUD8pOaSaOxR3oEZUDucDHAdCXbB2x1GVBp7CVCGRK2Rd6QpkZg29Hs3UaON/hXg8fpaCBTHqUYZltyxgPtcGchY3ch/dQU0eSlkU51VBwsYTK3EPMZ+Ez36WVOHbBNUbM7s+KlRb6S/ddiwrVLLX6jejkRgLSKTLXPmtncdB9yzbnc3hfKMMqk= zuul-build-sshkey",
                            "key_options": null,
                            "keyfile": "/home/zuul/.ssh/authorized_keys",
                            "manage_dir": true,
                            "path": null,
                            "state": "absent",
                            "user": "zuul",
                            "validate_certs": true
                        }
                    },
                    "role": {
                        "id": "0242ac17-0011-0132-3815-000000000016",
                        "name": "remove-build-sshkey",
                        "path": "/var/lib/zuul/builds/0588ed56b78644ddbc4c81220eec417a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/remove-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-28T00:40:54.319170Z",
                            "start": "2026-02-28T00:40:53.858055Z"
                        },
                        "id": "0242ac17-0011-0132-3815-000000000018",
                        "name": "Remove the build SSH key from all nodes"
                    }
                }
            ]
        }
    ],
    "stats": {
        "controller": {
            "changed": 4,
            "failures": 0,
            "ignored": 0,
            "ok": 5,
            "rescued": 0,
            "skipped": 1,
            "unreachable": 0
        }
    },
    "trusted": true
}
]
