[
{
    "branch": "main",
    "index": "0",
    "phase": "pre",
    "playbook": "vexxhost.dev/zuul-config/playbooks/base/pre.yaml",
    "plays": [
        {
            "play": {
                "duration": {
                    "end": "2026-02-11T00:44:59.318069Z",
                    "start": "2026-02-11T00:44:56.980714Z"
                },
                "id": "0242ac17-0010-f595-e566-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-11",
                                    "day": "11",
                                    "epoch": "1770770697",
                                    "epoch_int": "1770770697",
                                    "hour": "00",
                                    "iso8601": "2026-02-11T00:44:57Z",
                                    "iso8601_basic": "20260211T004457556881",
                                    "iso8601_basic_short": "20260211T004457",
                                    "iso8601_micro": "2026-02-11T00:44:57.556881Z",
                                    "minute": "44",
                                    "month": "02",
                                    "second": "57",
                                    "time": "00:44:57",
                                    "tz": "UTC",
                                    "tz_dst": "UTC",
                                    "tz_offset": "+0000",
                                    "weekday": "Wednesday",
                                    "weekday_number": "3",
                                    "weeknumber": "06",
                                    "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/855dd72a3bc24d528160da6987ba743a/ansible/pre_playbook_0/ansible.cfg",
                                    "DEBIAN_FRONTEND": "noninteractive",
                                    "GPG_KEY": "A035C8C19219BA821ECEA86B64E628F8D684696D",
                                    "HOME": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/work",
                                    "HOSTNAME": "3a2793d2bd32",
                                    "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/855dd72a3bc24d528160da6987ba743a/trusted/project_0/vexxhost.dev/zuul-config/playbooks/base",
                                    "PYTHONPATH": "/var/lib/zuul/ansible/9",
                                    "PYTHON_SHA256": "8fb5f9fbc7609fa822cb31549884575db7fd9657cbffb89510b5d7975963a83a",
                                    "PYTHON_VERSION": "3.11.13",
                                    "SSH_AGENT_PID": "3270614",
                                    "SSH_AUTH_SOCK": "/tmp/ssh-hQrNCt3v3XLu/agent.3270612",
                                    "TMP": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/work/tmp",
                                    "ZUUL_ANSIBLE_SPLIT_STREAMS": "False",
                                    "ZUUL_JOBDIR": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a",
                                    "ZUUL_JOB_FAILURE_OUTPUT": "[]",
                                    "ZUUL_JOB_LOG_CONFIG": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/ansible/logging.json",
                                    "ZUUL_OUTPUT_MAX_BYTES": "1073741824"
                                },
                                "ansible_fibre_channel_wwn": [],
                                "ansible_fips": false,
                                "ansible_form_factor": "NA",
                                "ansible_fqdn": "3a2793d2bd32",
                                "ansible_hostname": "3a2793d2bd32",
                                "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": 0.90966796875,
                                    "1m": 2.4990234375,
                                    "5m": 1.22021484375
                                },
                                "ansible_local": {},
                                "ansible_lsb": {},
                                "ansible_lvm": "N/A",
                                "ansible_machine": "x86_64",
                                "ansible_memfree_mb": 885,
                                "ansible_memory_mb": {
                                    "nocache": {
                                        "free": 20354,
                                        "used": 11736
                                    },
                                    "real": {
                                        "free": 885,
                                        "total": 32090,
                                        "used": 31205
                                    },
                                    "swap": {
                                        "cached": 0,
                                        "free": 0,
                                        "total": 0,
                                        "used": 0
                                    }
                                },
                                "ansible_memtotal_mb": 32090,
                                "ansible_mounts": [
                                    {
                                        "block_available": 10039948,
                                        "block_size": 4096,
                                        "block_total": 40601580,
                                        "block_used": 30561632,
                                        "device": "/dev/vda1",
                                        "fstype": "ext4",
                                        "inode_available": 16937443,
                                        "inode_total": 20643840,
                                        "inode_used": 3706397,
                                        "mount": "/etc/resolv.conf",
                                        "options": "ro,nosuid,nodev,relatime,discard,errors=remount-ro,bind",
                                        "size_available": 41123627008,
                                        "size_total": 166304071680,
                                        "uuid": "N/A"
                                    },
                                    {
                                        "block_available": 10039948,
                                        "block_size": 4096,
                                        "block_total": 40601580,
                                        "block_used": 30561632,
                                        "device": "/dev/vda1",
                                        "fstype": "ext4",
                                        "inode_available": 16937443,
                                        "inode_total": 20643840,
                                        "inode_used": 3706397,
                                        "mount": "/etc/hosts",
                                        "options": "ro,nosuid,nodev,relatime,discard,errors=remount-ro,bind",
                                        "size_available": 41123627008,
                                        "size_total": 166304071680,
                                        "uuid": "N/A"
                                    },
                                    {
                                        "block_available": 10039948,
                                        "block_size": 4096,
                                        "block_total": 40601580,
                                        "block_used": 30561632,
                                        "device": "/dev/vda1",
                                        "fstype": "ext4",
                                        "inode_available": 16937443,
                                        "inode_total": 20643840,
                                        "inode_used": 3706397,
                                        "mount": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/work",
                                        "options": "rw,nosuid,nodev,relatime,discard,errors=remount-ro,bind",
                                        "size_available": 41123627008,
                                        "size_total": 166304071680,
                                        "uuid": "N/A"
                                    },
                                    {
                                        "block_available": 10039948,
                                        "block_size": 4096,
                                        "block_total": 40601580,
                                        "block_used": 30561632,
                                        "device": "/dev/vda1",
                                        "fstype": "ext4",
                                        "inode_available": 16937443,
                                        "inode_total": 20643840,
                                        "inode_used": 3706397,
                                        "mount": "/var/lib/zuul/ansible/9",
                                        "options": "ro,nosuid,nodev,relatime,discard,errors=remount-ro,bind",
                                        "size_available": 41123627008,
                                        "size_total": 166304071680,
                                        "uuid": "N/A"
                                    },
                                    {
                                        "block_available": 10039948,
                                        "block_size": 4096,
                                        "block_total": 40601580,
                                        "block_used": 30561632,
                                        "device": "/dev/vda1",
                                        "fstype": "ext4",
                                        "inode_available": 16937443,
                                        "inode_total": 20643840,
                                        "inode_used": 3706397,
                                        "mount": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/ansible",
                                        "options": "ro,nosuid,nodev,relatime,discard,errors=remount-ro,bind",
                                        "size_available": 41123627008,
                                        "size_total": 166304071680,
                                        "uuid": "N/A"
                                    },
                                    {
                                        "block_available": 10039948,
                                        "block_size": 4096,
                                        "block_total": 40601580,
                                        "block_used": 30561632,
                                        "device": "/dev/vda1",
                                        "fstype": "ext4",
                                        "inode_available": 16937443,
                                        "inode_total": 20643840,
                                        "inode_used": 3706397,
                                        "mount": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/trusted",
                                        "options": "ro,nosuid,nodev,relatime,discard,errors=remount-ro,bind",
                                        "size_available": 41123627008,
                                        "size_total": 166304071680,
                                        "uuid": "N/A"
                                    },
                                    {
                                        "block_available": 10039948,
                                        "block_size": 4096,
                                        "block_total": 40601580,
                                        "block_used": 30561632,
                                        "device": "/dev/vda1",
                                        "fstype": "ext4",
                                        "inode_available": 16937443,
                                        "inode_total": 20643840,
                                        "inode_used": 3706397,
                                        "mount": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/untrusted",
                                        "options": "ro,nosuid,nodev,relatime,discard,errors=remount-ro,bind",
                                        "size_available": 41123627008,
                                        "size_total": 166304071680,
                                        "uuid": "N/A"
                                    },
                                    {
                                        "block_available": 10039948,
                                        "block_size": 4096,
                                        "block_total": 40601580,
                                        "block_used": 30561632,
                                        "device": "/dev/vda1",
                                        "fstype": "ext4",
                                        "inode_available": 16937443,
                                        "inode_total": 20643840,
                                        "inode_used": 3706397,
                                        "mount": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/ansible/pre_playbook_0",
                                        "options": "ro,nosuid,nodev,relatime,discard,errors=remount-ro,bind",
                                        "size_available": 41123627008,
                                        "size_total": 166304071680,
                                        "uuid": "N/A"
                                    },
                                    {
                                        "block_available": 10039948,
                                        "block_size": 4096,
                                        "block_total": 40601580,
                                        "block_used": 30561632,
                                        "device": "/dev/vda1",
                                        "fstype": "ext4",
                                        "inode_available": 16937443,
                                        "inode_total": 20643840,
                                        "inode_used": 3706397,
                                        "mount": "/etc/zuul/site-variables.yaml",
                                        "options": "ro,nosuid,nodev,relatime,discard,errors=remount-ro,bind",
                                        "size_available": 41123627008,
                                        "size_total": 166304071680,
                                        "uuid": "N/A"
                                    },
                                    {
                                        "block_available": 54406915,
                                        "block_size": 4096,
                                        "block_total": 263940717,
                                        "block_used": 209533802,
                                        "device": "/dev/vdb",
                                        "fstype": "ext4",
                                        "inode_available": 18380957,
                                        "inode_total": 67108864,
                                        "inode_used": 48727907,
                                        "mount": "/srv/static/logs",
                                        "options": "rw,nosuid,nodev,relatime,discard",
                                        "size_available": 222850723840,
                                        "size_total": 1081101176832,
                                        "uuid": "N/A"
                                    },
                                    {
                                        "block_available": 10039948,
                                        "block_size": 4096,
                                        "block_total": 40601580,
                                        "block_used": 30561632,
                                        "device": "/dev/vda1",
                                        "fstype": "ext4",
                                        "inode_available": 16937443,
                                        "inode_total": 20643840,
                                        "inode_used": 3706397,
                                        "mount": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/.ansible",
                                        "options": "rw,nosuid,nodev,relatime,discard,errors=remount-ro,bind",
                                        "size_available": 41123627008,
                                        "size_total": 166304071680,
                                        "uuid": "N/A"
                                    }
                                ],
                                "ansible_nodename": "3a2793d2bd32",
                                "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": 13,
                                        "minor": 11,
                                        "releaselevel": "final",
                                        "serial": 0
                                    },
                                    "version_info": [
                                        3,
                                        11,
                                        13,
                                        "final",
                                        0
                                    ]
                                },
                                "ansible_python_version": "3.11.13",
                                "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": 34434427,
                                "ansible_user_dir": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/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-11T00:44:57.853514Z",
                            "start": "2026-02-11T00:44:56.989444Z"
                        },
                        "id": "0242ac17-0010-f595-e566-00000000002a",
                        "name": "Gathering Facts"
                    }
                },
                {
                    "hosts": {
                        "localhost": {
                            "action": "include_role",
                            "changed": false,
                            "include_args": {
                                "name": "set-zuul-log-path-fact"
                            }
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-f595-e566-000000000006",
                        "name": "emit-job-header",
                        "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/emit-job-header"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-11T00:44:57.884191Z",
                            "start": "2026-02-11T00:44:57.859349Z"
                        },
                        "id": "0242ac17-0010-f595-e566-000000000008",
                        "name": "Setup log path fact"
                    }
                },
                {
                    "hosts": {
                        "localhost": {
                            "action": "set_fact",
                            "ansible_facts": {
                                "zuul_log_path": "855/oss/855dd72a3bc24d528160da6987ba743a"
                            },
                            "changed": false
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-f595-e566-000000000054",
                        "name": "set-zuul-log-path-fact",
                        "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/set-zuul-log-path-fact"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-11T00:44:57.923363Z",
                            "start": "2026-02-11T00:44:57.895875Z"
                        },
                        "id": "0242ac17-0010-f595-e566-000000000056",
                        "name": "Set log path for a build"
                    }
                },
                {
                    "hosts": {
                        "localhost": {
                            "action": "debug",
                            "changed": false,
                            "msg": "# Job Information\nAnsible Version: 2.16.15\nJob: ansible-collection-kubernetes-molecule-bgp\nPipeline: check\nExecutor: 3a2793d2bd32\nTriggered by: https://github.com/vexxhost/ansible-collection-kubernetes/pull/230\nEvent ID: c1003d70-06e2-11f1-9860-b25bf9d18ce0\n"
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-f595-e566-000000000006",
                        "name": "emit-job-header",
                        "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/emit-job-header"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-11T00:44:57.969301Z",
                            "start": "2026-02-11T00:44:57.929877Z"
                        },
                        "id": "0242ac17-0010-f595-e566-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: np0000155225\nUsername: zuul\nDistro: Debian 13.3\nProvider: yul1\nRegion: ca-ymq-1\nLabel: debian-trixie\nProduct Name: OpenStack Nova\nInterface IP: 162.253.55.200\n",
                                    "zj_item": "controller"
                                }
                            ]
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-f595-e566-000000000006",
                        "name": "emit-job-header",
                        "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/emit-job-header"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-11T00:44:58.070383Z",
                            "start": "2026-02-11T00:44:57.971911Z"
                        },
                        "id": "0242ac17-0010-f595-e566-00000000000a",
                        "name": "Print node information"
                    }
                },
                {
                    "hosts": {
                        "localhost": {
                            "action": "file",
                            "changed": true,
                            "diff": {
                                "after": {
                                    "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/work/logs/zuul-info",
                                    "state": "directory"
                                },
                                "before": {
                                    "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/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/855dd72a3bc24d528160da6987ba743a/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/855dd72a3bc24d528160da6987ba743a/work/logs/zuul-info",
                            "size": 4096,
                            "state": "directory",
                            "uid": 0
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-f595-e566-00000000000d",
                        "name": "log-inventory",
                        "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/log-inventory"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-11T00:44:58.471164Z",
                            "start": "2026-02-11T00:44:58.079793Z"
                        },
                        "id": "0242ac17-0010-f595-e566-00000000000f",
                        "name": "Ensure Zuul Ansible directory exists"
                    }
                },
                {
                    "hosts": {
                        "localhost": {
                            "action": "copy",
                            "changed": true,
                            "checksum": "141be9e3839579963c99200a79799a077dbf309d",
                            "dest": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/work/logs/zuul-info/inventory.yaml",
                            "diff": [],
                            "gid": 0,
                            "group": "root",
                            "invocation": {
                                "module_args": {
                                    "_original_basename": "inventory.yaml",
                                    "attributes": null,
                                    "backup": false,
                                    "checksum": "141be9e3839579963c99200a79799a077dbf309d",
                                    "content": null,
                                    "dest": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/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/855dd72a3bc24d528160da6987ba743a/work/.ansible/tmp/ansible-tmp-1770770698.5047119-84-106738068628882/source",
                                    "unsafe_writes": false,
                                    "validate": null
                                }
                            },
                            "md5sum": "ff5b1aada78688b497658be891fdfea8",
                            "mode": "0644",
                            "owner": "root",
                            "size": 9649,
                            "src": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/work/.ansible/tmp/ansible-tmp-1770770698.5047119-84-106738068628882/source",
                            "state": "file",
                            "uid": 0
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-f595-e566-00000000000d",
                        "name": "log-inventory",
                        "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/log-inventory"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-11T00:44:59.318069Z",
                            "start": "2026-02-11T00:44:58.477708Z"
                        },
                        "id": "0242ac17-0010-f595-e566-000000000010",
                        "name": "Copy ansible inventory to logs dir"
                    }
                }
            ]
        },
        {
            "play": {
                "duration": {
                    "end": "2026-02-11T00:45:06.473011Z",
                    "start": "2026-02-11T00:44:59.333137Z"
                },
                "id": "0242ac17-0010-f595-e566-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/855dd72a3bc24d528160da6987ba743a/work/855dd72a3bc24d528160da6987ba743a_id_rsa"
                                }
                            },
                            "stat": {
                                "exists": false
                            }
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-f595-e566-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-11T00:44:59.573051Z",
                            "start": "2026-02-11T00:44:59.344192Z"
                        },
                        "id": "0242ac17-0010-f595-e566-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-0010-f595-e566-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-11T00:44:59.613860Z",
                            "start": "2026-02-11T00:44:59.581935Z"
                        },
                        "id": "0242ac17-0010-f595-e566-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/855dd72a3bc24d528160da6987ba743a/work/855dd72a3bc24d528160da6987ba743a_id_rsa",
                                "-b",
                                "3072"
                            ],
                            "delta": "0:00:00.781479",
                            "end": "2026-02-11 00:45:00.788930",
                            "invocation": {
                                "module_args": {
                                    "_raw_params": "ssh-keygen -t rsa -N '' -C 'zuul-build-sshkey' -f /var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/work/855dd72a3bc24d528160da6987ba743a_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-0010-f595-e566-00000000009c-0-controller",
                                    "zuul_no_log": false,
                                    "zuul_output_max_bytes": 1073741824
                                }
                            },
                            "msg": "",
                            "rc": 0,
                            "start": "2026-02-11 00:45:00.007451",
                            "stderr": "",
                            "stderr_lines": [],
                            "stdout": "Generating public/private rsa key pair.\nYour identification has been saved in /var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/work/855dd72a3bc24d528160da6987ba743a_id_rsa\nYour public key has been saved in /var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/work/855dd72a3bc24d528160da6987ba743a_id_rsa.pub\nThe key fingerprint is:\nSHA256:ghvWo0elx4qk2L7gY5GIE5EPdFsKxDb12xpzRMW/WE4 zuul-build-sshkey\nThe key's randomart image is:\n+---[RSA 3072]----+\n|+=.o . .o.       |\n|++o = .  .       |\n|.+.o . .. .      |\n|. .  o++   E     |\n|o.. =+*oS = .    |\n|+= + *== . o     |\n|o.+ +.o          |\n|.=   .           |\n|..+.             |\n+----[SHA256]-----+",
                            "stdout_lines": [
                                "Generating public/private rsa key pair.",
                                "Your identification has been saved in /var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/work/855dd72a3bc24d528160da6987ba743a_id_rsa",
                                "Your public key has been saved in /var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/work/855dd72a3bc24d528160da6987ba743a_id_rsa.pub",
                                "The key fingerprint is:",
                                "SHA256:ghvWo0elx4qk2L7gY5GIE5EPdFsKxDb12xpzRMW/WE4 zuul-build-sshkey",
                                "The key's randomart image is:",
                                "+---[RSA 3072]----+",
                                "|+=.o . .o.       |",
                                "|++o = .  .       |",
                                "|.+.o . .. .      |",
                                "|. .  o++   E     |",
                                "|o.. =+*oS = .    |",
                                "|+= + *== . o     |",
                                "|o.+ +.o          |",
                                "|.=   .           |",
                                "|..+.             |",
                                "+----[SHA256]-----+"
                            ],
                            "zuul_log_id": "0242ac17-0010-f595-e566-00000000009c-0-controller"
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-f595-e566-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-11T00:45:00.835543Z",
                            "start": "2026-02-11T00:44:59.641716Z"
                        },
                        "id": "0242ac17-0010-f595-e566-00000000009c",
                        "name": "Create Temp SSH key"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "include_tasks",
                            "changed": false,
                            "include": "remote-linux.yaml",
                            "include_args": {}
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-f595-e566-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-11T00:45:00.871826Z",
                            "start": "2026-02-11T00:45:00.839398Z"
                        },
                        "id": "0242ac17-0010-f595-e566-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-0010-f595-e566-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-11T00:45:00.913774Z",
                            "start": "2026-02-11T00:45:00.887835Z"
                        },
                        "id": "0242ac17-0010-f595-e566-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 AAAAB3NzaC1yc2EAAAADAQABAAABgQCuio10Cog7ImT1kgW47reHKrvjvhgx6Q+lHrCywbHCCu1y7LUxsSNBkrxOwlKiV71FN9F0XTRPLuSmbCD8UlNtgpHX/cOFHsoK+jAePaPzPK/L3Pf/sdR9qUMgShSROINLYR5R6VP3Q8u+jxV4GazYG5aWpS9T3Eh4Ly3aNglPyoHdfjhkv9zB7wMNYNGfAQIoEOkmKSnvwhO1YgUmkTD4KDcBWT3LfYR2YDdzyOxCaMO20JK/SzBLizbTKhnhrzviGJ1fg5vT74GzAHQiuC4+e/iXZQdt9bswKJ8fuod+7e8JwFSff+GXcHkFLlM6xTDsBm+X9GZglTmuaMn/YJ7ofCb5sxANYWFSZTX674hEs4nEAS69mQTQT/DkX7Vm54btN4Xw+QX9jzxnT9Tts7V0hYaKpFkRvXzHry+1LZZ4mKSEj4KkUXfxSMbbBUmj/ihgcdhaj2B+Yr2JcUJOBksla1Cnb7Oha37jTaoB7ubw8zmN9Nk3rOkhOpgelfnxQv0= 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 AAAAB3NzaC1yc2EAAAADAQABAAABgQCuio10Cog7ImT1kgW47reHKrvjvhgx6Q+lHrCywbHCCu1y7LUxsSNBkrxOwlKiV71FN9F0XTRPLuSmbCD8UlNtgpHX/cOFHsoK+jAePaPzPK/L3Pf/sdR9qUMgShSROINLYR5R6VP3Q8u+jxV4GazYG5aWpS9T3Eh4Ly3aNglPyoHdfjhkv9zB7wMNYNGfAQIoEOkmKSnvwhO1YgUmkTD4KDcBWT3LfYR2YDdzyOxCaMO20JK/SzBLizbTKhnhrzviGJ1fg5vT74GzAHQiuC4+e/iXZQdt9bswKJ8fuod+7e8JwFSff+GXcHkFLlM6xTDsBm+X9GZglTmuaMn/YJ7ofCb5sxANYWFSZTX674hEs4nEAS69mQTQT/DkX7Vm54btN4Xw+QX9jzxnT9Tts7V0hYaKpFkRvXzHry+1LZZ4mKSEj4KkUXfxSMbbBUmj/ihgcdhaj2B+Yr2JcUJOBksla1Cnb7Oha37jTaoB7ubw8zmN9Nk3rOkhOpgelfnxQv0= 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-0010-f595-e566-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-11T00:45:01.515942Z",
                            "start": "2026-02-11T00:45:00.922304Z"
                        },
                        "id": "0242ac17-0010-f595-e566-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-0010-f595-e566-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-11T00:45:01.738672Z",
                            "start": "2026-02-11T00:45:01.520966Z"
                        },
                        "id": "0242ac17-0010-f595-e566-0000000000be",
                        "name": "Make sure user has a .ssh"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "copy",
                            "changed": true,
                            "checksum": "8d2a6a9ddcb2769e4630336a2b8adfb041ffa51a",
                            "dest": "/home/zuul/.ssh/id_rsa",
                            "diff": [],
                            "gid": 1000,
                            "group": "zuul",
                            "invocation": {
                                "module_args": {
                                    "_original_basename": "855dd72a3bc24d528160da6987ba743a_id_rsa",
                                    "attributes": null,
                                    "backup": false,
                                    "checksum": "8d2a6a9ddcb2769e4630336a2b8adfb041ffa51a",
                                    "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-1770770701.7858744-190-165908314268350/source",
                                    "unsafe_writes": false,
                                    "validate": null
                                }
                            },
                            "md5sum": "7e6f786c5f4de8ff1f955f17c302e04c",
                            "mode": "0600",
                            "owner": "zuul",
                            "size": 2602,
                            "src": "/home/zuul/.ansible/tmp/ansible-tmp-1770770701.7858744-190-165908314268350/source",
                            "state": "file",
                            "uid": 1000
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-f595-e566-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-11T00:45:02.262847Z",
                            "start": "2026-02-11T00:45:01.742809Z"
                        },
                        "id": "0242ac17-0010-f595-e566-0000000000bf",
                        "name": "Install build private key as SSH key on all nodes"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "copy",
                            "changed": true,
                            "checksum": "3dfbb98393820bbf1221cd81546d351c5ae1fbe7",
                            "dest": "/home/zuul/.ssh/id_rsa.pub",
                            "diff": [],
                            "gid": 1000,
                            "group": "zuul",
                            "invocation": {
                                "module_args": {
                                    "_original_basename": "855dd72a3bc24d528160da6987ba743a_id_rsa.pub",
                                    "attributes": null,
                                    "backup": false,
                                    "checksum": "3dfbb98393820bbf1221cd81546d351c5ae1fbe7",
                                    "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-1770770702.3265877-200-110860291286933/source",
                                    "unsafe_writes": false,
                                    "validate": null
                                }
                            },
                            "md5sum": "bfb85510cbd6919c60042afad282d4ba",
                            "mode": "0644",
                            "owner": "zuul",
                            "size": 571,
                            "src": "/home/zuul/.ansible/tmp/ansible-tmp-1770770702.3265877-200-110860291286933/source",
                            "state": "file",
                            "uid": 1000
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-f595-e566-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-11T00:45:02.818286Z",
                            "start": "2026-02-11T00:45:02.268167Z"
                        },
                        "id": "0242ac17-0010-f595-e566-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-0010-f595-e566-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-11T00:45:02.847108Z",
                            "start": "2026-02-11T00:45:02.821977Z"
                        },
                        "id": "0242ac17-0010-f595-e566-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-0010-f595-e566-0000000000a3",
                        "name": "remove-zuul-sshkey",
                        "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/remove-zuul-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-11T00:45:03.205083Z",
                            "start": "2026-02-11T00:45:02.851793Z"
                        },
                        "id": "0242ac17-0010-f595-e566-0000000000a5",
                        "name": "Remove master key from local agent"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "command",
                            "changed": true,
                            "cmd": [
                                "ssh-add",
                                "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/work/855dd72a3bc24d528160da6987ba743a_id_rsa"
                            ],
                            "delta": "0:00:00.011208",
                            "end": "2026-02-11 00:45:03.464473",
                            "invocation": {
                                "module_args": {
                                    "_raw_params": "ssh-add /var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/work/855dd72a3bc24d528160da6987ba743a_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-0010-f595-e566-0000000000ab-0-controller",
                                    "zuul_no_log": false,
                                    "zuul_output_max_bytes": 1073741824
                                }
                            },
                            "msg": "",
                            "rc": 0,
                            "start": "2026-02-11 00:45:03.453265",
                            "stderr": "",
                            "stderr_lines": [],
                            "stdout": "Identity added: /var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/work/855dd72a3bc24d528160da6987ba743a_id_rsa (zuul-build-sshkey)",
                            "stdout_lines": [
                                "Identity added: /var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/work/855dd72a3bc24d528160da6987ba743a_id_rsa (zuul-build-sshkey)"
                            ],
                            "zuul_log_id": "0242ac17-0010-f595-e566-0000000000ab-0-controller"
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-f595-e566-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-11T00:45:03.500381Z",
                            "start": "2026-02-11T00:45:03.217105Z"
                        },
                        "id": "0242ac17-0010-f595-e566-0000000000ab",
                        "name": "Add back temp key"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "ping",
                            "changed": false,
                            "invocation": {
                                "module_args": {
                                    "data": "pong"
                                }
                            },
                            "ping": "pong"
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-f595-e566-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-11T00:45:03.837556Z",
                            "start": "2026-02-11T00:45:03.507581Z"
                        },
                        "id": "0242ac17-0010-f595-e566-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-0010-f595-e566-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-11T00:45:03.871550Z",
                            "start": "2026-02-11T00:45:03.842104Z"
                        },
                        "id": "0242ac17-0010-f595-e566-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-0010-f595-e566-00000000001b",
                        "name": "prepare-workspace",
                        "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/prepare-workspace"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-11T00:45:04.250237Z",
                            "start": "2026-02-11T00:45:03.890006Z"
                        },
                        "id": "0242ac17-0010-f595-e566-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-0010-f595-e566-00000000001b",
                        "name": "prepare-workspace",
                        "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/prepare-workspace"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-11T00:45:05.231161Z",
                            "start": "2026-02-11T00:45:04.254953Z"
                        },
                        "id": "0242ac17-0010-f595-e566-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-0010-f595-e566-000000000020",
                        "name": "ensure-output-dirs",
                        "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/ensure-output-dirs"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-11T00:45:05.834673Z",
                            "start": "2026-02-11T00:45:05.245866Z"
                        },
                        "id": "0242ac17-0010-f595-e566-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-0010-f595-e566-000000000020",
                        "name": "ensure-output-dirs",
                        "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/ensure-output-dirs"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-11T00:45:06.473011Z",
                            "start": "2026-02-11T00:45:05.838916Z"
                        },
                        "id": "0242ac17-0010-f595-e566-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-11T00:45:10.303496Z",
                    "start": "2026-02-11T00:45:07.279578Z"
                },
                "id": "0242ac17-0010-2e03-c507-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-1770770707.3309946-5-111401679477350/uv-x86_64-unknown-linux-gnujxu7mhc1.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-1770770707.3309946-5-111401679477350/uv-x86_64-unknown-linux-gnujxu7mhc1.tar.gz",
                            "state": "directory",
                            "uid": 0
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-2e03-c507-000000000005",
                        "name": "setup-uv",
                        "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/untrusted/project_0/github.com/vexxhost/zuul-jobs/roles/setup-uv"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-11T00:45:09.761854Z",
                            "start": "2026-02-11T00:45:07.290747Z"
                        },
                        "id": "0242ac17-0010-2e03-c507-000000000007",
                        "name": "Extract archive"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "ansible.builtin.command",
                            "changed": true,
                            "cmd": [
                                "/usr/local/bin/uv",
                                "--version"
                            ],
                            "delta": "0:00:00.010705",
                            "end": "2026-02-11 00:45:10.147558",
                            "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-0010-2e03-c507-000000000008-1-controller",
                                    "zuul_no_log": false,
                                    "zuul_output_max_bytes": 1073741824
                                }
                            },
                            "msg": "",
                            "rc": 0,
                            "start": "2026-02-11 00:45:10.136853",
                            "stderr": "",
                            "stderr_lines": [],
                            "stdout": "uv 0.8.13",
                            "stdout_lines": [
                                "uv 0.8.13"
                            ],
                            "zuul_log_id": "0242ac17-0010-2e03-c507-000000000008-1-controller"
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-2e03-c507-000000000005",
                        "name": "setup-uv",
                        "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/untrusted/project_0/github.com/vexxhost/zuul-jobs/roles/setup-uv"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-11T00:45:10.303496Z",
                            "start": "2026-02-11T00:45:09.787690Z"
                        },
                        "id": "0242ac17-0010-2e03-c507-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-11T00:51:48.095941Z",
                    "start": "2026-02-11T00:45:10.997959Z"
                },
                "id": "0242ac17-0010-5810-aa40-000000000002",
                "name": "all"
            },
            "tasks": [
                {
                    "hosts": {
                        "controller": {
                            "action": "ansible.builtin.copy",
                            "changed": true,
                            "checksum": "141be9e3839579963c99200a79799a077dbf309d",
                            "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": "141be9e3839579963c99200a79799a077dbf309d",
                                    "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-1770770711.0458708-5-4439396833274/source",
                                    "unsafe_writes": false,
                                    "validate": null
                                }
                            },
                            "md5sum": "ff5b1aada78688b497658be891fdfea8",
                            "mode": "0644",
                            "owner": "zuul",
                            "size": 9649,
                            "src": "/home/zuul/.ansible/tmp/ansible-tmp-1770770711.0458708-5-4439396833274/source",
                            "state": "file",
                            "uid": 1000
                        }
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-11T00:45:11.930019Z",
                            "start": "2026-02-11T00:45:11.007995Z"
                        },
                        "id": "0242ac17-0010-5810-aa40-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-11T00:45:12.228950Z",
                            "start": "2026-02-11T00:45:11.933957Z"
                        },
                        "id": "0242ac17-0010-5810-aa40-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:06:35.448368",
                            "end": "2026-02-11 00:51:48.028727",
                            "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-0010-5810-aa40-000000000006-1-controller",
                                    "zuul_no_log": false,
                                    "zuul_output_max_bytes": 1073741824
                                }
                            },
                            "msg": "",
                            "rc": 0,
                            "start": "2026-02-11 00:45:12.580359",
                            "stderr": "",
                            "stderr_lines": [],
                            "stdout": "Using CPython 3.13.5 interpreter at: /usr/bin/python3\nCreating virtual environment at: .venv\nDownloading cryptography (4.3MiB)\nDownloading pygments (1.2MiB)\nDownloading ansible-core (2.3MiB)\n Downloading cryptography\n Downloading pygments\n Downloading ansible-core\nInstalled 36 packages in 48ms\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] *********************************************************\nWednesday 11 February 2026  00:47:23 +0000 (0:00:00.035)       0:00:00.035 ****\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] *************************************************\nWednesday 11 February 2026  00:47:24 +0000 (0:00:01.388)       0:00:01.423 ****\nok: [controller]\n\nPLAY [Prepare BGP] *************************************************************\n\nTASK [Gathering Facts] *********************************************************\nWednesday 11 February 2026  00:47:31 +0000 (0:00:06.503)       0:00:07.927 ****\nok: [controller]\n\nTASK [Enable IP forwarding] ****************************************************\nWednesday 11 February 2026  00:47:32 +0000 (0:00:00.796)       0:00:08.723 ****\nchanged: [controller]\n\nTASK [Add FRR repository] ******************************************************\nWednesday 11 February 2026  00:47:32 +0000 (0:00:00.448)       0:00:09.172 ****\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] ****************************************************\nWednesday 11 February 2026  00:47:38 +0000 (0:00:06.016)       0:00:15.188 ****\nchanged: [controller]\n\nTASK [Ensure bgpd is enabled] **************************************************\nWednesday 11 February 2026  00:47:47 +0000 (0:00:08.720)       0:00:23.909 ****\nchanged: [controller]\n\nTASK [Update FRR configuration] ************************************************\nWednesday 11 February 2026  00:47:47 +0000 (0:00:00.400)       0:00:24.309 ****\nchanged: [controller]\n\nTASK [Restart service frr] *****************************************************\nWednesday 11 February 2026  00:47:48 +0000 (0:00:00.957)       0:00:25.267 ****\nchanged: [controller]\n\nPLAY RECAP *********************************************************************\ncontroller                 : ok=9    changed=6    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0\n\n\nTASKS RECAP ********************************************************************\nWednesday 11 February 2026  00:47:54 +0000 (0:00:06.215)       0:00:31.482 ****\n===============================================================================\nInstall frr packages ---------------------------------------------------- 8.72s\nInstall Debian packages ------------------------------------------------- 6.50s\nRestart service frr ----------------------------------------------------- 6.22s\nAdd FRR repository ------------------------------------------------------ 6.02s\nGathering Facts --------------------------------------------------------- 1.39s\nUpdate FRR configuration ------------------------------------------------ 0.96s\nGathering Facts --------------------------------------------------------- 0.80s\nEnable IP forwarding ---------------------------------------------------- 0.45s\nEnsure bgpd is enabled -------------------------------------------------- 0.40s\nINFO     [bgp > prepare] Executed: Successful\nINFO     [bgp > converge] Executing\n\nPLAY [Configure Kubernetes VIP] ************************************************\n\nTASK [Gathering Facts] *********************************************************\nWednesday 11 February 2026  00:47:56 +0000 (0:00:00.018)       0:00:00.018 ****\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)] ***\nWednesday 11 February 2026  00:47:57 +0000 (0:00:00.984)       0:00:01.003 ****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Uninstall legacy HA stack] ****************\nWednesday 11 February 2026  00:47:57 +0000 (0:00:00.400)       0:00:01.404 ****\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] ****\nWednesday 11 February 2026  00:47:59 +0000 (0:00:01.386)       0:00:02.790 ****\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] *********\nWednesday 11 February 2026  00:48:00 +0000 (0:00:00.977)       0:00:03.767 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Check if kubeadm has already run] *********\nWednesday 11 February 2026  00:48:00 +0000 (0:00:00.441)       0:00:04.209 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Set fact with KUBECONFIG path] ************\nWednesday 11 February 2026  00:48:00 +0000 (0:00:00.308)       0:00:04.517 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Set fact with KUBECONFIG path (with super-admin.conf)] ***\nWednesday 11 February 2026  00:48:00 +0000 (0:00:00.031)       0:00:04.548 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Upload Kubernetes manifest] ***************\nWednesday 11 February 2026  00:48:00 +0000 (0:00:00.032)       0:00:04.581 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Ensure kube-vip configuration file] *******\nWednesday 11 February 2026  00:48:01 +0000 (0:00:00.954)       0:00:05.535 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Flush handlers] ***************************\nWednesday 11 February 2026  00:48:02 +0000 (0:00:00.316)       0:00:05.852 ****\n\nPLAY [Install Kubernetes] ******************************************************\n\nTASK [Gathering Facts] *********************************************************\nWednesday 11 February 2026  00:48:02 +0000 (0:00:00.058)       0:00:05.911 ****\nok: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nWednesday 11 February 2026  00:48:02 +0000 (0:00:00.812)       0:00:06.724 ****\nok: [controller]\n\nTASK [vexxhost.containers.package : Update state for tar] **********************\nWednesday 11 February 2026  00:48:03 +0000 (0:00:00.340)       0:00:07.064 ****\nskipping: [controller]\n\nTASK [vexxhost.containers.directory : Create directory (/var/lib/downloads)] ***\nWednesday 11 February 2026  00:48:03 +0000 (0:00:00.037)       0:00:07.101 ****\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nWednesday 11 February 2026  00:48:03 +0000 (0:00:00.321)       0:00:07.423 ****\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] *******************\nWednesday 11 February 2026  00:48:03 +0000 (0:00:00.086)       0:00:07.509 ****\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nWednesday 11 February 2026  00:48:04 +0000 (0:00:00.822)       0:00:08.332 ****\nskipping: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nWednesday 11 February 2026  00:48:04 +0000 (0:00:00.039)       0:00:08.371 ****\nok: [controller]\n\nTASK [vexxhost.containers.package : Update state for tar] **********************\nWednesday 11 February 2026  00:48:04 +0000 (0:00:00.318)       0:00:08.689 ****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nWednesday 11 February 2026  00:48:05 +0000 (0:00:01.010)       0:00:09.700 ****\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] *******************\nWednesday 11 February 2026  00:48:06 +0000 (0:00:00.071)       0:00:09.771 ****\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nWednesday 11 February 2026  00:48:07 +0000 (0:00:01.069)       0:00:10.840 ****\nchanged: [controller]\n\nTASK [vexxhost.containers.containerd : Install SELinux packages] ***************\nWednesday 11 February 2026  00:48:10 +0000 (0:00:03.212)       0:00:14.053 ****\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Set SELinux to permissive at runtime] ***\nWednesday 11 February 2026  00:48:10 +0000 (0:00:00.028)       0:00:14.081 ****\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Persist SELinux permissive mode] ********\nWednesday 11 February 2026  00:48:10 +0000 (0:00:00.028)       0:00:14.110 ****\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Install AppArmor packages] **************\nWednesday 11 February 2026  00:48:10 +0000 (0:00:00.025)       0:00:14.135 ****\nchanged: [controller]\n\nTASK [vexxhost.containers.containerd : Create systemd service file for containerd] ***\nWednesday 11 February 2026  00:48:16 +0000 (0:00:06.511)       0:00:20.646 ****\nchanged: [controller]\n\nTASK [vexxhost.containers.containerd : Create folders for configuration] *******\nWednesday 11 February 2026  00:48:17 +0000 (0:00:00.605)       0:00:21.252 ****\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] **********\nWednesday 11 February 2026  00:48:18 +0000 (0:00:01.417)       0:00:22.669 ****\nchanged: [controller]\n\nTASK [vexxhost.containers.containerd : Force any restarts if necessary] ********\nWednesday 11 February 2026  00:48:19 +0000 (0:00:00.763)       0:00:23.433 ****\n\nRUNNING HANDLER [vexxhost.containers.containerd : Restart containerd] **********\nWednesday 11 February 2026  00:48:19 +0000 (0:00:00.006)       0:00:23.439 ****\nchanged: [controller]\n\nRUNNING HANDLER [vexxhost.kubernetes.kubelet : Reload systemd] *****************\nWednesday 11 February 2026  00:48:20 +0000 (0:00:00.875)       0:00:24.315 ****\nok: [controller]\n\nTASK [vexxhost.containers.containerd : Enable and start service] ***************\nWednesday 11 February 2026  00:48:22 +0000 (0:00:01.534)       0:00:25.850 ****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes_upgrade_check : Retrieve the \"kubeadm-config\" ConfigMap] ***\nWednesday 11 February 2026  00:48:23 +0000 (0:00:01.792)       0:00:27.643 ****\n[ERROR]: Task failed: Module failed: Failed to import the required Python library (kubernetes) on np0000155225'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 np0000155225'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] ***\nWednesday 11 February 2026  00:48:24 +0000 (0:00:00.676)       0:00:28.319 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes_upgrade_check : Retrieve the current Kubernetes version] ***\nWednesday 11 February 2026  00:48:24 +0000 (0:00:00.035)       0:00:28.355 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes_upgrade_check : Extract major, minor, and patch versions] ***\nWednesday 11 February 2026  00:48:24 +0000 (0:00:00.031)       0:00:28.386 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes_upgrade_check : Fail if we're jumping more than one minor version] ***\nWednesday 11 February 2026  00:48:24 +0000 (0:00:00.042)       0:00:28.429 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes_upgrade_check : Set fact if we need to upgrade] ***\nWednesday 11 February 2026  00:48:24 +0000 (0:00:00.032)       0:00:28.461 ****\nskipping: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nWednesday 11 February 2026  00:48:24 +0000 (0:00:00.032)       0:00:28.494 ****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nWednesday 11 February 2026  00:48:25 +0000 (0:00:00.321)       0:00:28.815 ****\nok: [controller] => {\n    \"msg\": \"https://cdn.dl.k8s.io/release/v1.34.0/bin/linux/amd64/kubeadm\"\n}\n\nTASK [vexxhost.containers.download_artifact : Download item] *******************\nWednesday 11 February 2026  00:48:25 +0000 (0:00:00.098)       0:00:28.914 ****\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nWednesday 11 February 2026  00:48:29 +0000 (0:00:04.195)       0:00:33.109 ****\nskipping: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nWednesday 11 February 2026  00:48:29 +0000 (0:00:00.040)       0:00:33.150 ****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nWednesday 11 February 2026  00:48:29 +0000 (0:00:00.322)       0:00:33.472 ****\nok: [controller] => {\n    \"msg\": \"https://cdn.dl.k8s.io/release/v1.34.0/bin/linux/amd64/kubectl\"\n}\n\nTASK [vexxhost.containers.download_artifact : Download item] *******************\nWednesday 11 February 2026  00:48:29 +0000 (0:00:00.046)       0:00:33.519 ****\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nWednesday 11 February 2026  00:48:31 +0000 (0:00:02.018)       0:00:35.537 ****\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Install SELinux packages] ***************\nWednesday 11 February 2026  00:48:31 +0000 (0:00:00.050)       0:00:35.588 ****\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Set SELinux to permissive at runtime] ***\nWednesday 11 February 2026  00:48:31 +0000 (0:00:00.028)       0:00:35.616 ****\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Persist SELinux permissive mode] ********\nWednesday 11 February 2026  00:48:31 +0000 (0:00:00.027)       0:00:35.644 ****\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Install AppArmor packages] **************\nWednesday 11 February 2026  00:48:31 +0000 (0:00:00.032)       0:00:35.676 ****\nok: [controller]\n\nTASK [vexxhost.containers.containerd : Create systemd service file for containerd] ***\nWednesday 11 February 2026  00:48:32 +0000 (0:00:00.964)       0:00:36.640 ****\nok: [controller]\n\nTASK [vexxhost.containers.containerd : Create folders for configuration] *******\nWednesday 11 February 2026  00:48:33 +0000 (0:00:00.640)       0:00:37.281 ****\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] **********\nWednesday 11 February 2026  00:48:34 +0000 (0:00:01.402)       0:00:38.683 ****\nok: [controller]\n\nTASK [vexxhost.containers.containerd : Force any restarts if necessary] ********\nWednesday 11 February 2026  00:48:35 +0000 (0:00:00.803)       0:00:39.486 ****\n\nTASK [vexxhost.containers.containerd : Enable and start service] ***************\nWednesday 11 February 2026  00:48:35 +0000 (0:00:00.004)       0:00:39.491 ****\nok: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nWednesday 11 February 2026  00:48:36 +0000 (0:00:00.484)       0:00:39.976 ****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nWednesday 11 February 2026  00:48:36 +0000 (0:00:00.306)       0:00:40.282 ****\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] *******************\nWednesday 11 February 2026  00:48:36 +0000 (0:00:00.074)       0:00:40.357 ****\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nWednesday 11 February 2026  00:48:37 +0000 (0:00:00.694)       0:00:41.051 ****\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nWednesday 11 February 2026  00:48:39 +0000 (0:00:01.812)       0:00:42.863 ****\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] *******************\nWednesday 11 February 2026  00:48:39 +0000 (0:00:00.063)       0:00:42.927 ****\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nWednesday 11 February 2026  00:48:46 +0000 (0:00:07.291)       0:00:50.219 ****\nchanged: [controller]\n\nTASK [vexxhost.containers.cri_tools : Create crictl config] ********************\nWednesday 11 February 2026  00:48:48 +0000 (0:00:01.651)       0:00:51.870 ****\nchanged: [controller]\n\nTASK [vexxhost.containers.directory : Create directory (/opt/cni/bin)] *********\nWednesday 11 February 2026  00:48:48 +0000 (0:00:00.659)       0:00:52.529 ****\nchanged: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nWednesday 11 February 2026  00:48:49 +0000 (0:00:00.319)       0:00:52.849 ****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nWednesday 11 February 2026  00:48:49 +0000 (0:00:00.299)       0:00:53.148 ****\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] *******************\nWednesday 11 February 2026  00:48:49 +0000 (0:00:00.078)       0:00:53.227 ****\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nWednesday 11 February 2026  00:48:50 +0000 (0:00:00.992)       0:00:54.219 ****\nchanged: [controller]\n\nTASK [vexxhost.containers.cni_plugins : Gather variables for each operating system] ***\nWednesday 11 February 2026  00:48:53 +0000 (0:00:02.908)       0:00:57.128 ****\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] ***********\nWednesday 11 February 2026  00:48:53 +0000 (0:00:00.062)       0:00:57.191 ****\nchanged: [controller]\n\nTASK [vexxhost.containers.cni_plugins : Ensure IPv6 is enabled] ****************\nWednesday 11 February 2026  00:48:55 +0000 (0:00:02.469)       0:00:59.660 ****\nchanged: [controller]\n\nTASK [vexxhost.containers.cni_plugins : Enable kernel modules on-boot] *********\nWednesday 11 February 2026  00:48:56 +0000 (0:00:00.450)       0:01:00.111 ****\nchanged: [controller]\n\nTASK [vexxhost.containers.cni_plugins : Enable kernel modules in runtime] ******\nWednesday 11 February 2026  00:48:57 +0000 (0:00:00.678)       0:01:00.789 ****\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] *********************\nWednesday 11 February 2026  00:48:58 +0000 (0:00:01.485)       0:01:02.275 ****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nWednesday 11 February 2026  00:48:58 +0000 (0:00:00.298)       0:01:02.574 ****\nok: [controller] => {\n    \"msg\": \"https://cdn.dl.k8s.io/release/v1.34.0/bin/linux/amd64/kubelet\"\n}\n\nTASK [vexxhost.containers.download_artifact : Download item] *******************\nWednesday 11 February 2026  00:48:58 +0000 (0:00:00.045)       0:01:02.619 ****\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nWednesday 11 February 2026  00:49:01 +0000 (0:00:02.173)       0:01:04.793 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Gather variables for each operating system] ***\nWednesday 11 February 2026  00:49:01 +0000 (0:00:00.029)       0:01:04.822 ****\nok: [controller] => (item=/home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubelet/vars/debian.yml)\n\nTASK [vexxhost.kubernetes.kubelet : Install coreutils] *************************\nWednesday 11 February 2026  00:49:01 +0000 (0:00:00.056)       0:01:04.878 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Install additional packages] ***************\nWednesday 11 February 2026  00:49:01 +0000 (0:00:00.032)       0:01:04.911 ****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Configure sysctl values] *******************\nWednesday 11 February 2026  00:49:05 +0000 (0:00:04.472)       0:01:09.383 ****\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] ***\nWednesday 11 February 2026  00:49:08 +0000 (0:00:02.641)       0:01:12.025 ****\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] ********\nWednesday 11 February 2026  00:49:09 +0000 (0:00:00.830)       0:01:12.855 ****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Add kubeadm dropin for kubelet systemd service config] ***\nWednesday 11 February 2026  00:49:09 +0000 (0:00:00.645)       0:01:13.500 ****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Check swap status] *************************\nWednesday 11 February 2026  00:49:10 +0000 (0:00:00.659)       0:01:14.160 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Disable swap] ******************************\nWednesday 11 February 2026  00:49:10 +0000 (0:00:00.390)       0:01:14.551 ****\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] ***********\nWednesday 11 February 2026  00:49:10 +0000 (0:00:00.036)       0:01:14.587 ****\nok: [controller] => (item=swap)\nok: [controller] => (item=none)\n\nTASK [vexxhost.kubernetes.kubelet : Create noswap systemd service config file] ***\nWednesday 11 February 2026  00:49:11 +0000 (0:00:00.765)       0:01:15.353 ****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Enable noswap service] *********************\nWednesday 11 February 2026  00:49:12 +0000 (0:00:00.678)       0:01:16.031 ****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Force any restarts if necessary] ***********\nWednesday 11 February 2026  00:49:13 +0000 (0:00:01.048)       0:01:17.080 ****\n\nRUNNING HANDLER [vexxhost.kubernetes.kubelet : Reload systemd] *****************\nWednesday 11 February 2026  00:49:13 +0000 (0:00:00.008)       0:01:17.089 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Enable and start kubelet service] **********\nWednesday 11 February 2026  00:49:14 +0000 (0:00:01.576)       0:01:18.665 ****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Ensure availability of dbus on Debian] *****\nWednesday 11 February 2026  00:49:16 +0000 (0:00:01.770)       0:01:20.436 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Configure short hostname] ******************\nWednesday 11 February 2026  00:49:17 +0000 (0:00:00.887)       0:01:21.324 ****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Ensure hostname inside hosts file] *********\nWednesday 11 February 2026  00:49:18 +0000 (0:00:00.847)       0:01:22.171 ****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Remove kubernetes repository] ***********\nWednesday 11 February 2026  00:49:18 +0000 (0:00:00.422)       0:01:22.594 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Setup control plane] ********************\nWednesday 11 February 2026  00:49:19 +0000 (0:00:00.567)       0:01:23.161 ****\nincluded: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubernetes/tasks/control-plane.yml for controller\n\nTASK [vexxhost.kubernetes.kubernetes : Bootstrap cluster] **********************\nWednesday 11 February 2026  00:49:19 +0000 (0:00:00.082)       0:01:23.244 ****\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] ***\nWednesday 11 February 2026  00:49:19 +0000 (0:00:00.083)       0:01:23.327 ****\nok: [controller] => (item=controller)\n\nTASK [vexxhost.kubernetes.kubernetes : Pick node from pre-existing cluster] ****\nWednesday 11 February 2026  00:49:19 +0000 (0:00:00.314)       0:01:23.641 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Select first node to initialize cluster] ***\nWednesday 11 February 2026  00:49:19 +0000 (0:00:00.041)       0:01:23.683 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Print selected bootstrap node] **********\nWednesday 11 February 2026  00:49:20 +0000 (0:00:00.052)       0:01:23.735 ****\nok: [controller] => {\n    \"msg\": \"controller\"\n}\n\nTASK [vexxhost.kubernetes.kubernetes : Upload cluster configuration for bootstrap node] ***\nWednesday 11 February 2026  00:49:20 +0000 (0:00:00.040)       0:01:23.776 ****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create pki folder] **********************\nWednesday 11 February 2026  00:49:20 +0000 (0:00:00.685)       0:01:24.461 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create kubernetes ca key] ***************\nWednesday 11 February 2026  00:49:20 +0000 (0:00:00.031)       0:01:24.493 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create kubernetes ca cert] **************\nWednesday 11 February 2026  00:49:20 +0000 (0:00:00.038)       0:01:24.531 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create etcd-ca key] *********************\nWednesday 11 February 2026  00:49:20 +0000 (0:00:00.031)       0:01:24.563 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create etcd-ca cert] ********************\nWednesday 11 February 2026  00:49:20 +0000 (0:00:00.031)       0:01:24.595 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create front-proxy-ca key] **************\nWednesday 11 February 2026  00:49:20 +0000 (0:00:00.028)       0:01:24.623 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create front-proxy-ca cert] *************\nWednesday 11 February 2026  00:49:20 +0000 (0:00:00.034)       0:01:24.658 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Initialize cluster] *********************\nWednesday 11 February 2026  00:49:20 +0000 (0:00:00.035)       0:01:24.694 ****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Check if the node is already part of the cluster] ***\nWednesday 11 February 2026  00:49:52 +0000 (0:00:31.743)       0:01:56.437 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Join cluster] ***************************\nWednesday 11 February 2026  00:49:53 +0000 (0:00:00.364)       0:01:56.802 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create folder for admin configuration] ***\nWednesday 11 February 2026  00:49:53 +0000 (0:00:00.039)       0:01:56.842 ****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Creating a symlink for admin configuration file] ***\nWednesday 11 February 2026  00:49:53 +0000 (0:00:00.402)       0:01:57.245 ****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Add bash autocomplete for kubectl] ******\nWednesday 11 February 2026  00:49:53 +0000 (0:00:00.339)       0:01:57.584 ****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Install PIP] ****************************\nWednesday 11 February 2026  00:49:54 +0000 (0:00:00.305)       0:01:57.890 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Install Kubernetes Python package using pip on supported systems] ***\nWednesday 11 February 2026  00:49:54 +0000 (0:00:00.042)       0:01:57.933 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Enable EPEL repository] *****************\nWednesday 11 February 2026  00:49:54 +0000 (0:00:00.037)       0:01:57.971 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Install Kubernetes Python package using package manager on supported systems] ***\nWednesday 11 February 2026  00:49:54 +0000 (0:00:00.047)       0:01:58.019 ****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Allow workload on control plane node] ***\nWednesday 11 February 2026  00:50:05 +0000 (0:00:11.415)       0:02:09.434 ****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Remove kube-proxy resources] ************\nWednesday 11 February 2026  00:50:06 +0000 (0:00:01.102)       0:02:10.536 ****\nskipping: [controller] => (item=DaemonSet)\nskipping: [controller] => (item=ConfigMap)\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Start an upgrade] ***********************\nWednesday 11 February 2026  00:50:06 +0000 (0:00:00.041)       0:02:10.578 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Check if the Kubernetes API services is up to date] ***\nWednesday 11 February 2026  00:50:06 +0000 (0:00:00.038)       0:02:10.616 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Trigger an upgrade of the Kubernetes API services] ***\nWednesday 11 February 2026  00:50:06 +0000 (0:00:00.029)       0:02:10.646 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Setup nodes] ****************************\nWednesday 11 February 2026  00:50:06 +0000 (0:00:00.032)       0:02:10.678 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Upgrade & restart Kubelet node for upgrade (if needed)] ***\nWednesday 11 February 2026  00:50:06 +0000 (0:00:00.030)       0:02:10.709 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Set node selector for CoreDNS components] ***\nWednesday 11 February 2026  00:50:07 +0000 (0:00:00.599)       0:02:11.308 ****\nchanged: [controller]\n\nPLAY [Install control-plane components] ****************************************\n\nTASK [Gathering Facts] *********************************************************\nWednesday 11 February 2026  00:50:09 +0000 (0:00:01.456)       0:02:12.765 ****\nok: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nWednesday 11 February 2026  00:50:09 +0000 (0:00:00.923)       0:02:13.688 ****\nok: [controller]\n\nTASK [vexxhost.containers.package : Update state for tar] **********************\nWednesday 11 February 2026  00:50:10 +0000 (0:00:00.326)       0:02:14.015 ****\nok: [controller]\n\nTASK [vexxhost.containers.directory : Create directory (/var/lib/downloads)] ***\nWednesday 11 February 2026  00:50:11 +0000 (0:00:00.940)       0:02:14.955 ****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nWednesday 11 February 2026  00:50:11 +0000 (0:00:00.346)       0:02:15.302 ****\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] *******************\nWednesday 11 February 2026  00:50:11 +0000 (0:00:00.046)       0:02:15.349 ****\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nWednesday 11 February 2026  00:50:12 +0000 (0:00:00.693)       0:02:16.043 ****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.helm : Remove Helm repository] ***********************\nWednesday 11 February 2026  00:50:14 +0000 (0:00:01.938)       0:02:17.981 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.helm : Add bash autocomplete for helm] ***************\nWednesday 11 February 2026  00:50:14 +0000 (0:00:00.439)       0:02:18.420 ****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.helm : Get Helm plugins dir] *************************\nWednesday 11 February 2026  00:50:15 +0000 (0:00:00.330)       0:02:18.750 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.helm : Create Helm plugins directory if it does not exist] ***\nWednesday 11 February 2026  00:50:15 +0000 (0:00:00.468)       0:02:19.219 ****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.helm : Remove Helm diff plugin installed by kubernetes.core.helm_plugin] ***\nWednesday 11 February 2026  00:50:15 +0000 (0:00:00.319)       0:02:19.538 ****\nok: [controller]\n\nTASK [Install plugin] **********************************************************\nWednesday 11 February 2026  00:50:16 +0000 (0:00:00.322)       0:02:19.861 ****\nincluded: vexxhost.containers.download_artifact for controller\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nWednesday 11 February 2026  00:50:16 +0000 (0:00:00.070)       0:02:19.931 ****\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] *******************\nWednesday 11 February 2026  00:50:16 +0000 (0:00:00.039)       0:02:19.971 ****\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nWednesday 11 February 2026  00:50:17 +0000 (0:00:00.761)       0:02:20.732 ****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.upload_helm_chart : Include help chart upload method tasks] ***\nWednesday 11 February 2026  00:50:19 +0000 (0:00:02.234)       0:02:22.967 ****\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] ***************\nWednesday 11 February 2026  00:50:19 +0000 (0:00:00.094)       0:02:23.062 ****\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.cilium : Get current Kubernetes version] *************\nWednesday 11 February 2026  00:50:20 +0000 (0:00:00.831)       0:02:23.893 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.cilium : Deploy Helm chart] **************************\nWednesday 11 February 2026  00:50:21 +0000 (0:00:01.025)       0:02:24.918 ****\nchanged: [controller]\n\nPLAY RECAP *********************************************************************\ncontroller                 : ok=112  changed=52   unreachable=0    failed=0    skipped=34   rescued=0    ignored=3\n\n\nTASKS RECAP ********************************************************************\nWednesday 11 February 2026  00:50:24 +0000 (0:00:03.298)       0:02:28.217 ****\n===============================================================================\nvexxhost.kubernetes.kubernetes : Initialize cluster -------------------- 31.74s\nvexxhost.kubernetes.kubernetes : Install Kubernetes Python package using package manager on supported systems -- 11.42s\nvexxhost.containers.download_artifact : Download item ------------------- 7.29s\nvexxhost.containers.containerd : Install AppArmor packages -------------- 6.51s\nvexxhost.kubernetes.kubelet : Install additional packages --------------- 4.47s\nvexxhost.containers.download_artifact : Download item ------------------- 4.20s\nvexxhost.kubernetes.cilium : Deploy Helm chart -------------------------- 3.30s\nvexxhost.containers.download_artifact : Extract archive ----------------- 3.21s\nvexxhost.kubernetes.kubelet : Reload systemd ---------------------------- 3.11s\nvexxhost.containers.download_artifact : Extract archive ----------------- 2.91s\nvexxhost.kubernetes.kubelet : Configure sysctl values ------------------- 2.64s\nvexxhost.containers.cni_plugins : Install additional packages ----------- 2.47s\nvexxhost.containers.download_artifact : Extract archive ----------------- 2.23s\nvexxhost.containers.download_artifact : Download item ------------------- 2.17s\nvexxhost.containers.download_artifact : Download item ------------------- 2.02s\nvexxhost.containers.download_artifact : Extract archive ----------------- 1.94s\nvexxhost.containers.download_artifact : Extract archive ----------------- 1.81s\nvexxhost.containers.containerd : Enable and start service --------------- 1.79s\nvexxhost.kubernetes.kubelet : Enable and start kubelet service ---------- 1.77s\nvexxhost.containers.download_artifact : Extract archive ----------------- 1.65s\nINFO     [bgp > converge] Executed: Successful\nINFO     [bgp > idempotence] Executing\n\nPLAY [Configure Kubernetes VIP] ************************************************\n\nTASK [Gathering Facts] *********************************************************\nWednesday 11 February 2026  00:50:26 +0000 (0:00:00.018)       0:00:00.018 ****\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)] ***\nWednesday 11 February 2026  00:50:27 +0000 (0:00:01.123)       0:00:01.141 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Uninstall legacy HA stack] ****************\nWednesday 11 February 2026  00:50:27 +0000 (0:00:00.429)       0:00:01.570 ****\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] ****\nWednesday 11 February 2026  00:50:29 +0000 (0:00:01.521)       0:00:03.092 ****\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] *********\nWednesday 11 February 2026  00:50:30 +0000 (0:00:00.958)       0:00:04.050 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Check if kubeadm has already run] *********\nWednesday 11 February 2026  00:50:30 +0000 (0:00:00.438)       0:00:04.489 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Set fact with KUBECONFIG path] ************\nWednesday 11 February 2026  00:50:30 +0000 (0:00:00.366)       0:00:04.856 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Set fact with KUBECONFIG path (with super-admin.conf)] ***\nWednesday 11 February 2026  00:50:30 +0000 (0:00:00.026)       0:00:04.882 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Upload Kubernetes manifest] ***************\nWednesday 11 February 2026  00:50:31 +0000 (0:00:00.040)       0:00:04.922 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Ensure kube-vip configuration file] *******\nWednesday 11 February 2026  00:50:31 +0000 (0:00:00.919)       0:00:05.842 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Flush handlers] ***************************\nWednesday 11 February 2026  00:50:32 +0000 (0:00:00.304)       0:00:06.147 ****\n\nPLAY [Install Kubernetes] ******************************************************\n\nTASK [Gathering Facts] *********************************************************\nWednesday 11 February 2026  00:50:32 +0000 (0:00:00.063)       0:00:06.211 ****\nok: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nWednesday 11 February 2026  00:50:34 +0000 (0:00:01.830)       0:00:08.041 ****\nok: [controller]\n\nTASK [vexxhost.containers.package : Update state for tar] **********************\nWednesday 11 February 2026  00:50:34 +0000 (0:00:00.361)       0:00:08.403 ****\nskipping: [controller]\n\nTASK [vexxhost.containers.directory : Create directory (/var/lib/downloads)] ***\nWednesday 11 February 2026  00:50:34 +0000 (0:00:00.035)       0:00:08.439 ****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nWednesday 11 February 2026  00:50:34 +0000 (0:00:00.317)       0:00:08.756 ****\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] *******************\nWednesday 11 February 2026  00:50:34 +0000 (0:00:00.073)       0:00:08.830 ****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nWednesday 11 February 2026  00:50:35 +0000 (0:00:00.576)       0:00:09.407 ****\nskipping: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nWednesday 11 February 2026  00:50:35 +0000 (0:00:00.044)       0:00:09.451 ****\nok: [controller]\n\nTASK [vexxhost.containers.package : Update state for tar] **********************\nWednesday 11 February 2026  00:50:35 +0000 (0:00:00.312)       0:00:09.764 ****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nWednesday 11 February 2026  00:50:36 +0000 (0:00:01.094)       0:00:10.858 ****\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] *******************\nWednesday 11 February 2026  00:50:37 +0000 (0:00:00.072)       0:00:10.931 ****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nWednesday 11 February 2026  00:50:37 +0000 (0:00:00.495)       0:00:11.426 ****\nok: [controller]\n\nTASK [vexxhost.containers.containerd : Install SELinux packages] ***************\nWednesday 11 February 2026  00:50:40 +0000 (0:00:02.631)       0:00:14.057 ****\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Set SELinux to permissive at runtime] ***\nWednesday 11 February 2026  00:50:40 +0000 (0:00:00.025)       0:00:14.082 ****\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Persist SELinux permissive mode] ********\nWednesday 11 February 2026  00:50:40 +0000 (0:00:00.031)       0:00:14.114 ****\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Install AppArmor packages] **************\nWednesday 11 February 2026  00:50:40 +0000 (0:00:00.032)       0:00:14.146 ****\nok: [controller]\n\nTASK [vexxhost.containers.containerd : Create systemd service file for containerd] ***\nWednesday 11 February 2026  00:50:41 +0000 (0:00:01.032)       0:00:15.179 ****\nok: [controller]\n\nTASK [vexxhost.containers.containerd : Create folders for configuration] *******\nWednesday 11 February 2026  00:50:42 +0000 (0:00:01.082)       0:00:16.262 ****\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] **********\nWednesday 11 February 2026  00:50:43 +0000 (0:00:01.604)       0:00:17.867 ****\nok: [controller]\n\nTASK [vexxhost.containers.containerd : Force any restarts if necessary] ********\nWednesday 11 February 2026  00:50:44 +0000 (0:00:00.741)       0:00:18.608 ****\n\nTASK [vexxhost.containers.containerd : Enable and start service] ***************\nWednesday 11 February 2026  00:50:44 +0000 (0:00:00.006)       0:00:18.615 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes_upgrade_check : Retrieve the \"kubeadm-config\" ConfigMap] ***\nWednesday 11 February 2026  00:50:45 +0000 (0:00:00.802)       0:00:19.417 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes_upgrade_check : Parse the ClusterConfiguration] ***\nWednesday 11 February 2026  00:50:46 +0000 (0:00:01.173)       0:00:20.591 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes_upgrade_check : Retrieve the current Kubernetes version] ***\nWednesday 11 February 2026  00:50:46 +0000 (0:00:00.046)       0:00:20.637 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes_upgrade_check : Extract major, minor, and patch versions] ***\nWednesday 11 February 2026  00:50:46 +0000 (0:00:00.038)       0:00:20.676 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes_upgrade_check : Fail if we're jumping more than one minor version] ***\nWednesday 11 February 2026  00:50:46 +0000 (0:00:00.045)       0:00:20.721 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes_upgrade_check : Set fact if we need to upgrade] ***\nWednesday 11 February 2026  00:50:46 +0000 (0:00:00.037)       0:00:20.759 ****\nok: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nWednesday 11 February 2026  00:50:46 +0000 (0:00:00.053)       0:00:20.812 ****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nWednesday 11 February 2026  00:50:47 +0000 (0:00:00.406)       0:00:21.218 ****\nok: [controller] => {\n    \"msg\": \"https://cdn.dl.k8s.io/release/v1.34.0/bin/linux/amd64/kubeadm\"\n}\n\nTASK [vexxhost.containers.download_artifact : Download item] *******************\nWednesday 11 February 2026  00:50:47 +0000 (0:00:00.043)       0:00:21.261 ****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nWednesday 11 February 2026  00:50:47 +0000 (0:00:00.456)       0:00:21.718 ****\nskipping: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nWednesday 11 February 2026  00:50:47 +0000 (0:00:00.035)       0:00:21.754 ****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nWednesday 11 February 2026  00:50:48 +0000 (0:00:00.327)       0:00:22.081 ****\nok: [controller] => {\n    \"msg\": \"https://cdn.dl.k8s.io/release/v1.34.0/bin/linux/amd64/kubectl\"\n}\n\nTASK [vexxhost.containers.download_artifact : Download item] *******************\nWednesday 11 February 2026  00:50:48 +0000 (0:00:00.040)       0:00:22.122 ****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nWednesday 11 February 2026  00:50:48 +0000 (0:00:00.470)       0:00:22.593 ****\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Install SELinux packages] ***************\nWednesday 11 February 2026  00:50:48 +0000 (0:00:00.045)       0:00:22.639 ****\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Set SELinux to permissive at runtime] ***\nWednesday 11 February 2026  00:50:48 +0000 (0:00:00.026)       0:00:22.665 ****\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Persist SELinux permissive mode] ********\nWednesday 11 February 2026  00:50:48 +0000 (0:00:00.027)       0:00:22.692 ****\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Install AppArmor packages] **************\nWednesday 11 February 2026  00:50:48 +0000 (0:00:00.029)       0:00:22.722 ****\nok: [controller]\n\nTASK [vexxhost.containers.containerd : Create systemd service file for containerd] ***\nWednesday 11 February 2026  00:50:49 +0000 (0:00:00.905)       0:00:23.627 ****\nok: [controller]\n\nTASK [vexxhost.containers.containerd : Create folders for configuration] *******\nWednesday 11 February 2026  00:50:50 +0000 (0:00:00.681)       0:00:24.308 ****\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] **********\nWednesday 11 February 2026  00:50:52 +0000 (0:00:01.668)       0:00:25.976 ****\nok: [controller]\n\nTASK [vexxhost.containers.containerd : Force any restarts if necessary] ********\nWednesday 11 February 2026  00:50:52 +0000 (0:00:00.858)       0:00:26.835 ****\n\nTASK [vexxhost.containers.containerd : Enable and start service] ***************\nWednesday 11 February 2026  00:50:52 +0000 (0:00:00.007)       0:00:26.842 ****\nok: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nWednesday 11 February 2026  00:50:53 +0000 (0:00:00.594)       0:00:27.436 ****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nWednesday 11 February 2026  00:50:53 +0000 (0:00:00.330)       0:00:27.767 ****\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] *******************\nWednesday 11 February 2026  00:50:53 +0000 (0:00:00.081)       0:00:27.849 ****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nWednesday 11 February 2026  00:50:54 +0000 (0:00:00.485)       0:00:28.334 ****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nWednesday 11 February 2026  00:50:55 +0000 (0:00:01.478)       0:00:29.812 ****\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] *******************\nWednesday 11 February 2026  00:50:56 +0000 (0:00:00.083)       0:00:29.896 ****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nWednesday 11 February 2026  00:50:56 +0000 (0:00:00.498)       0:00:30.395 ****\nok: [controller]\n\nTASK [vexxhost.containers.cri_tools : Create crictl config] ********************\nWednesday 11 February 2026  00:50:58 +0000 (0:00:01.596)       0:00:31.991 ****\nok: [controller]\n\nTASK [vexxhost.containers.directory : Create directory (/opt/cni/bin)] *********\nWednesday 11 February 2026  00:50:58 +0000 (0:00:00.713)       0:00:32.704 ****\nok: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nWednesday 11 February 2026  00:50:59 +0000 (0:00:00.421)       0:00:33.126 ****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nWednesday 11 February 2026  00:50:59 +0000 (0:00:00.309)       0:00:33.436 ****\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] *******************\nWednesday 11 February 2026  00:50:59 +0000 (0:00:00.063)       0:00:33.500 ****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nWednesday 11 February 2026  00:51:00 +0000 (0:00:00.539)       0:00:34.040 ****\nok: [controller]\n\nTASK [vexxhost.containers.cni_plugins : Gather variables for each operating system] ***\nWednesday 11 February 2026  00:51:03 +0000 (0:00:03.423)       0:00:37.463 ****\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] ***********\nWednesday 11 February 2026  00:51:03 +0000 (0:00:00.084)       0:00:37.548 ****\nok: [controller]\n\nTASK [vexxhost.containers.cni_plugins : Ensure IPv6 is enabled] ****************\nWednesday 11 February 2026  00:51:04 +0000 (0:00:00.946)       0:00:38.494 ****\nok: [controller]\n\nTASK [vexxhost.containers.cni_plugins : Enable kernel modules on-boot] *********\nWednesday 11 February 2026  00:51:05 +0000 (0:00:00.552)       0:00:39.047 ****\nok: [controller]\n\nTASK [vexxhost.containers.cni_plugins : Enable kernel modules in runtime] ******\nWednesday 11 February 2026  00:51:05 +0000 (0:00:00.833)       0:00:39.880 ****\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] *********************\nWednesday 11 February 2026  00:51:07 +0000 (0:00:01.562)       0:00:41.443 ****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nWednesday 11 February 2026  00:51:07 +0000 (0:00:00.332)       0:00:41.775 ****\nok: [controller] => {\n    \"msg\": \"https://cdn.dl.k8s.io/release/v1.34.0/bin/linux/amd64/kubelet\"\n}\n\nTASK [vexxhost.containers.download_artifact : Download item] *******************\nWednesday 11 February 2026  00:51:07 +0000 (0:00:00.054)       0:00:41.829 ****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nWednesday 11 February 2026  00:51:08 +0000 (0:00:00.488)       0:00:42.318 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Gather variables for each operating system] ***\nWednesday 11 February 2026  00:51:08 +0000 (0:00:00.038)       0:00:42.356 ****\nok: [controller] => (item=/home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubelet/vars/debian.yml)\n\nTASK [vexxhost.kubernetes.kubelet : Install coreutils] *************************\nWednesday 11 February 2026  00:51:08 +0000 (0:00:00.057)       0:00:42.413 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Install additional packages] ***************\nWednesday 11 February 2026  00:51:08 +0000 (0:00:00.031)       0:00:42.445 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Configure sysctl values] *******************\nWednesday 11 February 2026  00:51:09 +0000 (0:00:00.893)       0:00:43.339 ****\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] ***\nWednesday 11 February 2026  00:51:11 +0000 (0:00:02.270)       0:00:45.610 ****\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] ********\nWednesday 11 February 2026  00:51:12 +0000 (0:00:00.967)       0:00:46.577 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Add kubeadm dropin for kubelet systemd service config] ***\nWednesday 11 February 2026  00:51:13 +0000 (0:00:00.704)       0:00:47.281 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Check swap status] *************************\nWednesday 11 February 2026  00:51:14 +0000 (0:00:00.730)       0:00:48.011 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Disable swap] ******************************\nWednesday 11 February 2026  00:51:14 +0000 (0:00:00.453)       0:00:48.465 ****\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] ***********\nWednesday 11 February 2026  00:51:14 +0000 (0:00:00.029)       0:00:48.495 ****\nok: [controller] => (item=swap)\nok: [controller] => (item=none)\n\nTASK [vexxhost.kubernetes.kubelet : Create noswap systemd service config file] ***\nWednesday 11 February 2026  00:51:15 +0000 (0:00:00.932)       0:00:49.427 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Enable noswap service] *********************\nWednesday 11 February 2026  00:51:16 +0000 (0:00:00.652)       0:00:50.080 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Force any restarts if necessary] ***********\nWednesday 11 February 2026  00:51:16 +0000 (0:00:00.489)       0:00:50.570 ****\n\nTASK [vexxhost.kubernetes.kubelet : Enable and start kubelet service] **********\nWednesday 11 February 2026  00:51:16 +0000 (0:00:00.005)       0:00:50.575 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Ensure availability of dbus on Debian] *****\nWednesday 11 February 2026  00:51:17 +0000 (0:00:00.485)       0:00:51.060 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Configure short hostname] ******************\nWednesday 11 February 2026  00:51:18 +0000 (0:00:00.923)       0:00:51.984 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Ensure hostname inside hosts file] *********\nWednesday 11 February 2026  00:51:19 +0000 (0:00:00.906)       0:00:52.890 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Remove kubernetes repository] ***********\nWednesday 11 February 2026  00:51:19 +0000 (0:00:00.408)       0:00:53.298 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Setup control plane] ********************\nWednesday 11 February 2026  00:51:19 +0000 (0:00:00.527)       0:00:53.826 ****\nincluded: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubernetes/tasks/control-plane.yml for controller\n\nTASK [vexxhost.kubernetes.kubernetes : Bootstrap cluster] **********************\nWednesday 11 February 2026  00:51:20 +0000 (0:00:00.080)       0:00:53.906 ****\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] ***\nWednesday 11 February 2026  00:51:20 +0000 (0:00:00.086)       0:00:53.992 ****\nok: [controller] => (item=controller)\n\nTASK [vexxhost.kubernetes.kubernetes : Pick node from pre-existing cluster] ****\nWednesday 11 February 2026  00:51:20 +0000 (0:00:00.311)       0:00:54.304 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Select first node to initialize cluster] ***\nWednesday 11 February 2026  00:51:20 +0000 (0:00:00.052)       0:00:54.357 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Print selected bootstrap node] **********\nWednesday 11 February 2026  00:51:20 +0000 (0:00:00.044)       0:00:54.401 ****\nok: [controller] => {\n    \"msg\": \"controller\"\n}\n\nTASK [vexxhost.kubernetes.kubernetes : Upload cluster configuration for bootstrap node] ***\nWednesday 11 February 2026  00:51:20 +0000 (0:00:00.042)       0:00:54.444 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create pki folder] **********************\nWednesday 11 February 2026  00:51:21 +0000 (0:00:00.663)       0:00:55.107 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create kubernetes ca key] ***************\nWednesday 11 February 2026  00:51:21 +0000 (0:00:00.033)       0:00:55.141 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create kubernetes ca cert] **************\nWednesday 11 February 2026  00:51:21 +0000 (0:00:00.026)       0:00:55.167 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create etcd-ca key] *********************\nWednesday 11 February 2026  00:51:21 +0000 (0:00:00.037)       0:00:55.205 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create etcd-ca cert] ********************\nWednesday 11 February 2026  00:51:21 +0000 (0:00:00.033)       0:00:55.239 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create front-proxy-ca key] **************\nWednesday 11 February 2026  00:51:21 +0000 (0:00:00.033)       0:00:55.273 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create front-proxy-ca cert] *************\nWednesday 11 February 2026  00:51:21 +0000 (0:00:00.036)       0:00:55.310 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Initialize cluster] *********************\nWednesday 11 February 2026  00:51:21 +0000 (0:00:00.031)       0:00:55.342 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Check if the node is already part of the cluster] ***\nWednesday 11 February 2026  00:51:21 +0000 (0:00:00.296)       0:00:55.638 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Join cluster] ***************************\nWednesday 11 February 2026  00:51:22 +0000 (0:00:00.298)       0:00:55.936 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create folder for admin configuration] ***\nWednesday 11 February 2026  00:51:22 +0000 (0:00:00.035)       0:00:55.972 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Creating a symlink for admin configuration file] ***\nWednesday 11 February 2026  00:51:22 +0000 (0:00:00.317)       0:00:56.290 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Add bash autocomplete for kubectl] ******\nWednesday 11 February 2026  00:51:22 +0000 (0:00:00.329)       0:00:56.620 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Install PIP] ****************************\nWednesday 11 February 2026  00:51:23 +0000 (0:00:00.300)       0:00:56.921 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Install Kubernetes Python package using pip on supported systems] ***\nWednesday 11 February 2026  00:51:23 +0000 (0:00:00.043)       0:00:56.965 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Enable EPEL repository] *****************\nWednesday 11 February 2026  00:51:23 +0000 (0:00:00.039)       0:00:57.004 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Install Kubernetes Python package using package manager on supported systems] ***\nWednesday 11 February 2026  00:51:23 +0000 (0:00:00.045)       0:00:57.050 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Allow workload on control plane node] ***\nWednesday 11 February 2026  00:51:24 +0000 (0:00:00.869)       0:00:57.920 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Remove kube-proxy resources] ************\nWednesday 11 February 2026  00:51:24 +0000 (0:00:00.845)       0:00:58.765 ****\nskipping: [controller] => (item=DaemonSet)\nskipping: [controller] => (item=ConfigMap)\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Start an upgrade] ***********************\nWednesday 11 February 2026  00:51:24 +0000 (0:00:00.043)       0:00:58.808 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Check if the Kubernetes API services is up to date] ***\nWednesday 11 February 2026  00:51:24 +0000 (0:00:00.043)       0:00:58.852 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Trigger an upgrade of the Kubernetes API services] ***\nWednesday 11 February 2026  00:51:25 +0000 (0:00:00.041)       0:00:58.894 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Setup nodes] ****************************\nWednesday 11 February 2026  00:51:25 +0000 (0:00:00.036)       0:00:58.931 ****\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Upgrade & restart Kubelet node for upgrade (if needed)] ***\nWednesday 11 February 2026  00:51:25 +0000 (0:00:00.033)       0:00:58.964 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Set node selector for CoreDNS components] ***\nWednesday 11 February 2026  00:51:25 +0000 (0:00:00.547)       0:00:59.511 ****\nok: [controller]\n\nPLAY [Install control-plane components] ****************************************\n\nTASK [Gathering Facts] *********************************************************\nWednesday 11 February 2026  00:51:26 +0000 (0:00:01.005)       0:01:00.517 ****\nok: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nWednesday 11 February 2026  00:51:27 +0000 (0:00:00.925)       0:01:01.442 ****\nok: [controller]\n\nTASK [vexxhost.containers.package : Update state for tar] **********************\nWednesday 11 February 2026  00:51:27 +0000 (0:00:00.327)       0:01:01.770 ****\nok: [controller]\n\nTASK [vexxhost.containers.directory : Create directory (/var/lib/downloads)] ***\nWednesday 11 February 2026  00:51:28 +0000 (0:00:00.893)       0:01:02.663 ****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nWednesday 11 February 2026  00:51:29 +0000 (0:00:00.302)       0:01:02.965 ****\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] *******************\nWednesday 11 February 2026  00:51:29 +0000 (0:00:00.044)       0:01:03.010 ****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nWednesday 11 February 2026  00:51:29 +0000 (0:00:00.447)       0:01:03.458 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.helm : Remove Helm repository] ***********************\nWednesday 11 February 2026  00:51:31 +0000 (0:00:02.098)       0:01:05.556 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.helm : Add bash autocomplete for helm] ***************\nWednesday 11 February 2026  00:51:32 +0000 (0:00:00.410)       0:01:05.967 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.helm : Get Helm plugins dir] *************************\nWednesday 11 February 2026  00:51:32 +0000 (0:00:00.310)       0:01:06.278 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.helm : Create Helm plugins directory if it does not exist] ***\nWednesday 11 February 2026  00:51:32 +0000 (0:00:00.340)       0:01:06.618 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.helm : Remove Helm diff plugin installed by kubernetes.core.helm_plugin] ***\nWednesday 11 February 2026  00:51:34 +0000 (0:00:01.302)       0:01:07.920 ****\nok: [controller]\n\nTASK [Install plugin] **********************************************************\nWednesday 11 February 2026  00:51:34 +0000 (0:00:00.324)       0:01:08.245 ****\nincluded: vexxhost.containers.download_artifact for controller\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nWednesday 11 February 2026  00:51:34 +0000 (0:00:00.056)       0:01:08.302 ****\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] *******************\nWednesday 11 February 2026  00:51:34 +0000 (0:00:00.046)       0:01:08.348 ****\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nWednesday 11 February 2026  00:51:34 +0000 (0:00:00.412)       0:01:08.761 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.upload_helm_chart : Include help chart upload method tasks] ***\nWednesday 11 February 2026  00:51:36 +0000 (0:00:01.684)       0:01:10.446 ****\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] ***************\nWednesday 11 February 2026  00:51:36 +0000 (0:00:00.089)       0:01:10.535 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.cilium : Get current Kubernetes version] *************\nWednesday 11 February 2026  00:51:37 +0000 (0:00:00.726)       0:01:11.262 ****\nok: [controller]\n\nTASK [vexxhost.kubernetes.cilium : Deploy Helm chart] **************************\nWednesday 11 February 2026  00:51:38 +0000 (0:00:00.921)       0:01:12.184 ****\nok: [controller]\n\nPLAY RECAP *********************************************************************\ncontroller                 : ok=113  changed=0    unreachable=0    failed=0    skipped=30   rescued=0    ignored=1\n\n\nTASKS RECAP ********************************************************************\nWednesday 11 February 2026  00:51:40 +0000 (0:00:02.234)       0:01:14.418 ****\n===============================================================================\nvexxhost.containers.download_artifact : Extract archive ----------------- 3.42s\nvexxhost.containers.download_artifact : Extract archive ----------------- 2.63s\nvexxhost.kubernetes.kubelet : Configure sysctl values ------------------- 2.27s\nvexxhost.kubernetes.cilium : Deploy Helm chart -------------------------- 2.23s\nvexxhost.containers.download_artifact : Extract archive ----------------- 2.10s\nGathering Facts --------------------------------------------------------- 1.83s\nvexxhost.containers.download_artifact : Extract archive ----------------- 1.68s\nvexxhost.containers.containerd : Create folders for configuration ------- 1.67s\nvexxhost.containers.containerd : Create folders for configuration ------- 1.60s\nvexxhost.containers.download_artifact : Extract archive ----------------- 1.60s\nvexxhost.containers.cni_plugins : Enable kernel modules in runtime ------ 1.56s\nvexxhost.kubernetes.kube_vip : Uninstall legacy HA stack ---------------- 1.52s\nvexxhost.containers.download_artifact : Extract archive ----------------- 1.48s\nvexxhost.kubernetes.helm : Create Helm plugins directory if it does not exist --- 1.30s\nvexxhost.kubernetes.kubernetes_upgrade_check : Retrieve the \"kubeadm-config\" ConfigMap --- 1.17s\nGathering Facts --------------------------------------------------------- 1.12s\nvexxhost.containers.package : Update state for tar ---------------------- 1.09s\nvexxhost.containers.containerd : Create systemd service file for containerd --- 1.08s\nvexxhost.containers.containerd : Install AppArmor packages -------------- 1.03s\nvexxhost.kubernetes.kubernetes : Set node selector for CoreDNS components --- 1.01s\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] *********************************************************\nWednesday 11 February 2026  00:51:41 +0000 (0:00:00.011)       0:00:00.011 ****\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] ****************************************************\nWednesday 11 February 2026  00:51:42 +0000 (0:00:01.248)       0:00:01.259 ****\nok: [controller]\n\nTASK [Make sure kubelet service is running] ************************************\nWednesday 11 February 2026  00:51:45 +0000 (0:00:03.152)       0:00:04.412 ****\nok: [controller] => {\n    \"changed\": false,\n    \"msg\": \"All assertions passed\"\n}\n\nTASK [Make sure kubelet service is enabled] ************************************\nWednesday 11 February 2026  00:51:45 +0000 (0:00:00.036)       0:00:04.448 ****\nok: [controller] => {\n    \"changed\": false,\n    \"msg\": \"All assertions passed\"\n}\n\nTASK [Get all nodes] ***********************************************************\nWednesday 11 February 2026  00:51:46 +0000 (0:00:00.036)       0:00:04.485 ****\nchanged: [controller]\n\nTASK [Print node list] *********************************************************\nWednesday 11 February 2026  00:51:46 +0000 (0:00:00.461)       0:00:04.946 ****\nok: [controller] => {\n    \"msg\": [\n        \"NAME         STATUS   ROLES           AGE    VERSION\",\n        \"controller   Ready    control-plane   118s   v1.34.0\"\n    ]\n}\n\nTASK [Assert no nody is not ready] *********************************************\nWednesday 11 February 2026  00:51:46 +0000 (0:00:00.033)       0:00:04.980 ****\nok: [controller] => {\n    \"changed\": false,\n    \"msg\": \"All assertions passed\"\n}\n\nPLAY [verify BGP] **************************************************************\n\nTASK [Gathering Facts] *********************************************************\nWednesday 11 February 2026  00:51:46 +0000 (0:00:00.038)       0:00:05.018 ****\nok: [controller]\n\nTASK [Get all nodes] ***********************************************************\nWednesday 11 February 2026  00:51:47 +0000 (0:00:00.933)       0:00:05.952 ****\nchanged: [controller]\n\nTASK [Print bgp neighbors received-routes] *************************************\nWednesday 11 February 2026  00:51:47 +0000 (0:00:00.332)       0:00:06.284 ****\nok: [controller] => {\n    \"msg\": [\n        \"BGP table version is 0, local router ID is 162.253.55.200, 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 ********************************************************************\nWednesday 11 February 2026  00:51:47 +0000 (0:00:00.027)       0:00:06.311 ****\n===============================================================================\nGather service facts ---------------------------------------------------- 3.15s\nGathering Facts --------------------------------------------------------- 1.25s\nGathering Facts --------------------------------------------------------- 0.93s\nGet all nodes ----------------------------------------------------------- 0.46s\nGet all nodes ----------------------------------------------------------- 0.33s\nAssert no nody is not ready --------------------------------------------- 0.04s\nMake sure kubelet service is enabled ------------------------------------ 0.04s\nMake sure kubelet service is running ------------------------------------ 0.04s\nPrint node list --------------------------------------------------------- 0.03s\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 cryptography (4.3MiB)",
                                "Downloading pygments (1.2MiB)",
                                "Downloading ansible-core (2.3MiB)",
                                " Downloading cryptography",
                                " Downloading pygments",
                                " Downloading ansible-core",
                                "Installed 36 packages in 48ms",
                                "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] *********************************************************",
                                "Wednesday 11 February 2026  00:47:23 +0000 (0:00:00.035)       0:00:00.035 ****",
                                "[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] *************************************************",
                                "Wednesday 11 February 2026  00:47:24 +0000 (0:00:01.388)       0:00:01.423 ****",
                                "ok: [controller]",
                                "",
                                "PLAY [Prepare BGP] *************************************************************",
                                "",
                                "TASK [Gathering Facts] *********************************************************",
                                "Wednesday 11 February 2026  00:47:31 +0000 (0:00:06.503)       0:00:07.927 ****",
                                "ok: [controller]",
                                "",
                                "TASK [Enable IP forwarding] ****************************************************",
                                "Wednesday 11 February 2026  00:47:32 +0000 (0:00:00.796)       0:00:08.723 ****",
                                "changed: [controller]",
                                "",
                                "TASK [Add FRR repository] ******************************************************",
                                "Wednesday 11 February 2026  00:47:32 +0000 (0:00:00.448)       0:00:09.172 ****",
                                "[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] ****************************************************",
                                "Wednesday 11 February 2026  00:47:38 +0000 (0:00:06.016)       0:00:15.188 ****",
                                "changed: [controller]",
                                "",
                                "TASK [Ensure bgpd is enabled] **************************************************",
                                "Wednesday 11 February 2026  00:47:47 +0000 (0:00:08.720)       0:00:23.909 ****",
                                "changed: [controller]",
                                "",
                                "TASK [Update FRR configuration] ************************************************",
                                "Wednesday 11 February 2026  00:47:47 +0000 (0:00:00.400)       0:00:24.309 ****",
                                "changed: [controller]",
                                "",
                                "TASK [Restart service frr] *****************************************************",
                                "Wednesday 11 February 2026  00:47:48 +0000 (0:00:00.957)       0:00:25.267 ****",
                                "changed: [controller]",
                                "",
                                "PLAY RECAP *********************************************************************",
                                "controller                 : ok=9    changed=6    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0",
                                "",
                                "",
                                "TASKS RECAP ********************************************************************",
                                "Wednesday 11 February 2026  00:47:54 +0000 (0:00:06.215)       0:00:31.482 ****",
                                "===============================================================================",
                                "Install frr packages ---------------------------------------------------- 8.72s",
                                "Install Debian packages ------------------------------------------------- 6.50s",
                                "Restart service frr ----------------------------------------------------- 6.22s",
                                "Add FRR repository ------------------------------------------------------ 6.02s",
                                "Gathering Facts --------------------------------------------------------- 1.39s",
                                "Update FRR configuration ------------------------------------------------ 0.96s",
                                "Gathering Facts --------------------------------------------------------- 0.80s",
                                "Enable IP forwarding ---------------------------------------------------- 0.45s",
                                "Ensure bgpd is enabled -------------------------------------------------- 0.40s",
                                "INFO     [bgp > prepare] Executed: Successful",
                                "INFO     [bgp > converge] Executing",
                                "",
                                "PLAY [Configure Kubernetes VIP] ************************************************",
                                "",
                                "TASK [Gathering Facts] *********************************************************",
                                "Wednesday 11 February 2026  00:47:56 +0000 (0:00:00.018)       0:00:00.018 ****",
                                "[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)] ***",
                                "Wednesday 11 February 2026  00:47:57 +0000 (0:00:00.984)       0:00:01.003 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Uninstall legacy HA stack] ****************",
                                "Wednesday 11 February 2026  00:47:57 +0000 (0:00:00.400)       0:00:01.404 ****",
                                "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] ****",
                                "Wednesday 11 February 2026  00:47:59 +0000 (0:00:01.386)       0:00:02.790 ****",
                                "[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] *********",
                                "Wednesday 11 February 2026  00:48:00 +0000 (0:00:00.977)       0:00:03.767 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Check if kubeadm has already run] *********",
                                "Wednesday 11 February 2026  00:48:00 +0000 (0:00:00.441)       0:00:04.209 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Set fact with KUBECONFIG path] ************",
                                "Wednesday 11 February 2026  00:48:00 +0000 (0:00:00.308)       0:00:04.517 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Set fact with KUBECONFIG path (with super-admin.conf)] ***",
                                "Wednesday 11 February 2026  00:48:00 +0000 (0:00:00.031)       0:00:04.548 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Upload Kubernetes manifest] ***************",
                                "Wednesday 11 February 2026  00:48:00 +0000 (0:00:00.032)       0:00:04.581 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Ensure kube-vip configuration file] *******",
                                "Wednesday 11 February 2026  00:48:01 +0000 (0:00:00.954)       0:00:05.535 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Flush handlers] ***************************",
                                "Wednesday 11 February 2026  00:48:02 +0000 (0:00:00.316)       0:00:05.852 ****",
                                "",
                                "PLAY [Install Kubernetes] ******************************************************",
                                "",
                                "TASK [Gathering Facts] *********************************************************",
                                "Wednesday 11 February 2026  00:48:02 +0000 (0:00:00.058)       0:00:05.911 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Wednesday 11 February 2026  00:48:02 +0000 (0:00:00.812)       0:00:06.724 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.package : Update state for tar] **********************",
                                "Wednesday 11 February 2026  00:48:03 +0000 (0:00:00.340)       0:00:07.064 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.directory : Create directory (/var/lib/downloads)] ***",
                                "Wednesday 11 February 2026  00:48:03 +0000 (0:00:00.037)       0:00:07.101 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Wednesday 11 February 2026  00:48:03 +0000 (0:00:00.321)       0:00:07.423 ****",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://github.com/opencontainers/runc/releases/download/v1.4.0/runc.amd64\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Wednesday 11 February 2026  00:48:03 +0000 (0:00:00.086)       0:00:07.509 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Wednesday 11 February 2026  00:48:04 +0000 (0:00:00.822)       0:00:08.332 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Wednesday 11 February 2026  00:48:04 +0000 (0:00:00.039)       0:00:08.371 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.package : Update state for tar] **********************",
                                "Wednesday 11 February 2026  00:48:04 +0000 (0:00:00.318)       0:00:08.689 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Wednesday 11 February 2026  00:48:05 +0000 (0:00:01.010)       0:00:09.700 ****",
                                "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] *******************",
                                "Wednesday 11 February 2026  00:48:06 +0000 (0:00:00.071)       0:00:09.771 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Wednesday 11 February 2026  00:48:07 +0000 (0:00:01.069)       0:00:10.840 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Install SELinux packages] ***************",
                                "Wednesday 11 February 2026  00:48:10 +0000 (0:00:03.212)       0:00:14.053 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Set SELinux to permissive at runtime] ***",
                                "Wednesday 11 February 2026  00:48:10 +0000 (0:00:00.028)       0:00:14.081 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Persist SELinux permissive mode] ********",
                                "Wednesday 11 February 2026  00:48:10 +0000 (0:00:00.028)       0:00:14.110 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Install AppArmor packages] **************",
                                "Wednesday 11 February 2026  00:48:10 +0000 (0:00:00.025)       0:00:14.135 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Create systemd service file for containerd] ***",
                                "Wednesday 11 February 2026  00:48:16 +0000 (0:00:06.511)       0:00:20.646 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Create folders for configuration] *******",
                                "Wednesday 11 February 2026  00:48:17 +0000 (0:00:00.605)       0:00:21.252 ****",
                                "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] **********",
                                "Wednesday 11 February 2026  00:48:18 +0000 (0:00:01.417)       0:00:22.669 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Force any restarts if necessary] ********",
                                "Wednesday 11 February 2026  00:48:19 +0000 (0:00:00.763)       0:00:23.433 ****",
                                "",
                                "RUNNING HANDLER [vexxhost.containers.containerd : Restart containerd] **********",
                                "Wednesday 11 February 2026  00:48:19 +0000 (0:00:00.006)       0:00:23.439 ****",
                                "changed: [controller]",
                                "",
                                "RUNNING HANDLER [vexxhost.kubernetes.kubelet : Reload systemd] *****************",
                                "Wednesday 11 February 2026  00:48:20 +0000 (0:00:00.875)       0:00:24.315 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Enable and start service] ***************",
                                "Wednesday 11 February 2026  00:48:22 +0000 (0:00:01.534)       0:00:25.850 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes_upgrade_check : Retrieve the \"kubeadm-config\" ConfigMap] ***",
                                "Wednesday 11 February 2026  00:48:23 +0000 (0:00:01.792)       0:00:27.643 ****",
                                "[ERROR]: Task failed: Module failed: Failed to import the required Python library (kubernetes) on np0000155225'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 np0000155225'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] ***",
                                "Wednesday 11 February 2026  00:48:24 +0000 (0:00:00.676)       0:00:28.319 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes_upgrade_check : Retrieve the current Kubernetes version] ***",
                                "Wednesday 11 February 2026  00:48:24 +0000 (0:00:00.035)       0:00:28.355 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes_upgrade_check : Extract major, minor, and patch versions] ***",
                                "Wednesday 11 February 2026  00:48:24 +0000 (0:00:00.031)       0:00:28.386 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes_upgrade_check : Fail if we're jumping more than one minor version] ***",
                                "Wednesday 11 February 2026  00:48:24 +0000 (0:00:00.042)       0:00:28.429 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes_upgrade_check : Set fact if we need to upgrade] ***",
                                "Wednesday 11 February 2026  00:48:24 +0000 (0:00:00.032)       0:00:28.461 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Wednesday 11 February 2026  00:48:24 +0000 (0:00:00.032)       0:00:28.494 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Wednesday 11 February 2026  00:48:25 +0000 (0:00:00.321)       0:00:28.815 ****",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://cdn.dl.k8s.io/release/v1.34.0/bin/linux/amd64/kubeadm\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Wednesday 11 February 2026  00:48:25 +0000 (0:00:00.098)       0:00:28.914 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Wednesday 11 February 2026  00:48:29 +0000 (0:00:04.195)       0:00:33.109 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Wednesday 11 February 2026  00:48:29 +0000 (0:00:00.040)       0:00:33.150 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Wednesday 11 February 2026  00:48:29 +0000 (0:00:00.322)       0:00:33.472 ****",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://cdn.dl.k8s.io/release/v1.34.0/bin/linux/amd64/kubectl\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Wednesday 11 February 2026  00:48:29 +0000 (0:00:00.046)       0:00:33.519 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Wednesday 11 February 2026  00:48:31 +0000 (0:00:02.018)       0:00:35.537 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Install SELinux packages] ***************",
                                "Wednesday 11 February 2026  00:48:31 +0000 (0:00:00.050)       0:00:35.588 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Set SELinux to permissive at runtime] ***",
                                "Wednesday 11 February 2026  00:48:31 +0000 (0:00:00.028)       0:00:35.616 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Persist SELinux permissive mode] ********",
                                "Wednesday 11 February 2026  00:48:31 +0000 (0:00:00.027)       0:00:35.644 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Install AppArmor packages] **************",
                                "Wednesday 11 February 2026  00:48:31 +0000 (0:00:00.032)       0:00:35.676 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Create systemd service file for containerd] ***",
                                "Wednesday 11 February 2026  00:48:32 +0000 (0:00:00.964)       0:00:36.640 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Create folders for configuration] *******",
                                "Wednesday 11 February 2026  00:48:33 +0000 (0:00:00.640)       0:00:37.281 ****",
                                "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] **********",
                                "Wednesday 11 February 2026  00:48:34 +0000 (0:00:01.402)       0:00:38.683 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Force any restarts if necessary] ********",
                                "Wednesday 11 February 2026  00:48:35 +0000 (0:00:00.803)       0:00:39.486 ****",
                                "",
                                "TASK [vexxhost.containers.containerd : Enable and start service] ***************",
                                "Wednesday 11 February 2026  00:48:35 +0000 (0:00:00.004)       0:00:39.491 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Wednesday 11 February 2026  00:48:36 +0000 (0:00:00.484)       0:00:39.976 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Wednesday 11 February 2026  00:48:36 +0000 (0:00:00.306)       0:00:40.282 ****",
                                "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] *******************",
                                "Wednesday 11 February 2026  00:48:36 +0000 (0:00:00.074)       0:00:40.357 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Wednesday 11 February 2026  00:48:37 +0000 (0:00:00.694)       0:00:41.051 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Wednesday 11 February 2026  00:48:39 +0000 (0:00:01.812)       0:00:42.863 ****",
                                "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] *******************",
                                "Wednesday 11 February 2026  00:48:39 +0000 (0:00:00.063)       0:00:42.927 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Wednesday 11 February 2026  00:48:46 +0000 (0:00:07.291)       0:00:50.219 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.cri_tools : Create crictl config] ********************",
                                "Wednesday 11 February 2026  00:48:48 +0000 (0:00:01.651)       0:00:51.870 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.directory : Create directory (/opt/cni/bin)] *********",
                                "Wednesday 11 February 2026  00:48:48 +0000 (0:00:00.659)       0:00:52.529 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Wednesday 11 February 2026  00:48:49 +0000 (0:00:00.319)       0:00:52.849 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Wednesday 11 February 2026  00:48:49 +0000 (0:00:00.299)       0:00:53.148 ****",
                                "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] *******************",
                                "Wednesday 11 February 2026  00:48:49 +0000 (0:00:00.078)       0:00:53.227 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Wednesday 11 February 2026  00:48:50 +0000 (0:00:00.992)       0:00:54.219 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.cni_plugins : Gather variables for each operating system] ***",
                                "Wednesday 11 February 2026  00:48:53 +0000 (0:00:02.908)       0:00:57.128 ****",
                                "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] ***********",
                                "Wednesday 11 February 2026  00:48:53 +0000 (0:00:00.062)       0:00:57.191 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.cni_plugins : Ensure IPv6 is enabled] ****************",
                                "Wednesday 11 February 2026  00:48:55 +0000 (0:00:02.469)       0:00:59.660 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.cni_plugins : Enable kernel modules on-boot] *********",
                                "Wednesday 11 February 2026  00:48:56 +0000 (0:00:00.450)       0:01:00.111 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.cni_plugins : Enable kernel modules in runtime] ******",
                                "Wednesday 11 February 2026  00:48:57 +0000 (0:00:00.678)       0:01:00.789 ****",
                                "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] *********************",
                                "Wednesday 11 February 2026  00:48:58 +0000 (0:00:01.485)       0:01:02.275 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Wednesday 11 February 2026  00:48:58 +0000 (0:00:00.298)       0:01:02.574 ****",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://cdn.dl.k8s.io/release/v1.34.0/bin/linux/amd64/kubelet\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Wednesday 11 February 2026  00:48:58 +0000 (0:00:00.045)       0:01:02.619 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Wednesday 11 February 2026  00:49:01 +0000 (0:00:02.173)       0:01:04.793 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Gather variables for each operating system] ***",
                                "Wednesday 11 February 2026  00:49:01 +0000 (0:00:00.029)       0:01:04.822 ****",
                                "ok: [controller] => (item=/home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubelet/vars/debian.yml)",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Install coreutils] *************************",
                                "Wednesday 11 February 2026  00:49:01 +0000 (0:00:00.056)       0:01:04.878 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Install additional packages] ***************",
                                "Wednesday 11 February 2026  00:49:01 +0000 (0:00:00.032)       0:01:04.911 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Configure sysctl values] *******************",
                                "Wednesday 11 February 2026  00:49:05 +0000 (0:00:04.472)       0:01:09.383 ****",
                                "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] ***",
                                "Wednesday 11 February 2026  00:49:08 +0000 (0:00:02.641)       0:01:12.025 ****",
                                "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] ********",
                                "Wednesday 11 February 2026  00:49:09 +0000 (0:00:00.830)       0:01:12.855 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Add kubeadm dropin for kubelet systemd service config] ***",
                                "Wednesday 11 February 2026  00:49:09 +0000 (0:00:00.645)       0:01:13.500 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Check swap status] *************************",
                                "Wednesday 11 February 2026  00:49:10 +0000 (0:00:00.659)       0:01:14.160 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Disable swap] ******************************",
                                "Wednesday 11 February 2026  00:49:10 +0000 (0:00:00.390)       0:01:14.551 ****",
                                "[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] ***********",
                                "Wednesday 11 February 2026  00:49:10 +0000 (0:00:00.036)       0:01:14.587 ****",
                                "ok: [controller] => (item=swap)",
                                "ok: [controller] => (item=none)",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Create noswap systemd service config file] ***",
                                "Wednesday 11 February 2026  00:49:11 +0000 (0:00:00.765)       0:01:15.353 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Enable noswap service] *********************",
                                "Wednesday 11 February 2026  00:49:12 +0000 (0:00:00.678)       0:01:16.031 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Force any restarts if necessary] ***********",
                                "Wednesday 11 February 2026  00:49:13 +0000 (0:00:01.048)       0:01:17.080 ****",
                                "",
                                "RUNNING HANDLER [vexxhost.kubernetes.kubelet : Reload systemd] *****************",
                                "Wednesday 11 February 2026  00:49:13 +0000 (0:00:00.008)       0:01:17.089 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Enable and start kubelet service] **********",
                                "Wednesday 11 February 2026  00:49:14 +0000 (0:00:01.576)       0:01:18.665 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Ensure availability of dbus on Debian] *****",
                                "Wednesday 11 February 2026  00:49:16 +0000 (0:00:01.770)       0:01:20.436 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Configure short hostname] ******************",
                                "Wednesday 11 February 2026  00:49:17 +0000 (0:00:00.887)       0:01:21.324 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Ensure hostname inside hosts file] *********",
                                "Wednesday 11 February 2026  00:49:18 +0000 (0:00:00.847)       0:01:22.171 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Remove kubernetes repository] ***********",
                                "Wednesday 11 February 2026  00:49:18 +0000 (0:00:00.422)       0:01:22.594 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Setup control plane] ********************",
                                "Wednesday 11 February 2026  00:49:19 +0000 (0:00:00.567)       0:01:23.161 ****",
                                "included: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubernetes/tasks/control-plane.yml for controller",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Bootstrap cluster] **********************",
                                "Wednesday 11 February 2026  00:49:19 +0000 (0:00:00.082)       0:01:23.244 ****",
                                "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] ***",
                                "Wednesday 11 February 2026  00:49:19 +0000 (0:00:00.083)       0:01:23.327 ****",
                                "ok: [controller] => (item=controller)",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Pick node from pre-existing cluster] ****",
                                "Wednesday 11 February 2026  00:49:19 +0000 (0:00:00.314)       0:01:23.641 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Select first node to initialize cluster] ***",
                                "Wednesday 11 February 2026  00:49:19 +0000 (0:00:00.041)       0:01:23.683 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Print selected bootstrap node] **********",
                                "Wednesday 11 February 2026  00:49:20 +0000 (0:00:00.052)       0:01:23.735 ****",
                                "ok: [controller] => {",
                                "    \"msg\": \"controller\"",
                                "}",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Upload cluster configuration for bootstrap node] ***",
                                "Wednesday 11 February 2026  00:49:20 +0000 (0:00:00.040)       0:01:23.776 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create pki folder] **********************",
                                "Wednesday 11 February 2026  00:49:20 +0000 (0:00:00.685)       0:01:24.461 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create kubernetes ca key] ***************",
                                "Wednesday 11 February 2026  00:49:20 +0000 (0:00:00.031)       0:01:24.493 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create kubernetes ca cert] **************",
                                "Wednesday 11 February 2026  00:49:20 +0000 (0:00:00.038)       0:01:24.531 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create etcd-ca key] *********************",
                                "Wednesday 11 February 2026  00:49:20 +0000 (0:00:00.031)       0:01:24.563 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create etcd-ca cert] ********************",
                                "Wednesday 11 February 2026  00:49:20 +0000 (0:00:00.031)       0:01:24.595 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create front-proxy-ca key] **************",
                                "Wednesday 11 February 2026  00:49:20 +0000 (0:00:00.028)       0:01:24.623 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create front-proxy-ca cert] *************",
                                "Wednesday 11 February 2026  00:49:20 +0000 (0:00:00.034)       0:01:24.658 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Initialize cluster] *********************",
                                "Wednesday 11 February 2026  00:49:20 +0000 (0:00:00.035)       0:01:24.694 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Check if the node is already part of the cluster] ***",
                                "Wednesday 11 February 2026  00:49:52 +0000 (0:00:31.743)       0:01:56.437 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Join cluster] ***************************",
                                "Wednesday 11 February 2026  00:49:53 +0000 (0:00:00.364)       0:01:56.802 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create folder for admin configuration] ***",
                                "Wednesday 11 February 2026  00:49:53 +0000 (0:00:00.039)       0:01:56.842 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Creating a symlink for admin configuration file] ***",
                                "Wednesday 11 February 2026  00:49:53 +0000 (0:00:00.402)       0:01:57.245 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Add bash autocomplete for kubectl] ******",
                                "Wednesday 11 February 2026  00:49:53 +0000 (0:00:00.339)       0:01:57.584 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Install PIP] ****************************",
                                "Wednesday 11 February 2026  00:49:54 +0000 (0:00:00.305)       0:01:57.890 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Install Kubernetes Python package using pip on supported systems] ***",
                                "Wednesday 11 February 2026  00:49:54 +0000 (0:00:00.042)       0:01:57.933 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Enable EPEL repository] *****************",
                                "Wednesday 11 February 2026  00:49:54 +0000 (0:00:00.037)       0:01:57.971 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Install Kubernetes Python package using package manager on supported systems] ***",
                                "Wednesday 11 February 2026  00:49:54 +0000 (0:00:00.047)       0:01:58.019 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Allow workload on control plane node] ***",
                                "Wednesday 11 February 2026  00:50:05 +0000 (0:00:11.415)       0:02:09.434 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Remove kube-proxy resources] ************",
                                "Wednesday 11 February 2026  00:50:06 +0000 (0:00:01.102)       0:02:10.536 ****",
                                "skipping: [controller] => (item=DaemonSet)",
                                "skipping: [controller] => (item=ConfigMap)",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Start an upgrade] ***********************",
                                "Wednesday 11 February 2026  00:50:06 +0000 (0:00:00.041)       0:02:10.578 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Check if the Kubernetes API services is up to date] ***",
                                "Wednesday 11 February 2026  00:50:06 +0000 (0:00:00.038)       0:02:10.616 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Trigger an upgrade of the Kubernetes API services] ***",
                                "Wednesday 11 February 2026  00:50:06 +0000 (0:00:00.029)       0:02:10.646 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Setup nodes] ****************************",
                                "Wednesday 11 February 2026  00:50:06 +0000 (0:00:00.032)       0:02:10.678 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Upgrade & restart Kubelet node for upgrade (if needed)] ***",
                                "Wednesday 11 February 2026  00:50:06 +0000 (0:00:00.030)       0:02:10.709 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Set node selector for CoreDNS components] ***",
                                "Wednesday 11 February 2026  00:50:07 +0000 (0:00:00.599)       0:02:11.308 ****",
                                "changed: [controller]",
                                "",
                                "PLAY [Install control-plane components] ****************************************",
                                "",
                                "TASK [Gathering Facts] *********************************************************",
                                "Wednesday 11 February 2026  00:50:09 +0000 (0:00:01.456)       0:02:12.765 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Wednesday 11 February 2026  00:50:09 +0000 (0:00:00.923)       0:02:13.688 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.package : Update state for tar] **********************",
                                "Wednesday 11 February 2026  00:50:10 +0000 (0:00:00.326)       0:02:14.015 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.directory : Create directory (/var/lib/downloads)] ***",
                                "Wednesday 11 February 2026  00:50:11 +0000 (0:00:00.940)       0:02:14.955 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Wednesday 11 February 2026  00:50:11 +0000 (0:00:00.346)       0:02:15.302 ****",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://get.helm.sh/helm-v3.11.2-linux-amd64.tar.gz\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Wednesday 11 February 2026  00:50:11 +0000 (0:00:00.046)       0:02:15.349 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Wednesday 11 February 2026  00:50:12 +0000 (0:00:00.693)       0:02:16.043 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.helm : Remove Helm repository] ***********************",
                                "Wednesday 11 February 2026  00:50:14 +0000 (0:00:01.938)       0:02:17.981 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.helm : Add bash autocomplete for helm] ***************",
                                "Wednesday 11 February 2026  00:50:14 +0000 (0:00:00.439)       0:02:18.420 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.helm : Get Helm plugins dir] *************************",
                                "Wednesday 11 February 2026  00:50:15 +0000 (0:00:00.330)       0:02:18.750 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.helm : Create Helm plugins directory if it does not exist] ***",
                                "Wednesday 11 February 2026  00:50:15 +0000 (0:00:00.468)       0:02:19.219 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.helm : Remove Helm diff plugin installed by kubernetes.core.helm_plugin] ***",
                                "Wednesday 11 February 2026  00:50:15 +0000 (0:00:00.319)       0:02:19.538 ****",
                                "ok: [controller]",
                                "",
                                "TASK [Install plugin] **********************************************************",
                                "Wednesday 11 February 2026  00:50:16 +0000 (0:00:00.322)       0:02:19.861 ****",
                                "included: vexxhost.containers.download_artifact for controller",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Wednesday 11 February 2026  00:50:16 +0000 (0:00:00.070)       0:02:19.931 ****",
                                "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] *******************",
                                "Wednesday 11 February 2026  00:50:16 +0000 (0:00:00.039)       0:02:19.971 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Wednesday 11 February 2026  00:50:17 +0000 (0:00:00.761)       0:02:20.732 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.upload_helm_chart : Include help chart upload method tasks] ***",
                                "Wednesday 11 February 2026  00:50:19 +0000 (0:00:02.234)       0:02:22.967 ****",
                                "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] ***************",
                                "Wednesday 11 February 2026  00:50:19 +0000 (0:00:00.094)       0:02:23.062 ****",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.cilium : Get current Kubernetes version] *************",
                                "Wednesday 11 February 2026  00:50:20 +0000 (0:00:00.831)       0:02:23.893 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.cilium : Deploy Helm chart] **************************",
                                "Wednesday 11 February 2026  00:50:21 +0000 (0:00:01.025)       0:02:24.918 ****",
                                "changed: [controller]",
                                "",
                                "PLAY RECAP *********************************************************************",
                                "controller                 : ok=112  changed=52   unreachable=0    failed=0    skipped=34   rescued=0    ignored=3",
                                "",
                                "",
                                "TASKS RECAP ********************************************************************",
                                "Wednesday 11 February 2026  00:50:24 +0000 (0:00:03.298)       0:02:28.217 ****",
                                "===============================================================================",
                                "vexxhost.kubernetes.kubernetes : Initialize cluster -------------------- 31.74s",
                                "vexxhost.kubernetes.kubernetes : Install Kubernetes Python package using package manager on supported systems -- 11.42s",
                                "vexxhost.containers.download_artifact : Download item ------------------- 7.29s",
                                "vexxhost.containers.containerd : Install AppArmor packages -------------- 6.51s",
                                "vexxhost.kubernetes.kubelet : Install additional packages --------------- 4.47s",
                                "vexxhost.containers.download_artifact : Download item ------------------- 4.20s",
                                "vexxhost.kubernetes.cilium : Deploy Helm chart -------------------------- 3.30s",
                                "vexxhost.containers.download_artifact : Extract archive ----------------- 3.21s",
                                "vexxhost.kubernetes.kubelet : Reload systemd ---------------------------- 3.11s",
                                "vexxhost.containers.download_artifact : Extract archive ----------------- 2.91s",
                                "vexxhost.kubernetes.kubelet : Configure sysctl values ------------------- 2.64s",
                                "vexxhost.containers.cni_plugins : Install additional packages ----------- 2.47s",
                                "vexxhost.containers.download_artifact : Extract archive ----------------- 2.23s",
                                "vexxhost.containers.download_artifact : Download item ------------------- 2.17s",
                                "vexxhost.containers.download_artifact : Download item ------------------- 2.02s",
                                "vexxhost.containers.download_artifact : Extract archive ----------------- 1.94s",
                                "vexxhost.containers.download_artifact : Extract archive ----------------- 1.81s",
                                "vexxhost.containers.containerd : Enable and start service --------------- 1.79s",
                                "vexxhost.kubernetes.kubelet : Enable and start kubelet service ---------- 1.77s",
                                "vexxhost.containers.download_artifact : Extract archive ----------------- 1.65s",
                                "INFO     [bgp > converge] Executed: Successful",
                                "INFO     [bgp > idempotence] Executing",
                                "",
                                "PLAY [Configure Kubernetes VIP] ************************************************",
                                "",
                                "TASK [Gathering Facts] *********************************************************",
                                "Wednesday 11 February 2026  00:50:26 +0000 (0:00:00.018)       0:00:00.018 ****",
                                "[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)] ***",
                                "Wednesday 11 February 2026  00:50:27 +0000 (0:00:01.123)       0:00:01.141 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Uninstall legacy HA stack] ****************",
                                "Wednesday 11 February 2026  00:50:27 +0000 (0:00:00.429)       0:00:01.570 ****",
                                "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] ****",
                                "Wednesday 11 February 2026  00:50:29 +0000 (0:00:01.521)       0:00:03.092 ****",
                                "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] *********",
                                "Wednesday 11 February 2026  00:50:30 +0000 (0:00:00.958)       0:00:04.050 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Check if kubeadm has already run] *********",
                                "Wednesday 11 February 2026  00:50:30 +0000 (0:00:00.438)       0:00:04.489 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Set fact with KUBECONFIG path] ************",
                                "Wednesday 11 February 2026  00:50:30 +0000 (0:00:00.366)       0:00:04.856 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Set fact with KUBECONFIG path (with super-admin.conf)] ***",
                                "Wednesday 11 February 2026  00:50:30 +0000 (0:00:00.026)       0:00:04.882 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Upload Kubernetes manifest] ***************",
                                "Wednesday 11 February 2026  00:50:31 +0000 (0:00:00.040)       0:00:04.922 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Ensure kube-vip configuration file] *******",
                                "Wednesday 11 February 2026  00:50:31 +0000 (0:00:00.919)       0:00:05.842 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Flush handlers] ***************************",
                                "Wednesday 11 February 2026  00:50:32 +0000 (0:00:00.304)       0:00:06.147 ****",
                                "",
                                "PLAY [Install Kubernetes] ******************************************************",
                                "",
                                "TASK [Gathering Facts] *********************************************************",
                                "Wednesday 11 February 2026  00:50:32 +0000 (0:00:00.063)       0:00:06.211 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Wednesday 11 February 2026  00:50:34 +0000 (0:00:01.830)       0:00:08.041 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.package : Update state for tar] **********************",
                                "Wednesday 11 February 2026  00:50:34 +0000 (0:00:00.361)       0:00:08.403 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.directory : Create directory (/var/lib/downloads)] ***",
                                "Wednesday 11 February 2026  00:50:34 +0000 (0:00:00.035)       0:00:08.439 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Wednesday 11 February 2026  00:50:34 +0000 (0:00:00.317)       0:00:08.756 ****",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://github.com/opencontainers/runc/releases/download/v1.4.0/runc.amd64\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Wednesday 11 February 2026  00:50:34 +0000 (0:00:00.073)       0:00:08.830 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Wednesday 11 February 2026  00:50:35 +0000 (0:00:00.576)       0:00:09.407 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Wednesday 11 February 2026  00:50:35 +0000 (0:00:00.044)       0:00:09.451 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.package : Update state for tar] **********************",
                                "Wednesday 11 February 2026  00:50:35 +0000 (0:00:00.312)       0:00:09.764 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Wednesday 11 February 2026  00:50:36 +0000 (0:00:01.094)       0:00:10.858 ****",
                                "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] *******************",
                                "Wednesday 11 February 2026  00:50:37 +0000 (0:00:00.072)       0:00:10.931 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Wednesday 11 February 2026  00:50:37 +0000 (0:00:00.495)       0:00:11.426 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Install SELinux packages] ***************",
                                "Wednesday 11 February 2026  00:50:40 +0000 (0:00:02.631)       0:00:14.057 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Set SELinux to permissive at runtime] ***",
                                "Wednesday 11 February 2026  00:50:40 +0000 (0:00:00.025)       0:00:14.082 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Persist SELinux permissive mode] ********",
                                "Wednesday 11 February 2026  00:50:40 +0000 (0:00:00.031)       0:00:14.114 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Install AppArmor packages] **************",
                                "Wednesday 11 February 2026  00:50:40 +0000 (0:00:00.032)       0:00:14.146 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Create systemd service file for containerd] ***",
                                "Wednesday 11 February 2026  00:50:41 +0000 (0:00:01.032)       0:00:15.179 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Create folders for configuration] *******",
                                "Wednesday 11 February 2026  00:50:42 +0000 (0:00:01.082)       0:00:16.262 ****",
                                "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] **********",
                                "Wednesday 11 February 2026  00:50:43 +0000 (0:00:01.604)       0:00:17.867 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Force any restarts if necessary] ********",
                                "Wednesday 11 February 2026  00:50:44 +0000 (0:00:00.741)       0:00:18.608 ****",
                                "",
                                "TASK [vexxhost.containers.containerd : Enable and start service] ***************",
                                "Wednesday 11 February 2026  00:50:44 +0000 (0:00:00.006)       0:00:18.615 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes_upgrade_check : Retrieve the \"kubeadm-config\" ConfigMap] ***",
                                "Wednesday 11 February 2026  00:50:45 +0000 (0:00:00.802)       0:00:19.417 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes_upgrade_check : Parse the ClusterConfiguration] ***",
                                "Wednesday 11 February 2026  00:50:46 +0000 (0:00:01.173)       0:00:20.591 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes_upgrade_check : Retrieve the current Kubernetes version] ***",
                                "Wednesday 11 February 2026  00:50:46 +0000 (0:00:00.046)       0:00:20.637 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes_upgrade_check : Extract major, minor, and patch versions] ***",
                                "Wednesday 11 February 2026  00:50:46 +0000 (0:00:00.038)       0:00:20.676 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes_upgrade_check : Fail if we're jumping more than one minor version] ***",
                                "Wednesday 11 February 2026  00:50:46 +0000 (0:00:00.045)       0:00:20.721 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes_upgrade_check : Set fact if we need to upgrade] ***",
                                "Wednesday 11 February 2026  00:50:46 +0000 (0:00:00.037)       0:00:20.759 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Wednesday 11 February 2026  00:50:46 +0000 (0:00:00.053)       0:00:20.812 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Wednesday 11 February 2026  00:50:47 +0000 (0:00:00.406)       0:00:21.218 ****",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://cdn.dl.k8s.io/release/v1.34.0/bin/linux/amd64/kubeadm\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Wednesday 11 February 2026  00:50:47 +0000 (0:00:00.043)       0:00:21.261 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Wednesday 11 February 2026  00:50:47 +0000 (0:00:00.456)       0:00:21.718 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Wednesday 11 February 2026  00:50:47 +0000 (0:00:00.035)       0:00:21.754 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Wednesday 11 February 2026  00:50:48 +0000 (0:00:00.327)       0:00:22.081 ****",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://cdn.dl.k8s.io/release/v1.34.0/bin/linux/amd64/kubectl\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Wednesday 11 February 2026  00:50:48 +0000 (0:00:00.040)       0:00:22.122 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Wednesday 11 February 2026  00:50:48 +0000 (0:00:00.470)       0:00:22.593 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Install SELinux packages] ***************",
                                "Wednesday 11 February 2026  00:50:48 +0000 (0:00:00.045)       0:00:22.639 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Set SELinux to permissive at runtime] ***",
                                "Wednesday 11 February 2026  00:50:48 +0000 (0:00:00.026)       0:00:22.665 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Persist SELinux permissive mode] ********",
                                "Wednesday 11 February 2026  00:50:48 +0000 (0:00:00.027)       0:00:22.692 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Install AppArmor packages] **************",
                                "Wednesday 11 February 2026  00:50:48 +0000 (0:00:00.029)       0:00:22.722 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Create systemd service file for containerd] ***",
                                "Wednesday 11 February 2026  00:50:49 +0000 (0:00:00.905)       0:00:23.627 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Create folders for configuration] *******",
                                "Wednesday 11 February 2026  00:50:50 +0000 (0:00:00.681)       0:00:24.308 ****",
                                "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] **********",
                                "Wednesday 11 February 2026  00:50:52 +0000 (0:00:01.668)       0:00:25.976 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Force any restarts if necessary] ********",
                                "Wednesday 11 February 2026  00:50:52 +0000 (0:00:00.858)       0:00:26.835 ****",
                                "",
                                "TASK [vexxhost.containers.containerd : Enable and start service] ***************",
                                "Wednesday 11 February 2026  00:50:52 +0000 (0:00:00.007)       0:00:26.842 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Wednesday 11 February 2026  00:50:53 +0000 (0:00:00.594)       0:00:27.436 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Wednesday 11 February 2026  00:50:53 +0000 (0:00:00.330)       0:00:27.767 ****",
                                "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] *******************",
                                "Wednesday 11 February 2026  00:50:53 +0000 (0:00:00.081)       0:00:27.849 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Wednesday 11 February 2026  00:50:54 +0000 (0:00:00.485)       0:00:28.334 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Wednesday 11 February 2026  00:50:55 +0000 (0:00:01.478)       0:00:29.812 ****",
                                "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] *******************",
                                "Wednesday 11 February 2026  00:50:56 +0000 (0:00:00.083)       0:00:29.896 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Wednesday 11 February 2026  00:50:56 +0000 (0:00:00.498)       0:00:30.395 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.cri_tools : Create crictl config] ********************",
                                "Wednesday 11 February 2026  00:50:58 +0000 (0:00:01.596)       0:00:31.991 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.directory : Create directory (/opt/cni/bin)] *********",
                                "Wednesday 11 February 2026  00:50:58 +0000 (0:00:00.713)       0:00:32.704 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Wednesday 11 February 2026  00:50:59 +0000 (0:00:00.421)       0:00:33.126 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Wednesday 11 February 2026  00:50:59 +0000 (0:00:00.309)       0:00:33.436 ****",
                                "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] *******************",
                                "Wednesday 11 February 2026  00:50:59 +0000 (0:00:00.063)       0:00:33.500 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Wednesday 11 February 2026  00:51:00 +0000 (0:00:00.539)       0:00:34.040 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.cni_plugins : Gather variables for each operating system] ***",
                                "Wednesday 11 February 2026  00:51:03 +0000 (0:00:03.423)       0:00:37.463 ****",
                                "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] ***********",
                                "Wednesday 11 February 2026  00:51:03 +0000 (0:00:00.084)       0:00:37.548 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.cni_plugins : Ensure IPv6 is enabled] ****************",
                                "Wednesday 11 February 2026  00:51:04 +0000 (0:00:00.946)       0:00:38.494 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.cni_plugins : Enable kernel modules on-boot] *********",
                                "Wednesday 11 February 2026  00:51:05 +0000 (0:00:00.552)       0:00:39.047 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.cni_plugins : Enable kernel modules in runtime] ******",
                                "Wednesday 11 February 2026  00:51:05 +0000 (0:00:00.833)       0:00:39.880 ****",
                                "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] *********************",
                                "Wednesday 11 February 2026  00:51:07 +0000 (0:00:01.562)       0:00:41.443 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Wednesday 11 February 2026  00:51:07 +0000 (0:00:00.332)       0:00:41.775 ****",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://cdn.dl.k8s.io/release/v1.34.0/bin/linux/amd64/kubelet\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Wednesday 11 February 2026  00:51:07 +0000 (0:00:00.054)       0:00:41.829 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Wednesday 11 February 2026  00:51:08 +0000 (0:00:00.488)       0:00:42.318 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Gather variables for each operating system] ***",
                                "Wednesday 11 February 2026  00:51:08 +0000 (0:00:00.038)       0:00:42.356 ****",
                                "ok: [controller] => (item=/home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubelet/vars/debian.yml)",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Install coreutils] *************************",
                                "Wednesday 11 February 2026  00:51:08 +0000 (0:00:00.057)       0:00:42.413 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Install additional packages] ***************",
                                "Wednesday 11 February 2026  00:51:08 +0000 (0:00:00.031)       0:00:42.445 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Configure sysctl values] *******************",
                                "Wednesday 11 February 2026  00:51:09 +0000 (0:00:00.893)       0:00:43.339 ****",
                                "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] ***",
                                "Wednesday 11 February 2026  00:51:11 +0000 (0:00:02.270)       0:00:45.610 ****",
                                "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] ********",
                                "Wednesday 11 February 2026  00:51:12 +0000 (0:00:00.967)       0:00:46.577 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Add kubeadm dropin for kubelet systemd service config] ***",
                                "Wednesday 11 February 2026  00:51:13 +0000 (0:00:00.704)       0:00:47.281 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Check swap status] *************************",
                                "Wednesday 11 February 2026  00:51:14 +0000 (0:00:00.730)       0:00:48.011 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Disable swap] ******************************",
                                "Wednesday 11 February 2026  00:51:14 +0000 (0:00:00.453)       0:00:48.465 ****",
                                "[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] ***********",
                                "Wednesday 11 February 2026  00:51:14 +0000 (0:00:00.029)       0:00:48.495 ****",
                                "ok: [controller] => (item=swap)",
                                "ok: [controller] => (item=none)",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Create noswap systemd service config file] ***",
                                "Wednesday 11 February 2026  00:51:15 +0000 (0:00:00.932)       0:00:49.427 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Enable noswap service] *********************",
                                "Wednesday 11 February 2026  00:51:16 +0000 (0:00:00.652)       0:00:50.080 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Force any restarts if necessary] ***********",
                                "Wednesday 11 February 2026  00:51:16 +0000 (0:00:00.489)       0:00:50.570 ****",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Enable and start kubelet service] **********",
                                "Wednesday 11 February 2026  00:51:16 +0000 (0:00:00.005)       0:00:50.575 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Ensure availability of dbus on Debian] *****",
                                "Wednesday 11 February 2026  00:51:17 +0000 (0:00:00.485)       0:00:51.060 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Configure short hostname] ******************",
                                "Wednesday 11 February 2026  00:51:18 +0000 (0:00:00.923)       0:00:51.984 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Ensure hostname inside hosts file] *********",
                                "Wednesday 11 February 2026  00:51:19 +0000 (0:00:00.906)       0:00:52.890 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Remove kubernetes repository] ***********",
                                "Wednesday 11 February 2026  00:51:19 +0000 (0:00:00.408)       0:00:53.298 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Setup control plane] ********************",
                                "Wednesday 11 February 2026  00:51:19 +0000 (0:00:00.527)       0:00:53.826 ****",
                                "included: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubernetes/tasks/control-plane.yml for controller",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Bootstrap cluster] **********************",
                                "Wednesday 11 February 2026  00:51:20 +0000 (0:00:00.080)       0:00:53.906 ****",
                                "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] ***",
                                "Wednesday 11 February 2026  00:51:20 +0000 (0:00:00.086)       0:00:53.992 ****",
                                "ok: [controller] => (item=controller)",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Pick node from pre-existing cluster] ****",
                                "Wednesday 11 February 2026  00:51:20 +0000 (0:00:00.311)       0:00:54.304 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Select first node to initialize cluster] ***",
                                "Wednesday 11 February 2026  00:51:20 +0000 (0:00:00.052)       0:00:54.357 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Print selected bootstrap node] **********",
                                "Wednesday 11 February 2026  00:51:20 +0000 (0:00:00.044)       0:00:54.401 ****",
                                "ok: [controller] => {",
                                "    \"msg\": \"controller\"",
                                "}",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Upload cluster configuration for bootstrap node] ***",
                                "Wednesday 11 February 2026  00:51:20 +0000 (0:00:00.042)       0:00:54.444 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create pki folder] **********************",
                                "Wednesday 11 February 2026  00:51:21 +0000 (0:00:00.663)       0:00:55.107 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create kubernetes ca key] ***************",
                                "Wednesday 11 February 2026  00:51:21 +0000 (0:00:00.033)       0:00:55.141 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create kubernetes ca cert] **************",
                                "Wednesday 11 February 2026  00:51:21 +0000 (0:00:00.026)       0:00:55.167 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create etcd-ca key] *********************",
                                "Wednesday 11 February 2026  00:51:21 +0000 (0:00:00.037)       0:00:55.205 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create etcd-ca cert] ********************",
                                "Wednesday 11 February 2026  00:51:21 +0000 (0:00:00.033)       0:00:55.239 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create front-proxy-ca key] **************",
                                "Wednesday 11 February 2026  00:51:21 +0000 (0:00:00.033)       0:00:55.273 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create front-proxy-ca cert] *************",
                                "Wednesday 11 February 2026  00:51:21 +0000 (0:00:00.036)       0:00:55.310 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Initialize cluster] *********************",
                                "Wednesday 11 February 2026  00:51:21 +0000 (0:00:00.031)       0:00:55.342 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Check if the node is already part of the cluster] ***",
                                "Wednesday 11 February 2026  00:51:21 +0000 (0:00:00.296)       0:00:55.638 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Join cluster] ***************************",
                                "Wednesday 11 February 2026  00:51:22 +0000 (0:00:00.298)       0:00:55.936 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create folder for admin configuration] ***",
                                "Wednesday 11 February 2026  00:51:22 +0000 (0:00:00.035)       0:00:55.972 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Creating a symlink for admin configuration file] ***",
                                "Wednesday 11 February 2026  00:51:22 +0000 (0:00:00.317)       0:00:56.290 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Add bash autocomplete for kubectl] ******",
                                "Wednesday 11 February 2026  00:51:22 +0000 (0:00:00.329)       0:00:56.620 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Install PIP] ****************************",
                                "Wednesday 11 February 2026  00:51:23 +0000 (0:00:00.300)       0:00:56.921 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Install Kubernetes Python package using pip on supported systems] ***",
                                "Wednesday 11 February 2026  00:51:23 +0000 (0:00:00.043)       0:00:56.965 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Enable EPEL repository] *****************",
                                "Wednesday 11 February 2026  00:51:23 +0000 (0:00:00.039)       0:00:57.004 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Install Kubernetes Python package using package manager on supported systems] ***",
                                "Wednesday 11 February 2026  00:51:23 +0000 (0:00:00.045)       0:00:57.050 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Allow workload on control plane node] ***",
                                "Wednesday 11 February 2026  00:51:24 +0000 (0:00:00.869)       0:00:57.920 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Remove kube-proxy resources] ************",
                                "Wednesday 11 February 2026  00:51:24 +0000 (0:00:00.845)       0:00:58.765 ****",
                                "skipping: [controller] => (item=DaemonSet)",
                                "skipping: [controller] => (item=ConfigMap)",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Start an upgrade] ***********************",
                                "Wednesday 11 February 2026  00:51:24 +0000 (0:00:00.043)       0:00:58.808 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Check if the Kubernetes API services is up to date] ***",
                                "Wednesday 11 February 2026  00:51:24 +0000 (0:00:00.043)       0:00:58.852 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Trigger an upgrade of the Kubernetes API services] ***",
                                "Wednesday 11 February 2026  00:51:25 +0000 (0:00:00.041)       0:00:58.894 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Setup nodes] ****************************",
                                "Wednesday 11 February 2026  00:51:25 +0000 (0:00:00.036)       0:00:58.931 ****",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Upgrade & restart Kubelet node for upgrade (if needed)] ***",
                                "Wednesday 11 February 2026  00:51:25 +0000 (0:00:00.033)       0:00:58.964 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Set node selector for CoreDNS components] ***",
                                "Wednesday 11 February 2026  00:51:25 +0000 (0:00:00.547)       0:00:59.511 ****",
                                "ok: [controller]",
                                "",
                                "PLAY [Install control-plane components] ****************************************",
                                "",
                                "TASK [Gathering Facts] *********************************************************",
                                "Wednesday 11 February 2026  00:51:26 +0000 (0:00:01.005)       0:01:00.517 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Wednesday 11 February 2026  00:51:27 +0000 (0:00:00.925)       0:01:01.442 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.package : Update state for tar] **********************",
                                "Wednesday 11 February 2026  00:51:27 +0000 (0:00:00.327)       0:01:01.770 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.directory : Create directory (/var/lib/downloads)] ***",
                                "Wednesday 11 February 2026  00:51:28 +0000 (0:00:00.893)       0:01:02.663 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Wednesday 11 February 2026  00:51:29 +0000 (0:00:00.302)       0:01:02.965 ****",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://get.helm.sh/helm-v3.11.2-linux-amd64.tar.gz\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Wednesday 11 February 2026  00:51:29 +0000 (0:00:00.044)       0:01:03.010 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Wednesday 11 February 2026  00:51:29 +0000 (0:00:00.447)       0:01:03.458 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.helm : Remove Helm repository] ***********************",
                                "Wednesday 11 February 2026  00:51:31 +0000 (0:00:02.098)       0:01:05.556 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.helm : Add bash autocomplete for helm] ***************",
                                "Wednesday 11 February 2026  00:51:32 +0000 (0:00:00.410)       0:01:05.967 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.helm : Get Helm plugins dir] *************************",
                                "Wednesday 11 February 2026  00:51:32 +0000 (0:00:00.310)       0:01:06.278 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.helm : Create Helm plugins directory if it does not exist] ***",
                                "Wednesday 11 February 2026  00:51:32 +0000 (0:00:00.340)       0:01:06.618 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.helm : Remove Helm diff plugin installed by kubernetes.core.helm_plugin] ***",
                                "Wednesday 11 February 2026  00:51:34 +0000 (0:00:01.302)       0:01:07.920 ****",
                                "ok: [controller]",
                                "",
                                "TASK [Install plugin] **********************************************************",
                                "Wednesday 11 February 2026  00:51:34 +0000 (0:00:00.324)       0:01:08.245 ****",
                                "included: vexxhost.containers.download_artifact for controller",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Wednesday 11 February 2026  00:51:34 +0000 (0:00:00.056)       0:01:08.302 ****",
                                "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] *******************",
                                "Wednesday 11 February 2026  00:51:34 +0000 (0:00:00.046)       0:01:08.348 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Wednesday 11 February 2026  00:51:34 +0000 (0:00:00.412)       0:01:08.761 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.upload_helm_chart : Include help chart upload method tasks] ***",
                                "Wednesday 11 February 2026  00:51:36 +0000 (0:00:01.684)       0:01:10.446 ****",
                                "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] ***************",
                                "Wednesday 11 February 2026  00:51:36 +0000 (0:00:00.089)       0:01:10.535 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.cilium : Get current Kubernetes version] *************",
                                "Wednesday 11 February 2026  00:51:37 +0000 (0:00:00.726)       0:01:11.262 ****",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.cilium : Deploy Helm chart] **************************",
                                "Wednesday 11 February 2026  00:51:38 +0000 (0:00:00.921)       0:01:12.184 ****",
                                "ok: [controller]",
                                "",
                                "PLAY RECAP *********************************************************************",
                                "controller                 : ok=113  changed=0    unreachable=0    failed=0    skipped=30   rescued=0    ignored=1",
                                "",
                                "",
                                "TASKS RECAP ********************************************************************",
                                "Wednesday 11 February 2026  00:51:40 +0000 (0:00:02.234)       0:01:14.418 ****",
                                "===============================================================================",
                                "vexxhost.containers.download_artifact : Extract archive ----------------- 3.42s",
                                "vexxhost.containers.download_artifact : Extract archive ----------------- 2.63s",
                                "vexxhost.kubernetes.kubelet : Configure sysctl values ------------------- 2.27s",
                                "vexxhost.kubernetes.cilium : Deploy Helm chart -------------------------- 2.23s",
                                "vexxhost.containers.download_artifact : Extract archive ----------------- 2.10s",
                                "Gathering Facts --------------------------------------------------------- 1.83s",
                                "vexxhost.containers.download_artifact : Extract archive ----------------- 1.68s",
                                "vexxhost.containers.containerd : Create folders for configuration ------- 1.67s",
                                "vexxhost.containers.containerd : Create folders for configuration ------- 1.60s",
                                "vexxhost.containers.download_artifact : Extract archive ----------------- 1.60s",
                                "vexxhost.containers.cni_plugins : Enable kernel modules in runtime ------ 1.56s",
                                "vexxhost.kubernetes.kube_vip : Uninstall legacy HA stack ---------------- 1.52s",
                                "vexxhost.containers.download_artifact : Extract archive ----------------- 1.48s",
                                "vexxhost.kubernetes.helm : Create Helm plugins directory if it does not exist --- 1.30s",
                                "vexxhost.kubernetes.kubernetes_upgrade_check : Retrieve the \"kubeadm-config\" ConfigMap --- 1.17s",
                                "Gathering Facts --------------------------------------------------------- 1.12s",
                                "vexxhost.containers.package : Update state for tar ---------------------- 1.09s",
                                "vexxhost.containers.containerd : Create systemd service file for containerd --- 1.08s",
                                "vexxhost.containers.containerd : Install AppArmor packages -------------- 1.03s",
                                "vexxhost.kubernetes.kubernetes : Set node selector for CoreDNS components --- 1.01s",
                                "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] *********************************************************",
                                "Wednesday 11 February 2026  00:51:41 +0000 (0:00:00.011)       0:00:00.011 ****",
                                "[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] ****************************************************",
                                "Wednesday 11 February 2026  00:51:42 +0000 (0:00:01.248)       0:00:01.259 ****",
                                "ok: [controller]",
                                "",
                                "TASK [Make sure kubelet service is running] ************************************",
                                "Wednesday 11 February 2026  00:51:45 +0000 (0:00:03.152)       0:00:04.412 ****",
                                "ok: [controller] => {",
                                "    \"changed\": false,",
                                "    \"msg\": \"All assertions passed\"",
                                "}",
                                "",
                                "TASK [Make sure kubelet service is enabled] ************************************",
                                "Wednesday 11 February 2026  00:51:45 +0000 (0:00:00.036)       0:00:04.448 ****",
                                "ok: [controller] => {",
                                "    \"changed\": false,",
                                "    \"msg\": \"All assertions passed\"",
                                "}",
                                "",
                                "TASK [Get all nodes] ***********************************************************",
                                "Wednesday 11 February 2026  00:51:46 +0000 (0:00:00.036)       0:00:04.485 ****",
                                "changed: [controller]",
                                "",
                                "TASK [Print node list] *********************************************************",
                                "Wednesday 11 February 2026  00:51:46 +0000 (0:00:00.461)       0:00:04.946 ****",
                                "ok: [controller] => {",
                                "    \"msg\": [",
                                "        \"NAME         STATUS   ROLES           AGE    VERSION\",",
                                "        \"controller   Ready    control-plane   118s   v1.34.0\"",
                                "    ]",
                                "}",
                                "",
                                "TASK [Assert no nody is not ready] *********************************************",
                                "Wednesday 11 February 2026  00:51:46 +0000 (0:00:00.033)       0:00:04.980 ****",
                                "ok: [controller] => {",
                                "    \"changed\": false,",
                                "    \"msg\": \"All assertions passed\"",
                                "}",
                                "",
                                "PLAY [verify BGP] **************************************************************",
                                "",
                                "TASK [Gathering Facts] *********************************************************",
                                "Wednesday 11 February 2026  00:51:46 +0000 (0:00:00.038)       0:00:05.018 ****",
                                "ok: [controller]",
                                "",
                                "TASK [Get all nodes] ***********************************************************",
                                "Wednesday 11 February 2026  00:51:47 +0000 (0:00:00.933)       0:00:05.952 ****",
                                "changed: [controller]",
                                "",
                                "TASK [Print bgp neighbors received-routes] *************************************",
                                "Wednesday 11 February 2026  00:51:47 +0000 (0:00:00.332)       0:00:06.284 ****",
                                "ok: [controller] => {",
                                "    \"msg\": [",
                                "        \"BGP table version is 0, local router ID is 162.253.55.200, 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 ********************************************************************",
                                "Wednesday 11 February 2026  00:51:47 +0000 (0:00:00.027)       0:00:06.311 ****",
                                "===============================================================================",
                                "Gather service facts ---------------------------------------------------- 3.15s",
                                "Gathering Facts --------------------------------------------------------- 1.25s",
                                "Gathering Facts --------------------------------------------------------- 0.93s",
                                "Get all nodes ----------------------------------------------------------- 0.46s",
                                "Get all nodes ----------------------------------------------------------- 0.33s",
                                "Assert no nody is not ready --------------------------------------------- 0.04s",
                                "Make sure kubelet service is enabled ------------------------------------ 0.04s",
                                "Make sure kubelet service is running ------------------------------------ 0.04s",
                                "Print node list --------------------------------------------------------- 0.03s",
                                "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-0010-5810-aa40-000000000006-1-controller"
                        }
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-11T00:51:48.095941Z",
                            "start": "2026-02-11T00:45:12.249738Z"
                        },
                        "id": "0242ac17-0010-5810-aa40-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": "vexxhost.dev/zuul-config/playbooks/base/post.yaml",
    "plays": [
        {
            "play": {
                "duration": {
                    "end": "2026-02-11T00:51:52.076810Z",
                    "start": "2026-02-11T00:51:48.831200Z"
                },
                "id": "0242ac17-0010-f05a-d852-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-0010-f05a-d852-000000000006",
                        "name": "fetch-output",
                        "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/fetch-output"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-11T00:51:48.887400Z",
                            "start": "2026-02-11T00:51:48.841481Z"
                        },
                        "id": "0242ac17-0010-f05a-d852-000000000008",
                        "name": "Set log path for multiple nodes"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "set_fact",
                            "ansible_facts": {
                                "log_path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/work/logs"
                            },
                            "changed": false
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-f05a-d852-000000000006",
                        "name": "fetch-output",
                        "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/fetch-output"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-11T00:51:48.938344Z",
                            "start": "2026-02-11T00:51:48.895709Z"
                        },
                        "id": "0242ac17-0010-f05a-d852-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/855dd72a3bc24d528160da6987ba743a/work/logs"
                                        },
                                        "before": {
                                            "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/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/855dd72a3bc24d528160da6987ba743a/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/855dd72a3bc24d528160da6987ba743a/work/logs",
                                    "size": 4096,
                                    "state": "directory",
                                    "uid": 0,
                                    "zj_output_dir": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/work/logs"
                                },
                                {
                                    "ansible_loop_var": "zj_output_dir",
                                    "changed": true,
                                    "diff": {
                                        "after": {
                                            "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/work/artifacts",
                                            "state": "directory"
                                        },
                                        "before": {
                                            "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/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/855dd72a3bc24d528160da6987ba743a/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/855dd72a3bc24d528160da6987ba743a/work/artifacts",
                                    "size": 4096,
                                    "state": "directory",
                                    "uid": 0,
                                    "zj_output_dir": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/work/artifacts"
                                },
                                {
                                    "ansible_loop_var": "zj_output_dir",
                                    "changed": true,
                                    "diff": {
                                        "after": {
                                            "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/work/docs",
                                            "state": "directory"
                                        },
                                        "before": {
                                            "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/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/855dd72a3bc24d528160da6987ba743a/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/855dd72a3bc24d528160da6987ba743a/work/docs",
                                    "size": 4096,
                                    "state": "directory",
                                    "uid": 0,
                                    "zj_output_dir": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/work/docs"
                                }
                            ]
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-f05a-d852-000000000006",
                        "name": "fetch-output",
                        "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/fetch-output"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-11T00:51:49.833948Z",
                            "start": "2026-02-11T00:51:48.944466Z"
                        },
                        "id": "0242ac17-0010-f05a-d852-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@162.253.55.200:/home/zuul/zuul-output/logs/ /var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/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/855dd72a3bc24d528160da6987ba743a/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@162.253.55.200:/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/855dd72a3bc24d528160da6987ba743a/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@162.253.55.200:/home/zuul/zuul-output/artifacts/ /var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/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/855dd72a3bc24d528160da6987ba743a/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@162.253.55.200:/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/855dd72a3bc24d528160da6987ba743a/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@162.253.55.200:/home/zuul/zuul-output/docs/ /var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/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/855dd72a3bc24d528160da6987ba743a/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@162.253.55.200:/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/855dd72a3bc24d528160da6987ba743a/work/docs",
                                        "src": "docs"
                                    }
                                }
                            ]
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-f05a-d852-000000000006",
                        "name": "fetch-output",
                        "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/fetch-output"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-11T00:51:51.405796Z",
                            "start": "2026-02-11T00:51:49.842556Z"
                        },
                        "id": "0242ac17-0010-f05a-d852-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/855dd72a3bc24d528160da6987ba743a/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/855dd72a3bc24d528160da6987ba743a/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/855dd72a3bc24d528160da6987ba743a/work/artifacts/* /var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/work/logs/artifacts\nfi\n",
                                    "delta": "0:00:00.008602",
                                    "end": "2026-02-11 00:51:51.790923",
                                    "failed": false,
                                    "invocation": {
                                        "module_args": {
                                            "_raw_params": "if [ -n \"$(find /var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/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/855dd72a3bc24d528160da6987ba743a/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/855dd72a3bc24d528160da6987ba743a/work/artifacts/* /var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/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-11 00:51:51.782321",
                                    "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/855dd72a3bc24d528160da6987ba743a/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/855dd72a3bc24d528160da6987ba743a/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/855dd72a3bc24d528160da6987ba743a/work/docs/* /var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/work/logs/docs\nfi\n",
                                    "delta": "0:00:00.006515",
                                    "end": "2026-02-11 00:51:52.028156",
                                    "failed": false,
                                    "invocation": {
                                        "module_args": {
                                            "_raw_params": "if [ -n \"$(find /var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/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/855dd72a3bc24d528160da6987ba743a/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/855dd72a3bc24d528160da6987ba743a/work/docs/* /var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/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-11 00:51:52.021641",
                                    "stderr": "",
                                    "stderr_lines": [],
                                    "stdout": "",
                                    "stdout_lines": [],
                                    "zj_item": "docs",
                                    "zuul_log_id": "in-loop-ignore"
                                }
                            ]
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-f05a-d852-00000000000f",
                        "name": "merge-output-to-logs",
                        "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/merge-output-to-logs"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-11T00:51:52.076810Z",
                            "start": "2026-02-11T00:51:51.416893Z"
                        },
                        "id": "0242ac17-0010-f05a-d852-000000000011",
                        "name": "Move artifacts and docs to logs dir"
                    }
                }
            ]
        },
        {
            "play": {
                "duration": {
                    "end": "2026-02-11T00:51:52.561206Z",
                    "start": "2026-02-11T00:51:52.086877Z"
                },
                "id": "0242ac17-0010-f05a-d852-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 AAAAB3NzaC1yc2EAAAADAQABAAABgQCuio10Cog7ImT1kgW47reHKrvjvhgx6Q+lHrCywbHCCu1y7LUxsSNBkrxOwlKiV71FN9F0XTRPLuSmbCD8UlNtgpHX/cOFHsoK+jAePaPzPK/L3Pf/sdR9qUMgShSROINLYR5R6VP3Q8u+jxV4GazYG5aWpS9T3Eh4Ly3aNglPyoHdfjhkv9zB7wMNYNGfAQIoEOkmKSnvwhO1YgUmkTD4KDcBWT3LfYR2YDdzyOxCaMO20JK/SzBLizbTKhnhrzviGJ1fg5vT74GzAHQiuC4+e/iXZQdt9bswKJ8fuod+7e8JwFSff+GXcHkFLlM6xTDsBm+X9GZglTmuaMn/YJ7ofCb5sxANYWFSZTX674hEs4nEAS69mQTQT/DkX7Vm54btN4Xw+QX9jzxnT9Tts7V0hYaKpFkRvXzHry+1LZZ4mKSEj4KkUXfxSMbbBUmj/ihgcdhaj2B+Yr2JcUJOBksla1Cnb7Oha37jTaoB7ubw8zmN9Nk3rOkhOpgelfnxQv0= 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 AAAAB3NzaC1yc2EAAAADAQABAAABgQCuio10Cog7ImT1kgW47reHKrvjvhgx6Q+lHrCywbHCCu1y7LUxsSNBkrxOwlKiV71FN9F0XTRPLuSmbCD8UlNtgpHX/cOFHsoK+jAePaPzPK/L3Pf/sdR9qUMgShSROINLYR5R6VP3Q8u+jxV4GazYG5aWpS9T3Eh4Ly3aNglPyoHdfjhkv9zB7wMNYNGfAQIoEOkmKSnvwhO1YgUmkTD4KDcBWT3LfYR2YDdzyOxCaMO20JK/SzBLizbTKhnhrzviGJ1fg5vT74GzAHQiuC4+e/iXZQdt9bswKJ8fuod+7e8JwFSff+GXcHkFLlM6xTDsBm+X9GZglTmuaMn/YJ7ofCb5sxANYWFSZTX674hEs4nEAS69mQTQT/DkX7Vm54btN4Xw+QX9jzxnT9Tts7V0hYaKpFkRvXzHry+1LZZ4mKSEj4KkUXfxSMbbBUmj/ihgcdhaj2B+Yr2JcUJOBksla1Cnb7Oha37jTaoB7ubw8zmN9Nk3rOkhOpgelfnxQv0= 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-0010-f05a-d852-000000000016",
                        "name": "remove-build-sshkey",
                        "path": "/var/lib/zuul/builds/855dd72a3bc24d528160da6987ba743a/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/remove-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-02-11T00:51:52.561206Z",
                            "start": "2026-02-11T00:51:52.092791Z"
                        },
                        "id": "0242ac17-0010-f05a-d852-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
}
]
