[
{
    "branch": "main",
    "index": "0",
    "phase": "pre",
    "playbook": "github.com/vexxhost/zuul-config/playbooks/base/pre.yaml",
    "plays": [
        {
            "play": {
                "duration": {
                    "end": "2026-05-08T10:16:45.029557Z",
                    "start": "2026-05-08T10:16:41.492307Z"
                },
                "id": "0242ac17-0010-9ee5-8c75-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-05-08",
                                    "day": "08",
                                    "epoch": "1778235402",
                                    "epoch_int": "1778235402",
                                    "hour": "10",
                                    "iso8601": "2026-05-08T10:16:42Z",
                                    "iso8601_basic": "20260508T101642200805",
                                    "iso8601_basic_short": "20260508T101642",
                                    "iso8601_micro": "2026-05-08T10:16:42.200805Z",
                                    "minute": "16",
                                    "month": "05",
                                    "second": "42",
                                    "time": "10:16:42",
                                    "tz": "UTC",
                                    "tz_dst": "UTC",
                                    "tz_offset": "+0000",
                                    "weekday": "Friday",
                                    "weekday_number": "5",
                                    "weeknumber": "18",
                                    "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/268f0dd920d14ca1b3bff4b64a2e54d3/ansible/pre_playbook_0/ansible.cfg",
                                    "DEBIAN_FRONTEND": "noninteractive",
                                    "GPG_KEY": "A035C8C19219BA821ECEA86B64E628F8D684696D",
                                    "HOME": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/work",
                                    "HOSTNAME": "2d72f0692154",
                                    "KUBECONFIG": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/kube/config",
                                    "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/268f0dd920d14ca1b3bff4b64a2e54d3/trusted/project_0/github.com/vexxhost/zuul-config/playbooks/base",
                                    "PYTHONPATH": "/var/lib/zuul/ansible/9",
                                    "PYTHON_SHA256": "8d3ed8ec5c88c1c95f5e558612a725450d2452813ddad5e58fdb1a53b1209b78",
                                    "PYTHON_VERSION": "3.11.14",
                                    "SSH_AGENT_PID": "2065359",
                                    "SSH_AUTH_SOCK": "/tmp/ssh-i32er5mqJcH6/agent.2065358",
                                    "TMP": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/work/tmp",
                                    "ZUUL_ANSIBLE_SPLIT_STREAMS": "False",
                                    "ZUUL_JOBDIR": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3",
                                    "ZUUL_JOB_FAILURE_OUTPUT": "[]",
                                    "ZUUL_JOB_LOG_CONFIG": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/ansible/logging.json",
                                    "ZUUL_OUTPUT_MAX_BYTES": "1073741824"
                                },
                                "ansible_fibre_channel_wwn": [],
                                "ansible_fips": false,
                                "ansible_form_factor": "NA",
                                "ansible_fqdn": "2d72f0692154",
                                "ansible_hostname": "2d72f0692154",
                                "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": 3.208984375,
                                    "1m": 6.06982421875,
                                    "5m": 4.943359375
                                },
                                "ansible_local": {},
                                "ansible_lsb": {},
                                "ansible_lvm": "N/A",
                                "ansible_machine": "x86_64",
                                "ansible_memfree_mb": 1468,
                                "ansible_memory_mb": {
                                    "nocache": {
                                        "free": 14506,
                                        "used": 17584
                                    },
                                    "real": {
                                        "free": 1468,
                                        "total": 32090,
                                        "used": 30622
                                    },
                                    "swap": {
                                        "cached": 0,
                                        "free": 0,
                                        "total": 0,
                                        "used": 0
                                    }
                                },
                                "ansible_memtotal_mb": 32090,
                                "ansible_mounts": [
                                    {
                                        "block_available": 7552919,
                                        "block_size": 4096,
                                        "block_total": 40601580,
                                        "block_used": 33048661,
                                        "device": "/dev/vda1",
                                        "fstype": "ext4",
                                        "inode_available": 15806747,
                                        "inode_total": 20643840,
                                        "inode_used": 4837093,
                                        "mount": "/etc/resolv.conf",
                                        "options": "ro,nosuid,nodev,relatime,discard,errors=remount-ro,bind",
                                        "size_available": 30936756224,
                                        "size_total": 166304071680,
                                        "uuid": "N/A"
                                    },
                                    {
                                        "block_available": 7552893,
                                        "block_size": 4096,
                                        "block_total": 40601580,
                                        "block_used": 33048687,
                                        "device": "/dev/vda1",
                                        "fstype": "ext4",
                                        "inode_available": 15806744,
                                        "inode_total": 20643840,
                                        "inode_used": 4837096,
                                        "mount": "/etc/hosts",
                                        "options": "ro,nosuid,nodev,relatime,discard,errors=remount-ro,bind",
                                        "size_available": 30936649728,
                                        "size_total": 166304071680,
                                        "uuid": "N/A"
                                    },
                                    {
                                        "block_available": 7552893,
                                        "block_size": 4096,
                                        "block_total": 40601580,
                                        "block_used": 33048687,
                                        "device": "/dev/vda1",
                                        "fstype": "ext4",
                                        "inode_available": 15806742,
                                        "inode_total": 20643840,
                                        "inode_used": 4837098,
                                        "mount": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/work",
                                        "options": "rw,nosuid,nodev,relatime,discard,errors=remount-ro,bind",
                                        "size_available": 30936649728,
                                        "size_total": 166304071680,
                                        "uuid": "N/A"
                                    },
                                    {
                                        "block_available": 7552879,
                                        "block_size": 4096,
                                        "block_total": 40601580,
                                        "block_used": 33048701,
                                        "device": "/dev/vda1",
                                        "fstype": "ext4",
                                        "inode_available": 15806735,
                                        "inode_total": 20643840,
                                        "inode_used": 4837105,
                                        "mount": "/var/lib/zuul/ansible/9",
                                        "options": "ro,nosuid,nodev,relatime,discard,errors=remount-ro,bind",
                                        "size_available": 30936592384,
                                        "size_total": 166304071680,
                                        "uuid": "N/A"
                                    },
                                    {
                                        "block_available": 7552858,
                                        "block_size": 4096,
                                        "block_total": 40601580,
                                        "block_used": 33048722,
                                        "device": "/dev/vda1",
                                        "fstype": "ext4",
                                        "inode_available": 15806714,
                                        "inode_total": 20643840,
                                        "inode_used": 4837126,
                                        "mount": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/ansible",
                                        "options": "ro,nosuid,nodev,relatime,discard,errors=remount-ro,bind",
                                        "size_available": 30936506368,
                                        "size_total": 166304071680,
                                        "uuid": "N/A"
                                    },
                                    {
                                        "block_available": 7552771,
                                        "block_size": 4096,
                                        "block_total": 40601580,
                                        "block_used": 33048809,
                                        "device": "/dev/vda1",
                                        "fstype": "ext4",
                                        "inode_available": 15806662,
                                        "inode_total": 20643840,
                                        "inode_used": 4837178,
                                        "mount": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/kube",
                                        "options": "ro,nosuid,nodev,relatime,discard,errors=remount-ro,bind",
                                        "size_available": 30936150016,
                                        "size_total": 166304071680,
                                        "uuid": "N/A"
                                    },
                                    {
                                        "block_available": 7552766,
                                        "block_size": 4096,
                                        "block_total": 40601580,
                                        "block_used": 33048814,
                                        "device": "/dev/vda1",
                                        "fstype": "ext4",
                                        "inode_available": 15806655,
                                        "inode_total": 20643840,
                                        "inode_used": 4837185,
                                        "mount": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/trusted",
                                        "options": "ro,nosuid,nodev,relatime,discard,errors=remount-ro,bind",
                                        "size_available": 30936129536,
                                        "size_total": 166304071680,
                                        "uuid": "N/A"
                                    },
                                    {
                                        "block_available": 7552754,
                                        "block_size": 4096,
                                        "block_total": 40601580,
                                        "block_used": 33048826,
                                        "device": "/dev/vda1",
                                        "fstype": "ext4",
                                        "inode_available": 15806644,
                                        "inode_total": 20643840,
                                        "inode_used": 4837196,
                                        "mount": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/untrusted",
                                        "options": "ro,nosuid,nodev,relatime,discard,errors=remount-ro,bind",
                                        "size_available": 30936080384,
                                        "size_total": 166304071680,
                                        "uuid": "N/A"
                                    },
                                    {
                                        "block_available": 7552749,
                                        "block_size": 4096,
                                        "block_total": 40601580,
                                        "block_used": 33048831,
                                        "device": "/dev/vda1",
                                        "fstype": "ext4",
                                        "inode_available": 15806640,
                                        "inode_total": 20643840,
                                        "inode_used": 4837200,
                                        "mount": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/ansible/pre_playbook_0",
                                        "options": "ro,nosuid,nodev,relatime,discard,errors=remount-ro,bind",
                                        "size_available": 30936059904,
                                        "size_total": 166304071680,
                                        "uuid": "N/A"
                                    },
                                    {
                                        "block_available": 7552749,
                                        "block_size": 4096,
                                        "block_total": 40601580,
                                        "block_used": 33048831,
                                        "device": "/dev/vda1",
                                        "fstype": "ext4",
                                        "inode_available": 15806640,
                                        "inode_total": 20643840,
                                        "inode_used": 4837200,
                                        "mount": "/etc/zuul/site-variables.yaml",
                                        "options": "ro,nosuid,nodev,relatime,discard,errors=remount-ro,bind",
                                        "size_available": 30936059904,
                                        "size_total": 166304071680,
                                        "uuid": "N/A"
                                    },
                                    {
                                        "block_available": 161170082,
                                        "block_size": 4096,
                                        "block_total": 263940717,
                                        "block_used": 102770635,
                                        "device": "/dev/vdb",
                                        "fstype": "ext4",
                                        "inode_available": 51470633,
                                        "inode_total": 67108864,
                                        "inode_used": 15638231,
                                        "mount": "/srv/static/logs",
                                        "options": "rw,nosuid,nodev,relatime,discard",
                                        "size_available": 660152655872,
                                        "size_total": 1081101176832,
                                        "uuid": "N/A"
                                    },
                                    {
                                        "block_available": 7552737,
                                        "block_size": 4096,
                                        "block_total": 40601580,
                                        "block_used": 33048843,
                                        "device": "/dev/vda1",
                                        "fstype": "ext4",
                                        "inode_available": 15806630,
                                        "inode_total": 20643840,
                                        "inode_used": 4837210,
                                        "mount": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/.ansible",
                                        "options": "rw,nosuid,nodev,relatime,discard,errors=remount-ro,bind",
                                        "size_available": 30936010752,
                                        "size_total": 166304071680,
                                        "uuid": "N/A"
                                    }
                                ],
                                "ansible_nodename": "2d72f0692154",
                                "ansible_os_family": "Debian",
                                "ansible_pkg_mgr": "apt",
                                "ansible_proc_cmdline": {
                                    "BOOT_IMAGE": "/boot/vmlinuz-5.15.0-130-generic",
                                    "console": [
                                        "tty1",
                                        "ttyS0"
                                    ],
                                    "ro": true,
                                    "root": "UUID=5a569d86-b935-46dd-ae79-7a72a25b6a4c"
                                },
                                "ansible_processor": [
                                    "0",
                                    "AuthenticAMD",
                                    "AMD EPYC-Rome Processor",
                                    "1",
                                    "AuthenticAMD",
                                    "AMD EPYC-Rome Processor",
                                    "2",
                                    "AuthenticAMD",
                                    "AMD EPYC-Rome Processor",
                                    "3",
                                    "AuthenticAMD",
                                    "AMD EPYC-Rome Processor",
                                    "4",
                                    "AuthenticAMD",
                                    "AMD EPYC-Rome Processor",
                                    "5",
                                    "AuthenticAMD",
                                    "AMD EPYC-Rome Processor",
                                    "6",
                                    "AuthenticAMD",
                                    "AMD EPYC-Rome Processor",
                                    "7",
                                    "AuthenticAMD",
                                    "AMD EPYC-Rome Processor",
                                    "8",
                                    "AuthenticAMD",
                                    "AMD EPYC-Rome Processor",
                                    "9",
                                    "AuthenticAMD",
                                    "AMD EPYC-Rome Processor",
                                    "10",
                                    "AuthenticAMD",
                                    "AMD EPYC-Rome Processor",
                                    "11",
                                    "AuthenticAMD",
                                    "AMD EPYC-Rome Processor",
                                    "12",
                                    "AuthenticAMD",
                                    "AMD EPYC-Rome Processor",
                                    "13",
                                    "AuthenticAMD",
                                    "AMD EPYC-Rome Processor",
                                    "14",
                                    "AuthenticAMD",
                                    "AMD EPYC-Rome Processor",
                                    "15",
                                    "AuthenticAMD",
                                    "AMD EPYC-Rome Processor"
                                ],
                                "ansible_processor_cores": 1,
                                "ansible_processor_count": 16,
                                "ansible_processor_nproc": 16,
                                "ansible_processor_threads_per_core": 1,
                                "ansible_processor_vcpus": 16,
                                "ansible_product_name": "NA",
                                "ansible_product_serial": "NA",
                                "ansible_product_uuid": "NA",
                                "ansible_product_version": "NA",
                                "ansible_python": {
                                    "executable": "/usr/local/lib/zuul/ansible/9/bin/python",
                                    "has_sslcontext": true,
                                    "type": "cpython",
                                    "version": {
                                        "major": 3,
                                        "micro": 14,
                                        "minor": 11,
                                        "releaselevel": "final",
                                        "serial": 0
                                    },
                                    "version_info": [
                                        3,
                                        11,
                                        14,
                                        "final",
                                        0
                                    ]
                                },
                                "ansible_python_version": "3.11.14",
                                "ansible_real_group_id": 0,
                                "ansible_real_user_id": 0,
                                "ansible_selinux": {
                                    "status": "disabled"
                                },
                                "ansible_selinux_python_present": true,
                                "ansible_service_mgr": "bwrap",
                                "ansible_swapfree_mb": 0,
                                "ansible_swaptotal_mb": 0,
                                "ansible_system": "Linux",
                                "ansible_system_capabilities": "N/A",
                                "ansible_system_capabilities_enforced": "N/A",
                                "ansible_system_vendor": "NA",
                                "ansible_uptime_seconds": 41899132,
                                "ansible_user_dir": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/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-05-08T10:16:42.505723Z",
                            "start": "2026-05-08T10:16:41.508357Z"
                        },
                        "id": "0242ac17-0010-9ee5-8c75-00000000002a",
                        "name": "Gathering Facts"
                    }
                },
                {
                    "hosts": {
                        "localhost": {
                            "action": "include_role",
                            "changed": false,
                            "include_args": {
                                "name": "set-zuul-log-path-fact"
                            }
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-9ee5-8c75-000000000006",
                        "name": "emit-job-header",
                        "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/emit-job-header"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-05-08T10:16:42.540242Z",
                            "start": "2026-05-08T10:16:42.509771Z"
                        },
                        "id": "0242ac17-0010-9ee5-8c75-000000000008",
                        "name": "Setup log path fact"
                    }
                },
                {
                    "hosts": {
                        "localhost": {
                            "action": "set_fact",
                            "ansible_facts": {
                                "zuul_log_path": "268/oss/268f0dd920d14ca1b3bff4b64a2e54d3"
                            },
                            "changed": false
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-9ee5-8c75-000000000054",
                        "name": "set-zuul-log-path-fact",
                        "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/set-zuul-log-path-fact"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-05-08T10:16:42.588089Z",
                            "start": "2026-05-08T10:16:42.554417Z"
                        },
                        "id": "0242ac17-0010-9ee5-8c75-000000000056",
                        "name": "Set log path for a build"
                    }
                },
                {
                    "hosts": {
                        "localhost": {
                            "action": "debug",
                            "changed": false,
                            "msg": "# Job Information\nAnsible Version: 2.16.18\nJob: atmosphere-common-molecule-secretgen-controller\nPipeline: check\nExecutor: 2d72f0692154\nTriggered by: https://github.com/vexxhost/atmosphere.common/pull/99\nEvent ID: f67e04f0-4ac6-11f1-9165-12bb799884e4\n"
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-9ee5-8c75-000000000006",
                        "name": "emit-job-header",
                        "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/emit-job-header"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-05-08T10:16:42.644678Z",
                            "start": "2026-05-08T10:16:42.596812Z"
                        },
                        "id": "0242ac17-0010-9ee5-8c75-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: np0000172681\nUsername: zuul\nDistro: Ubuntu 24.04\nProvider: yul1\nRegion: ca-ymq-1\nLabel: ubuntu-noble\nProduct Name: OpenStack Nova\nInterface IP: 199.204.45.216\n",
                                    "zj_item": "controller"
                                }
                            ]
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-9ee5-8c75-000000000006",
                        "name": "emit-job-header",
                        "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/emit-job-header"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-05-08T10:16:42.892782Z",
                            "start": "2026-05-08T10:16:42.759289Z"
                        },
                        "id": "0242ac17-0010-9ee5-8c75-00000000000a",
                        "name": "Print node information"
                    }
                },
                {
                    "hosts": {
                        "localhost": {
                            "action": "file",
                            "changed": true,
                            "diff": {
                                "after": {
                                    "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/work/logs/zuul-info",
                                    "state": "directory"
                                },
                                "before": {
                                    "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/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/268f0dd920d14ca1b3bff4b64a2e54d3/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/268f0dd920d14ca1b3bff4b64a2e54d3/work/logs/zuul-info",
                            "size": 4096,
                            "state": "directory",
                            "uid": 0
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-9ee5-8c75-00000000000d",
                        "name": "log-inventory",
                        "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/log-inventory"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-05-08T10:16:43.395566Z",
                            "start": "2026-05-08T10:16:42.902144Z"
                        },
                        "id": "0242ac17-0010-9ee5-8c75-00000000000f",
                        "name": "Ensure Zuul Ansible directory exists"
                    }
                },
                {
                    "hosts": {
                        "localhost": {
                            "action": "copy",
                            "changed": true,
                            "checksum": "9cdec4119db526f415325defd11fce0dd7d2a52e",
                            "dest": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/work/logs/zuul-info/inventory.yaml",
                            "diff": [],
                            "gid": 0,
                            "group": "root",
                            "invocation": {
                                "module_args": {
                                    "_original_basename": "inventory.yaml",
                                    "attributes": null,
                                    "backup": false,
                                    "checksum": "9cdec4119db526f415325defd11fce0dd7d2a52e",
                                    "content": null,
                                    "dest": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/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/268f0dd920d14ca1b3bff4b64a2e54d3/work/.ansible/tmp/ansible-tmp-1778235403.444531-84-272107183049094/source",
                                    "unsafe_writes": false,
                                    "validate": null
                                }
                            },
                            "md5sum": "2b57c8412fb4d0b566c18fa68f4dd131",
                            "mode": "0644",
                            "owner": "root",
                            "size": 295622,
                            "src": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/work/.ansible/tmp/ansible-tmp-1778235403.444531-84-272107183049094/source",
                            "state": "file",
                            "uid": 0
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-9ee5-8c75-00000000000d",
                        "name": "log-inventory",
                        "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/log-inventory"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-05-08T10:16:45.029557Z",
                            "start": "2026-05-08T10:16:43.402634Z"
                        },
                        "id": "0242ac17-0010-9ee5-8c75-000000000010",
                        "name": "Copy ansible inventory to logs dir"
                    }
                }
            ]
        },
        {
            "play": {
                "duration": {
                    "end": "2026-05-08T10:16:52.548255Z",
                    "start": "2026-05-08T10:16:45.040103Z"
                },
                "id": "0242ac17-0010-9ee5-8c75-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/268f0dd920d14ca1b3bff4b64a2e54d3/work/268f0dd920d14ca1b3bff4b64a2e54d3_id_rsa"
                                }
                            },
                            "stat": {
                                "exists": false
                            }
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-9ee5-8c75-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-05-08T10:16:45.584822Z",
                            "start": "2026-05-08T10:16:45.050152Z"
                        },
                        "id": "0242ac17-0010-9ee5-8c75-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-9ee5-8c75-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-05-08T10:16:45.633923Z",
                            "start": "2026-05-08T10:16:45.595386Z"
                        },
                        "id": "0242ac17-0010-9ee5-8c75-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/268f0dd920d14ca1b3bff4b64a2e54d3/work/268f0dd920d14ca1b3bff4b64a2e54d3_id_rsa",
                                "-b",
                                "3072"
                            ],
                            "delta": "0:00:00.381519",
                            "end": "2026-05-08 10:16:46.411890",
                            "invocation": {
                                "module_args": {
                                    "_raw_params": "ssh-keygen -t rsa -N '' -C 'zuul-build-sshkey' -f /var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/work/268f0dd920d14ca1b3bff4b64a2e54d3_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-9ee5-8c75-00000000009c-0-controller",
                                    "zuul_no_log": false,
                                    "zuul_output_max_bytes": 1073741824
                                }
                            },
                            "msg": "",
                            "rc": 0,
                            "start": "2026-05-08 10:16:46.030371",
                            "stderr": "",
                            "stderr_lines": [],
                            "stdout": "Generating public/private rsa key pair.\nYour identification has been saved in /var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/work/268f0dd920d14ca1b3bff4b64a2e54d3_id_rsa\nYour public key has been saved in /var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/work/268f0dd920d14ca1b3bff4b64a2e54d3_id_rsa.pub\nThe key fingerprint is:\nSHA256:lHv2YVMYbvH49kFVeo3TsfnJDioyv2AfQs2f0TBg5W0 zuul-build-sshkey\nThe key's randomart image is:\n+---[RSA 3072]----+\n|         o..o  .+|\n|        ..o..* +*|\n|        o  +=E*++|\n|       .o. .=oooo|\n|       .Soo.+oo+.|\n|      .  o.o++o..|\n|       * o +.  ..|\n|      . B o      |\n|         +.      |\n+----[SHA256]-----+",
                            "stdout_lines": [
                                "Generating public/private rsa key pair.",
                                "Your identification has been saved in /var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/work/268f0dd920d14ca1b3bff4b64a2e54d3_id_rsa",
                                "Your public key has been saved in /var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/work/268f0dd920d14ca1b3bff4b64a2e54d3_id_rsa.pub",
                                "The key fingerprint is:",
                                "SHA256:lHv2YVMYbvH49kFVeo3TsfnJDioyv2AfQs2f0TBg5W0 zuul-build-sshkey",
                                "The key's randomart image is:",
                                "+---[RSA 3072]----+",
                                "|         o..o  .+|",
                                "|        ..o..* +*|",
                                "|        o  +=E*++|",
                                "|       .o. .=oooo|",
                                "|       .Soo.+oo+.|",
                                "|      .  o.o++o..|",
                                "|       * o +.  ..|",
                                "|      . B o      |",
                                "|         +.      |",
                                "+----[SHA256]-----+"
                            ],
                            "zuul_log_id": "0242ac17-0010-9ee5-8c75-00000000009c-0-controller"
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-9ee5-8c75-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-05-08T10:16:46.471342Z",
                            "start": "2026-05-08T10:16:45.654813Z"
                        },
                        "id": "0242ac17-0010-9ee5-8c75-00000000009c",
                        "name": "Create Temp SSH key"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "include_tasks",
                            "changed": false,
                            "include": "remote-linux.yaml",
                            "include_args": {}
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-9ee5-8c75-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-05-08T10:16:46.513338Z",
                            "start": "2026-05-08T10:16:46.477357Z"
                        },
                        "id": "0242ac17-0010-9ee5-8c75-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-9ee5-8c75-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-05-08T10:16:46.555873Z",
                            "start": "2026-05-08T10:16:46.529933Z"
                        },
                        "id": "0242ac17-0010-9ee5-8c75-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 AAAAB3NzaC1yc2EAAAADAQABAAABgQDdK9vF0BuPVWxC7SEWZ3ALK04EhUUuPXlOF0VfiK1QI7f9ZTXBj7Mq4SCSwRuo/KRQZgf0h/gIC3R6QJreZbJmQJ7StW4Ha21RlmWAXb/rab2ILoMfa60TOdbsKKkK9RPMxVtc/Ro5jboBEJypb7rTH9M6OaDwXTz0hvM+lpaBQoEzjCXK/gchewr22jljSCxpHf0IuxeAKlKp9UIoSNtbB1Gp2c+W4eBc6VXpGjUdDQrZnCJeywAPhwroghbHDGM1MXqwvTDLiD6WFW+aN98D0lAW5LGK4kijKsdzK3j6Lyb+OcAkRfMfCA8b9L2VyBG1d9vQcGJjeEkQxJZyar+7XQW2wSjWDcFjXnW51BfuHfRkoB6mos6sEjzbw7gnWYX552VnXraCv3KdH1NI8mEjJL5/GXuGTlRAAHwSqIpRHspazxUL7wuiX6z5mSv31n8/GK3pqHLSF07s5ce36Mpx7JlZYC9bP6lbcavl8uHTjEQ5PYC8nigIWU1oS+Bikfk= 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 AAAAB3NzaC1yc2EAAAADAQABAAABgQDdK9vF0BuPVWxC7SEWZ3ALK04EhUUuPXlOF0VfiK1QI7f9ZTXBj7Mq4SCSwRuo/KRQZgf0h/gIC3R6QJreZbJmQJ7StW4Ha21RlmWAXb/rab2ILoMfa60TOdbsKKkK9RPMxVtc/Ro5jboBEJypb7rTH9M6OaDwXTz0hvM+lpaBQoEzjCXK/gchewr22jljSCxpHf0IuxeAKlKp9UIoSNtbB1Gp2c+W4eBc6VXpGjUdDQrZnCJeywAPhwroghbHDGM1MXqwvTDLiD6WFW+aN98D0lAW5LGK4kijKsdzK3j6Lyb+OcAkRfMfCA8b9L2VyBG1d9vQcGJjeEkQxJZyar+7XQW2wSjWDcFjXnW51BfuHfRkoB6mos6sEjzbw7gnWYX552VnXraCv3KdH1NI8mEjJL5/GXuGTlRAAHwSqIpRHspazxUL7wuiX6z5mSv31n8/GK3pqHLSF07s5ce36Mpx7JlZYC9bP6lbcavl8uHTjEQ5PYC8nigIWU1oS+Bikfk= 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-9ee5-8c75-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-05-08T10:16:47.204818Z",
                            "start": "2026-05-08T10:16:46.565857Z"
                        },
                        "id": "0242ac17-0010-9ee5-8c75-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-9ee5-8c75-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-05-08T10:16:47.457762Z",
                            "start": "2026-05-08T10:16:47.211058Z"
                        },
                        "id": "0242ac17-0010-9ee5-8c75-0000000000be",
                        "name": "Make sure user has a .ssh"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "copy",
                            "changed": true,
                            "checksum": "c25b079e8e5cb23c1af25310c14401d531fcc424",
                            "dest": "/home/zuul/.ssh/id_rsa",
                            "diff": [],
                            "gid": 1000,
                            "group": "zuul",
                            "invocation": {
                                "module_args": {
                                    "_original_basename": "268f0dd920d14ca1b3bff4b64a2e54d3_id_rsa",
                                    "attributes": null,
                                    "backup": false,
                                    "checksum": "c25b079e8e5cb23c1af25310c14401d531fcc424",
                                    "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-1778235407.5112424-190-91686251283615/source",
                                    "unsafe_writes": false,
                                    "validate": null
                                }
                            },
                            "md5sum": "39e65c37c3346d5fb285008f1fa1c380",
                            "mode": "0600",
                            "owner": "zuul",
                            "size": 2602,
                            "src": "/home/zuul/.ansible/tmp/ansible-tmp-1778235407.5112424-190-91686251283615/source",
                            "state": "file",
                            "uid": 1000
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-9ee5-8c75-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-05-08T10:16:48.034108Z",
                            "start": "2026-05-08T10:16:47.465330Z"
                        },
                        "id": "0242ac17-0010-9ee5-8c75-0000000000bf",
                        "name": "Install build private key as SSH key on all nodes"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "copy",
                            "changed": true,
                            "checksum": "6b520fca71920b27d7b3b4898f23965747c5bfb3",
                            "dest": "/home/zuul/.ssh/id_rsa.pub",
                            "diff": [],
                            "gid": 1000,
                            "group": "zuul",
                            "invocation": {
                                "module_args": {
                                    "_original_basename": "268f0dd920d14ca1b3bff4b64a2e54d3_id_rsa.pub",
                                    "attributes": null,
                                    "backup": false,
                                    "checksum": "6b520fca71920b27d7b3b4898f23965747c5bfb3",
                                    "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-1778235408.079767-200-48844414164882/source",
                                    "unsafe_writes": false,
                                    "validate": null
                                }
                            },
                            "md5sum": "70b81f2c1bb23451860c1dfd73eb7077",
                            "mode": "0644",
                            "owner": "zuul",
                            "size": 571,
                            "src": "/home/zuul/.ansible/tmp/ansible-tmp-1778235408.079767-200-48844414164882/source",
                            "state": "file",
                            "uid": 1000
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-9ee5-8c75-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-05-08T10:16:48.578923Z",
                            "start": "2026-05-08T10:16:48.039102Z"
                        },
                        "id": "0242ac17-0010-9ee5-8c75-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-9ee5-8c75-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-05-08T10:16:48.608888Z",
                            "start": "2026-05-08T10:16:48.584234Z"
                        },
                        "id": "0242ac17-0010-9ee5-8c75-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-9ee5-8c75-0000000000a3",
                        "name": "remove-zuul-sshkey",
                        "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/remove-zuul-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-05-08T10:16:49.180298Z",
                            "start": "2026-05-08T10:16:48.619271Z"
                        },
                        "id": "0242ac17-0010-9ee5-8c75-0000000000a5",
                        "name": "Remove master key from local agent"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "command",
                            "changed": true,
                            "cmd": [
                                "ssh-add",
                                "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/work/268f0dd920d14ca1b3bff4b64a2e54d3_id_rsa"
                            ],
                            "delta": "0:00:00.012578",
                            "end": "2026-05-08 10:16:49.438324",
                            "invocation": {
                                "module_args": {
                                    "_raw_params": "ssh-add /var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/work/268f0dd920d14ca1b3bff4b64a2e54d3_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-9ee5-8c75-0000000000ab-0-controller",
                                    "zuul_no_log": false,
                                    "zuul_output_max_bytes": 1073741824
                                }
                            },
                            "msg": "",
                            "rc": 0,
                            "start": "2026-05-08 10:16:49.425746",
                            "stderr": "",
                            "stderr_lines": [],
                            "stdout": "Identity added: /var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/work/268f0dd920d14ca1b3bff4b64a2e54d3_id_rsa (zuul-build-sshkey)",
                            "stdout_lines": [
                                "Identity added: /var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/work/268f0dd920d14ca1b3bff4b64a2e54d3_id_rsa (zuul-build-sshkey)"
                            ],
                            "zuul_log_id": "0242ac17-0010-9ee5-8c75-0000000000ab-0-controller"
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-9ee5-8c75-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-05-08T10:16:49.489091Z",
                            "start": "2026-05-08T10:16:49.198297Z"
                        },
                        "id": "0242ac17-0010-9ee5-8c75-0000000000ab",
                        "name": "Add back temp key"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "ping",
                            "changed": false,
                            "invocation": {
                                "module_args": {
                                    "data": "pong"
                                }
                            },
                            "ping": "pong"
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-9ee5-8c75-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-05-08T10:16:49.834663Z",
                            "start": "2026-05-08T10:16:49.495665Z"
                        },
                        "id": "0242ac17-0010-9ee5-8c75-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-9ee5-8c75-000000000016",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-05-08T10:16:49.863724Z",
                            "start": "2026-05-08T10:16:49.839535Z"
                        },
                        "id": "0242ac17-0010-9ee5-8c75-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-9ee5-8c75-00000000001b",
                        "name": "prepare-workspace",
                        "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/prepare-workspace"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-05-08T10:16:50.276775Z",
                            "start": "2026-05-08T10:16:49.880495Z"
                        },
                        "id": "0242ac17-0010-9ee5-8c75-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-9ee5-8c75-00000000001b",
                        "name": "prepare-workspace",
                        "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/prepare-workspace"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-05-08T10:16:51.327908Z",
                            "start": "2026-05-08T10:16:50.282949Z"
                        },
                        "id": "0242ac17-0010-9ee5-8c75-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-9ee5-8c75-000000000020",
                        "name": "ensure-output-dirs",
                        "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/ensure-output-dirs"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-05-08T10:16:51.935511Z",
                            "start": "2026-05-08T10:16:51.339185Z"
                        },
                        "id": "0242ac17-0010-9ee5-8c75-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-9ee5-8c75-000000000020",
                        "name": "ensure-output-dirs",
                        "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/ensure-output-dirs"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-05-08T10:16:52.548255Z",
                            "start": "2026-05-08T10:16:51.943507Z"
                        },
                        "id": "0242ac17-0010-9ee5-8c75-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-05-08T10:16:56.248167Z",
                    "start": "2026-05-08T10:16:53.338000Z"
                },
                "id": "0242ac17-0010-16a7-347d-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-1778235413.3948169-5-31213866067476/uv-x86_64-unknown-linux-gnugy1zh1p2.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-1778235413.3948169-5-31213866067476/uv-x86_64-unknown-linux-gnugy1zh1p2.tar.gz",
                            "state": "directory",
                            "uid": 0
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-16a7-347d-000000000005",
                        "name": "setup-uv",
                        "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/untrusted/project_0/github.com/vexxhost/zuul-jobs/roles/setup-uv"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-05-08T10:16:55.700746Z",
                            "start": "2026-05-08T10:16:53.353207Z"
                        },
                        "id": "0242ac17-0010-16a7-347d-000000000007",
                        "name": "Extract archive"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "ansible.builtin.command",
                            "changed": true,
                            "cmd": [
                                "/usr/local/bin/uv",
                                "--version"
                            ],
                            "delta": "0:00:00.016179",
                            "end": "2026-05-08 10:16:56.123191",
                            "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-16a7-347d-000000000008-1-controller",
                                    "zuul_no_log": false,
                                    "zuul_output_max_bytes": 1073741824
                                }
                            },
                            "msg": "",
                            "rc": 0,
                            "start": "2026-05-08 10:16:56.107012",
                            "stderr": "",
                            "stderr_lines": [],
                            "stdout": "uv 0.8.13",
                            "stdout_lines": [
                                "uv 0.8.13"
                            ],
                            "zuul_log_id": "0242ac17-0010-16a7-347d-000000000008-1-controller"
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-16a7-347d-000000000005",
                        "name": "setup-uv",
                        "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/untrusted/project_0/github.com/vexxhost/zuul-jobs/roles/setup-uv"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-05-08T10:16:56.248167Z",
                            "start": "2026-05-08T10:16:55.730697Z"
                        },
                        "id": "0242ac17-0010-16a7-347d-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-05-08T10:20:31.102086Z",
                    "start": "2026-05-08T10:16:56.979380Z"
                },
                "id": "0242ac17-0010-36d7-0626-000000000002",
                "name": "all"
            },
            "tasks": [
                {
                    "hosts": {
                        "controller": {
                            "action": "ansible.builtin.copy",
                            "changed": true,
                            "checksum": "9cdec4119db526f415325defd11fce0dd7d2a52e",
                            "dest": "src/github.com/vexxhost/atmosphere.common/inventory.yaml",
                            "diff": [],
                            "gid": 1000,
                            "group": "zuul",
                            "invocation": {
                                "module_args": {
                                    "_original_basename": "inventory.yaml",
                                    "attributes": null,
                                    "backup": false,
                                    "checksum": "9cdec4119db526f415325defd11fce0dd7d2a52e",
                                    "content": null,
                                    "dest": "src/github.com/vexxhost/atmosphere.common",
                                    "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-1778235417.033443-5-104797620765109/source",
                                    "unsafe_writes": false,
                                    "validate": null
                                }
                            },
                            "md5sum": "2b57c8412fb4d0b566c18fa68f4dd131",
                            "mode": "0644",
                            "owner": "zuul",
                            "size": 295622,
                            "src": "/home/zuul/.ansible/tmp/ansible-tmp-1778235417.033443-5-104797620765109/source",
                            "state": "file",
                            "uid": 1000
                        }
                    },
                    "task": {
                        "duration": {
                            "end": "2026-05-08T10:16:58.011140Z",
                            "start": "2026-05-08T10:16:56.990602Z"
                        },
                        "id": "0242ac17-0010-36d7-0626-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/atmosphere.common/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-05-08T10:16:58.418922Z",
                            "start": "2026-05-08T10:16:58.017413Z"
                        },
                        "id": "0242ac17-0010-36d7-0626-000000000005",
                        "name": "Switch \"ansible_host\" to private IP"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "ansible.builtin.command",
                            "changed": true,
                            "cmd": [
                                "uv",
                                "run",
                                "molecule",
                                "test",
                                "--destroy",
                                "never",
                                "-s",
                                "secretgen-controller"
                            ],
                            "delta": "0:03:31.988159",
                            "end": "2026-05-08 10:20:30.808781",
                            "invocation": {
                                "module_args": {
                                    "_raw_params": "uv run molecule test --destroy never -s secretgen-controller",
                                    "_uses_shell": false,
                                    "argv": null,
                                    "chdir": "src/github.com/vexxhost/atmosphere.common",
                                    "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-36d7-0626-000000000006-1-controller",
                                    "zuul_no_log": false,
                                    "zuul_output_max_bytes": 1073741824
                                }
                            },
                            "msg": "",
                            "rc": 0,
                            "start": "2026-05-08 10:16:58.820622",
                            "stderr": "",
                            "stderr_lines": [],
                            "stdout": "Using CPython 3.12.3 interpreter at: /usr/bin/python3\nCreating virtual environment at: .venv\nwarning: No `requires-python` value found in the workspace. Defaulting to `>=3.12`.\nDownloading cryptography (4.3MiB)\nDownloading kubernetes (1.9MiB)\nDownloading pygments (1.2MiB)\nDownloading ansible-core (2.3MiB)\n Downloading cryptography\n Downloading pygments\n Downloading kubernetes\n Downloading ansible-core\nInstalled 47 packages in 45ms\nINFO     Collection 'atmosphere.common' detected.\nINFO     Scenarios will be used from 'extensions/molecule'\nINFO     [secretgen-controller > discovery] scenario test matrix: dependency, cleanup, destroy, syntax, create, prepare, converge, idempotence, side_effect, verify, cleanup, destroy\nINFO     [secretgen-controller > prerun] Performing prerun with role_name_check=0...\nINFO     [secretgen-controller > dependency] Executing\nWARNING  [secretgen-controller > dependency] Missing roles requirements file: requirements.yml\nWARNING  [secretgen-controller > dependency] Missing collections requirements file: collections.yml\nWARNING  [secretgen-controller > dependency] Executed: 2 missing (Remove from test_sequence to suppress)\nINFO     [secretgen-controller > cleanup] Executing\nWARNING  [secretgen-controller > cleanup] Executed: Missing playbook (Remove from test_sequence to suppress)\nINFO     [secretgen-controller > destroy] Executing\nWARNING  [secretgen-controller > destroy] Skipping, '--destroy=never' requested.\nINFO     [secretgen-controller > destroy] Executed: Successful\nINFO     [secretgen-controller > syntax] Executing\n\nplaybook: /home/zuul/src/github.com/vexxhost/atmosphere.common/extensions/molecule/secretgen-controller/converge.yml\nINFO     [secretgen-controller > syntax] Executed: Successful\nINFO     [secretgen-controller > create] Executing\nWARNING  [secretgen-controller > create] Executed: Missing playbook (Remove from test_sequence to suppress)\nINFO     [secretgen-controller > prepare] Executing\n\nPLAY [Prepare] *****************************************************************\n\nTASK [Gathering Facts] *********************************************************\nFriday 08 May 2026  10:17:23 +0000 (0:00:00.032)       0:00:00.032 ************\n[WARNING]: Host 'controller' is using the discovered Python interpreter at '/usr/bin/python3.12', but future installation of another Python interpreter could cause a different interpreter to be discovered. See https://docs.ansible.com/ansible-core/2.19/reference_appendices/interpreter_discovery.html for more information.\nok: [controller]\n\nTASK [Install Debian packages] *************************************************\nFriday 08 May 2026  10:17:24 +0000 (0:00:01.329)       0:00:01.361 ************\nok: [controller]\n\nPLAY [Configure Kubernetes VIP] ************************************************\n\nTASK [Gathering Facts] *********************************************************\nFriday 08 May 2026  10:17:30 +0000 (0:00:06.217)       0:00:07.579 ************\nok: [controller]\n\nTASK [vexxhost.containers.directory : Create directory (/etc/kubernetes/manifests)] ***\nFriday 08 May 2026  10:17:32 +0000 (0:00:01.871)       0:00:09.450 ************\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Uninstall legacy HA stack] ****************\nFriday 08 May 2026  10:17:33 +0000 (0:00:00.453)       0:00:09.904 ************\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] ****\nFriday 08 May 2026  10:17:34 +0000 (0:00:01.495)       0:00:11.400 ************\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] *********\nFriday 08 May 2026  10:17:35 +0000 (0:00:00.992)       0:00:12.392 ************\nok: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Check if kubeadm has already run] *********\nFriday 08 May 2026  10:17:36 +0000 (0:00:00.429)       0:00:12.822 ************\nok: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Set fact with KUBECONFIG path] ************\nFriday 08 May 2026  10:17:36 +0000 (0:00:00.314)       0:00:13.136 ************\nok: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Set fact with KUBECONFIG path (with super-admin.conf)] ***\nFriday 08 May 2026  10:17:36 +0000 (0:00:00.031)       0:00:13.168 ************\nok: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Upload Kubernetes manifest] ***************\nFriday 08 May 2026  10:17:36 +0000 (0:00:00.043)       0:00:13.212 ************\nok: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Ensure kube-vip configuration file] *******\nFriday 08 May 2026  10:17:37 +0000 (0:00:00.981)       0:00:14.193 ************\nok: [controller]\n\nTASK [vexxhost.kubernetes.kube_vip : Flush handlers] ***************************\nFriday 08 May 2026  10:17:37 +0000 (0:00:00.312)       0:00:14.506 ************\n\nPLAY [Install Kubernetes] ******************************************************\n\nTASK [Gathering Facts] *********************************************************\nFriday 08 May 2026  10:17:37 +0000 (0:00:00.048)       0:00:14.554 ************\nok: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nFriday 08 May 2026  10:17:38 +0000 (0:00:00.882)       0:00:15.436 ************\nok: [controller]\n\nTASK [vexxhost.containers.package : Update state for tar] **********************\nFriday 08 May 2026  10:17:39 +0000 (0:00:00.392)       0:00:15.829 ************\nskipping: [controller]\n\nTASK [vexxhost.containers.directory : Create directory (/var/lib/downloads)] ***\nFriday 08 May 2026  10:17:39 +0000 (0:00:00.031)       0:00:15.861 ************\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nFriday 08 May 2026  10:17:39 +0000 (0:00:00.317)       0:00:16.179 ************\nok: [controller] => {\n    \"msg\": \"https://github.com/opencontainers/runc/releases/download/v1.4.2/runc.amd64\"\n}\n\nTASK [vexxhost.containers.download_artifact : Download item] *******************\nFriday 08 May 2026  10:17:39 +0000 (0:00:00.073)       0:00:16.252 ************\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 [vexxhost.containers.download_artifact : Extract archive] *****************\nFriday 08 May 2026  10:17:40 +0000 (0:00:01.122)       0:00:17.374 ************\nskipping: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nFriday 08 May 2026  10:17:40 +0000 (0:00:00.035)       0:00:17.409 ************\nok: [controller]\n\nTASK [vexxhost.containers.package : Update state for tar] **********************\nFriday 08 May 2026  10:17:41 +0000 (0:00:00.306)       0:00:17.716 ************\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nFriday 08 May 2026  10:17:42 +0000 (0:00:01.045)       0:00:18.761 ************\nok: [controller] => {\n    \"msg\": \"https://github.com/containerd/containerd/releases/download/v2.2.3/containerd-2.2.3-linux-amd64.tar.gz\"\n}\n\nTASK [vexxhost.containers.download_artifact : Download item] *******************\nFriday 08 May 2026  10:17:42 +0000 (0:00:00.073)       0:00:18.835 ************\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nFriday 08 May 2026  10:17:43 +0000 (0:00:00.904)       0:00:19.739 ************\nchanged: [controller]\n\nTASK [vexxhost.containers.containerd : Install SELinux packages] ***************\nFriday 08 May 2026  10:17:46 +0000 (0:00:03.201)       0:00:22.941 ************\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Set SELinux to permissive at runtime] ***\nFriday 08 May 2026  10:17:46 +0000 (0:00:00.033)       0:00:22.974 ************\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Persist SELinux permissive mode] ********\nFriday 08 May 2026  10:17:46 +0000 (0:00:00.032)       0:00:23.007 ************\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Install AppArmor packages] **************\nFriday 08 May 2026  10:17:46 +0000 (0:00:00.032)       0:00:23.040 ************\nchanged: [controller]\n\nTASK [vexxhost.containers.containerd : Create systemd service file for containerd] ***\nFriday 08 May 2026  10:17:53 +0000 (0:00:07.039)       0:00:30.080 ************\nchanged: [controller]\n\nTASK [vexxhost.containers.containerd : Create folders for configuration] *******\nFriday 08 May 2026  10:17:54 +0000 (0:00:00.705)       0:00:30.785 ************\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] **********\nFriday 08 May 2026  10:17:55 +0000 (0:00:01.496)       0:00:32.281 ************\nchanged: [controller]\n\nTASK [vexxhost.containers.containerd : Force any restarts if necessary] ********\nFriday 08 May 2026  10:17:56 +0000 (0:00:00.814)       0:00:33.095 ************\n\nRUNNING HANDLER [vexxhost.containers.containerd : Restart containerd] **********\nFriday 08 May 2026  10:17:56 +0000 (0:00:00.006)       0:00:33.101 ************\nchanged: [controller]\n\nRUNNING HANDLER [vexxhost.kubernetes.kubelet : Reload systemd] *****************\nFriday 08 May 2026  10:17:57 +0000 (0:00:00.873)       0:00:33.975 ************\nok: [controller]\n\nTASK [vexxhost.containers.containerd : Enable and start service] ***************\nFriday 08 May 2026  10:17:58 +0000 (0:00:00.944)       0:00:34.920 ************\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes_upgrade_check : Retrieve the \"kubeadm-config\" ConfigMap] ***\nFriday 08 May 2026  10:17:59 +0000 (0:00:00.765)       0:00:35.685 ************\n[ERROR]: Task failed: Module failed: Failed to import the required Python library (kubernetes) on np0000172681's Python /usr/bin/python3.12. 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 np0000172681's Python /usr/bin/python3.12. 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] ***\nFriday 08 May 2026  10:17:59 +0000 (0:00:00.737)       0:00:36.423 ************\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes_upgrade_check : Retrieve the current Kubernetes version] ***\nFriday 08 May 2026  10:17:59 +0000 (0:00:00.033)       0:00:36.457 ************\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes_upgrade_check : Extract major, minor, and patch versions] ***\nFriday 08 May 2026  10:17:59 +0000 (0:00:00.035)       0:00:36.492 ************\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes_upgrade_check : Fail if we're jumping more than one minor version] ***\nFriday 08 May 2026  10:17:59 +0000 (0:00:00.036)       0:00:36.529 ************\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes_upgrade_check : Set fact if we need to upgrade] ***\nFriday 08 May 2026  10:17:59 +0000 (0:00:00.035)       0:00:36.564 ************\nskipping: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nFriday 08 May 2026  10:18:00 +0000 (0:00:00.040)       0:00:36.604 ************\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nFriday 08 May 2026  10:18:00 +0000 (0:00:00.328)       0:00:36.933 ************\nok: [controller] => {\n    \"msg\": \"https://dl.k8s.io/release/v1.28.13/bin/linux/amd64/kubeadm\"\n}\n\nTASK [vexxhost.containers.download_artifact : Download item] *******************\nFriday 08 May 2026  10:18:00 +0000 (0:00:00.050)       0:00:36.983 ************\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nFriday 08 May 2026  10:18:02 +0000 (0:00:01.630)       0:00:38.613 ************\nskipping: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nFriday 08 May 2026  10:18:02 +0000 (0:00:00.040)       0:00:38.654 ************\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nFriday 08 May 2026  10:18:02 +0000 (0:00:00.305)       0:00:38.959 ************\nok: [controller] => {\n    \"msg\": \"https://dl.k8s.io/release/v1.28.13/bin/linux/amd64/kubectl\"\n}\n\nTASK [vexxhost.containers.download_artifact : Download item] *******************\nFriday 08 May 2026  10:18:02 +0000 (0:00:00.046)       0:00:39.006 ************\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nFriday 08 May 2026  10:18:03 +0000 (0:00:01.014)       0:00:40.021 ************\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Install SELinux packages] ***************\nFriday 08 May 2026  10:18:03 +0000 (0:00:00.044)       0:00:40.065 ************\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Set SELinux to permissive at runtime] ***\nFriday 08 May 2026  10:18:03 +0000 (0:00:00.030)       0:00:40.096 ************\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Persist SELinux permissive mode] ********\nFriday 08 May 2026  10:18:03 +0000 (0:00:00.028)       0:00:40.124 ************\nskipping: [controller]\n\nTASK [vexxhost.containers.containerd : Install AppArmor packages] **************\nFriday 08 May 2026  10:18:03 +0000 (0:00:00.032)       0:00:40.157 ************\nok: [controller]\n\nTASK [vexxhost.containers.containerd : Create systemd service file for containerd] ***\nFriday 08 May 2026  10:18:04 +0000 (0:00:01.252)       0:00:41.409 ************\nok: [controller]\n\nTASK [vexxhost.containers.containerd : Create folders for configuration] *******\nFriday 08 May 2026  10:18:05 +0000 (0:00:00.693)       0:00:42.103 ************\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] **********\nFriday 08 May 2026  10:18:06 +0000 (0:00:01.462)       0:00:43.565 ************\nok: [controller]\n\nTASK [vexxhost.containers.containerd : Force any restarts if necessary] ********\nFriday 08 May 2026  10:18:07 +0000 (0:00:00.792)       0:00:44.357 ************\n\nTASK [vexxhost.containers.containerd : Enable and start service] ***************\nFriday 08 May 2026  10:18:07 +0000 (0:00:00.003)       0:00:44.361 ************\nok: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nFriday 08 May 2026  10:18:08 +0000 (0:00:00.506)       0:00:44.867 ************\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nFriday 08 May 2026  10:18:08 +0000 (0:00:00.320)       0:00:45.187 ************\nok: [controller] => {\n    \"msg\": \"https://github.com/kubernetes-sigs/cri-tools/releases/download/v1.35.0/crictl-v1.35.0-linux-amd64.tar.gz\"\n}\n\nTASK [vexxhost.containers.download_artifact : Download item] *******************\nFriday 08 May 2026  10:18:08 +0000 (0:00:00.061)       0:00:45.249 ************\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nFriday 08 May 2026  10:18:09 +0000 (0:00:00.805)       0:00:46.054 ************\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nFriday 08 May 2026  10:18:11 +0000 (0:00:01.665)       0:00:47.720 ************\nok: [controller] => {\n    \"msg\": \"https://github.com/kubernetes-sigs/cri-tools/releases/download/v1.35.0/critest-v1.35.0-linux-amd64.tar.gz\"\n}\n\nTASK [vexxhost.containers.download_artifact : Download item] *******************\nFriday 08 May 2026  10:18:11 +0000 (0:00:00.064)       0:00:47.784 ************\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nFriday 08 May 2026  10:18:11 +0000 (0:00:00.783)       0:00:48.567 ************\nchanged: [controller]\n\nTASK [vexxhost.containers.cri_tools : Create crictl config] ********************\nFriday 08 May 2026  10:18:13 +0000 (0:00:01.698)       0:00:50.266 ************\nchanged: [controller]\n\nTASK [vexxhost.containers.directory : Create directory (/opt/cni/bin)] *********\nFriday 08 May 2026  10:18:14 +0000 (0:00:00.706)       0:00:50.973 ************\nchanged: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nFriday 08 May 2026  10:18:14 +0000 (0:00:00.324)       0:00:51.298 ************\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nFriday 08 May 2026  10:18:15 +0000 (0:00:00.313)       0:00:51.612 ************\nok: [controller] => {\n    \"msg\": \"https://github.com/containernetworking/plugins/releases/download/v1.9.1/cni-plugins-linux-amd64-v1.9.1.tgz\"\n}\n\nTASK [vexxhost.containers.download_artifact : Download item] *******************\nFriday 08 May 2026  10:18:15 +0000 (0:00:00.062)       0:00:51.675 ************\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nFriday 08 May 2026  10:18:16 +0000 (0:00:00.996)       0:00:52.672 ************\nchanged: [controller]\n\nTASK [vexxhost.containers.cni_plugins : Gather variables for each operating system] ***\nFriday 08 May 2026  10:18:20 +0000 (0:00:03.946)       0:00:56.618 ************\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] ***********\nFriday 08 May 2026  10:18:20 +0000 (0:00:00.054)       0:00:56.672 ************\nok: [controller]\n\nTASK [vexxhost.containers.cni_plugins : Ensure IPv6 is enabled] ****************\nFriday 08 May 2026  10:18:21 +0000 (0:00:01.269)       0:00:57.942 ************\nchanged: [controller]\n\nTASK [vexxhost.containers.cni_plugins : Enable kernel modules on-boot] *********\nFriday 08 May 2026  10:18:21 +0000 (0:00:00.447)       0:00:58.389 ************\nchanged: [controller]\n\nTASK [vexxhost.containers.cni_plugins : Enable kernel modules in runtime] ******\nFriday 08 May 2026  10:18:22 +0000 (0:00:00.710)       0:00:59.100 ************\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] *********************\nFriday 08 May 2026  10:18:23 +0000 (0:00:01.365)       0:01:00.465 ************\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nFriday 08 May 2026  10:18:24 +0000 (0:00:00.313)       0:01:00.778 ************\nok: [controller] => {\n    \"msg\": \"https://dl.k8s.io/release/v1.28.13/bin/linux/amd64/kubelet\"\n}\n\nTASK [vexxhost.containers.download_artifact : Download item] *******************\nFriday 08 May 2026  10:18:24 +0000 (0:00:00.046)       0:01:00.825 ************\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nFriday 08 May 2026  10:18:25 +0000 (0:00:01.240)       0:01:02.066 ************\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Gather variables for each operating system] ***\nFriday 08 May 2026  10:18:25 +0000 (0:00:00.037)       0:01:02.104 ************\nok: [controller] => (item=/home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubelet/vars/debian.yml)\n\nTASK [vexxhost.kubernetes.kubelet : Install coreutils] *************************\nFriday 08 May 2026  10:18:25 +0000 (0:00:00.053)       0:01:02.158 ************\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Install additional packages] ***************\nFriday 08 May 2026  10:18:25 +0000 (0:00:00.030)       0:01:02.188 ************\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Configure sysctl values] *******************\nFriday 08 May 2026  10:18:29 +0000 (0:00:03.914)       0:01:06.103 ************\nchanged: [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] ***\nFriday 08 May 2026  10:18:31 +0000 (0:00:02.090)       0:01:08.193 ************\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] ********\nFriday 08 May 2026  10:18:32 +0000 (0:00:00.864)       0:01:09.058 ************\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Add kubeadm dropin for kubelet systemd service config] ***\nFriday 08 May 2026  10:18:33 +0000 (0:00:00.689)       0:01:09.748 ************\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Check swap status] *************************\nFriday 08 May 2026  10:18:33 +0000 (0:00:00.706)       0:01:10.455 ************\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Disable swap] ******************************\nFriday 08 May 2026  10:18:34 +0000 (0:00:00.446)       0:01:10.901 ************\n[ERROR]: Task failed: Conditional result was '' of type 'str', which evaluates to False. Conditionals must have a boolean result.\n\nTask failed.\nOrigin: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubelet/tasks/main.yml:86:7\n\n84       register: kubelet_swapon\n85\n86     - name: Disable swap\n         ^ column 7\n\n<<< caused by >>>\n\nConditional result was '' of type 'str', which evaluates to False. Conditionals must have a boolean result.\nOrigin: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubelet/tasks/main.yml:91:11\n\n89       ignore_errors: \"{{ ansible_check_mode }}\"\n90       when:\n91         - 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 was '' of type 'str', which evaluates to False. Conditionals must have a boolean result.\"}\n...ignoring\n\nTASK [vexxhost.kubernetes.kubelet : Remove swapfile from /etc/fstab] ***********\nFriday 08 May 2026  10:18:34 +0000 (0:00:00.032)       0:01:10.933 ************\n[WARNING]: Deprecation warnings can be disabled by setting `deprecation_warnings=False` in ansible.cfg.\n[DEPRECATION WARNING]: Passing `warnings` to `exit_json` or `fail_json` is deprecated. This feature will be removed from ansible-core version 2.23. Use `AnsibleModule.warn` instead.\nok: [controller] => (item=swap)\nok: [controller] => (item=none)\n\nTASK [vexxhost.kubernetes.kubelet : Create noswap systemd service config file] ***\nFriday 08 May 2026  10:18:35 +0000 (0:00:00.738)       0:01:11.672 ************\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Enable noswap service] *********************\nFriday 08 May 2026  10:18:35 +0000 (0:00:00.695)       0:01:12.368 ************\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Force any restarts if necessary] ***********\nFriday 08 May 2026  10:18:36 +0000 (0:00:00.722)       0:01:13.091 ************\n\nRUNNING HANDLER [vexxhost.kubernetes.kubelet : Reload systemd] *****************\nFriday 08 May 2026  10:18:36 +0000 (0:00:00.005)       0:01:13.096 ************\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Enable and start kubelet service] **********\nFriday 08 May 2026  10:18:37 +0000 (0:00:00.925)       0:01:14.022 ************\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Ensure availability of dbus on Debian] *****\nFriday 08 May 2026  10:18:38 +0000 (0:00:00.781)       0:01:14.803 ************\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Configure short hostname] ******************\nFriday 08 May 2026  10:18:39 +0000 (0:00:01.025)       0:01:15.829 ************\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubelet : Ensure hostname inside hosts file] *********\nFriday 08 May 2026  10:18:40 +0000 (0:00:00.877)       0:01:16.706 ************\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Remove kubernetes repository] ***********\nFriday 08 May 2026  10:18:40 +0000 (0:00:00.449)       0:01:17.155 ************\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Setup control plane] ********************\nFriday 08 May 2026  10:18:41 +0000 (0:00:00.590)       0:01:17.745 ************\nincluded: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubernetes/tasks/control-plane.yml for controller\n\nTASK [vexxhost.kubernetes.kubernetes : Bootstrap cluster] **********************\nFriday 08 May 2026  10:18:41 +0000 (0:00:00.083)       0:01:17.829 ************\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] ***\nFriday 08 May 2026  10:18:41 +0000 (0:00:00.080)       0:01:17.909 ************\nok: [controller] => (item=controller)\n\nTASK [vexxhost.kubernetes.kubernetes : Pick node from pre-existing cluster] ****\nFriday 08 May 2026  10:18:41 +0000 (0:00:00.320)       0:01:18.230 ************\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Select first node to initialize cluster] ***\nFriday 08 May 2026  10:18:41 +0000 (0:00:00.040)       0:01:18.271 ************\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Print selected bootstrap node] **********\nFriday 08 May 2026  10:18:41 +0000 (0:00:00.049)       0:01:18.320 ************\nok: [controller] => {\n    \"msg\": \"controller\"\n}\n\nTASK [vexxhost.kubernetes.kubernetes : Upload cluster configuration for bootstrap node] ***\nFriday 08 May 2026  10:18:41 +0000 (0:00:00.038)       0:01:18.358 ************\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create pki folder] **********************\nFriday 08 May 2026  10:18:42 +0000 (0:00:00.739)       0:01:19.098 ************\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create kubernetes ca key] ***************\nFriday 08 May 2026  10:18:42 +0000 (0:00:00.036)       0:01:19.135 ************\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create kubernetes ca cert] **************\nFriday 08 May 2026  10:18:42 +0000 (0:00:00.034)       0:01:19.169 ************\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create etcd-ca key] *********************\nFriday 08 May 2026  10:18:42 +0000 (0:00:00.031)       0:01:19.201 ************\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create etcd-ca cert] ********************\nFriday 08 May 2026  10:18:42 +0000 (0:00:00.031)       0:01:19.233 ************\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create front-proxy-ca key] **************\nFriday 08 May 2026  10:18:42 +0000 (0:00:00.031)       0:01:19.265 ************\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create front-proxy-ca cert] *************\nFriday 08 May 2026  10:18:42 +0000 (0:00:00.032)       0:01:19.298 ************\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Initialize cluster] *********************\nFriday 08 May 2026  10:18:42 +0000 (0:00:00.035)       0:01:19.333 ************\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Check if the node is already part of the cluster] ***\nFriday 08 May 2026  10:19:12 +0000 (0:00:29.659)       0:01:48.993 ************\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Join cluster] ***************************\nFriday 08 May 2026  10:19:12 +0000 (0:00:00.333)       0:01:49.326 ************\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Create folder for admin configuration] ***\nFriday 08 May 2026  10:19:12 +0000 (0:00:00.034)       0:01:49.361 ************\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Creating a symlink for admin configuration file] ***\nFriday 08 May 2026  10:19:13 +0000 (0:00:00.332)       0:01:49.694 ************\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Add bash autocomplete for kubectl] ******\nFriday 08 May 2026  10:19:13 +0000 (0:00:00.314)       0:01:50.008 ************\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Install PIP] ****************************\nFriday 08 May 2026  10:19:13 +0000 (0:00:00.311)       0:01:50.319 ************\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Install Kubernetes Python package using pip on supported systems] ***\nFriday 08 May 2026  10:19:13 +0000 (0:00:00.038)       0:01:50.357 ************\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Enable EPEL repository] *****************\nFriday 08 May 2026  10:19:13 +0000 (0:00:00.036)       0:01:50.394 ************\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Install Kubernetes Python package using package manager on supported systems] ***\nFriday 08 May 2026  10:19:13 +0000 (0:00:00.036)       0:01:50.431 ************\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Allow workload on control plane node] ***\nFriday 08 May 2026  10:19:29 +0000 (0:00:16.077)       0:02:06.508 ************\n[WARNING]: kubernetes<24.2.0 is not supported or tested. Some features may not work.\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Remove kube-proxy resources] ************\nFriday 08 May 2026  10:19:30 +0000 (0:00:00.899)       0:02:07.408 ************\nskipping: [controller] => (item=DaemonSet)\nskipping: [controller] => (item=ConfigMap)\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Start an upgrade] ***********************\nFriday 08 May 2026  10:19:30 +0000 (0:00:00.039)       0:02:07.447 ************\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Check if the Kubernetes API services is up to date] ***\nFriday 08 May 2026  10:19:30 +0000 (0:00:00.036)       0:02:07.484 ************\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Trigger an upgrade of the Kubernetes API services] ***\nFriday 08 May 2026  10:19:30 +0000 (0:00:00.030)       0:02:07.515 ************\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Setup nodes] ****************************\nFriday 08 May 2026  10:19:30 +0000 (0:00:00.036)       0:02:07.551 ************\nskipping: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Upgrade & restart Kubelet node for upgrade (if needed)] ***\nFriday 08 May 2026  10:19:30 +0000 (0:00:00.031)       0:02:07.582 ************\nok: [controller]\n\nTASK [vexxhost.kubernetes.kubernetes : Set node selector for CoreDNS components] ***\nFriday 08 May 2026  10:19:31 +0000 (0:00:00.543)       0:02:08.126 ************\nchanged: [controller]\n\nPLAY [Install control-plane components] ****************************************\n\nTASK [Gathering Facts] *********************************************************\nFriday 08 May 2026  10:19:32 +0000 (0:00:01.010)       0:02:09.136 ************\nok: [controller]\n\nTASK [vexxhost.containers.forget_package : Forget package] *********************\nFriday 08 May 2026  10:19:33 +0000 (0:00:00.848)       0:02:09.985 ************\nok: [controller]\n\nTASK [vexxhost.containers.package : Update state for tar] **********************\nFriday 08 May 2026  10:19:33 +0000 (0:00:00.314)       0:02:10.300 ************\nok: [controller]\n\nTASK [vexxhost.containers.directory : Create directory (/var/lib/downloads)] ***\nFriday 08 May 2026  10:19:34 +0000 (0:00:01.037)       0:02:11.337 ************\nok: [controller]\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nFriday 08 May 2026  10:19:35 +0000 (0:00:00.312)       0:02:11.650 ************\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] *******************\nFriday 08 May 2026  10:19:35 +0000 (0:00:00.039)       0:02:11.689 ************\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nFriday 08 May 2026  10:19:36 +0000 (0:00:00.904)       0:02:12.593 ************\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.helm : Remove Helm repository] ***********************\nFriday 08 May 2026  10:19:37 +0000 (0:00:01.774)       0:02:14.368 ************\nok: [controller]\n\nTASK [vexxhost.kubernetes.helm : Add bash autocomplete for helm] ***************\nFriday 08 May 2026  10:19:38 +0000 (0:00:00.439)       0:02:14.808 ************\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.helm : Get Helm plugins dir] *************************\nFriday 08 May 2026  10:19:38 +0000 (0:00:00.310)       0:02:15.119 ************\nok: [controller]\n\nTASK [vexxhost.kubernetes.helm : Create Helm plugins directory if it does not exist] ***\nFriday 08 May 2026  10:19:38 +0000 (0:00:00.354)       0:02:15.473 ************\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.helm : Remove Helm diff plugin installed by kubernetes.core.helm_plugin] ***\nFriday 08 May 2026  10:19:39 +0000 (0:00:00.309)       0:02:15.783 ************\nok: [controller]\n\nTASK [Install plugin] **********************************************************\nFriday 08 May 2026  10:19:39 +0000 (0:00:00.314)       0:02:16.097 ************\nincluded: vexxhost.containers.download_artifact for controller\n\nTASK [vexxhost.containers.download_artifact : Starting download of file] *******\nFriday 08 May 2026  10:19:39 +0000 (0:00:00.050)       0:02:16.148 ************\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] *******************\nFriday 08 May 2026  10:19:39 +0000 (0:00:00.039)       0:02:16.187 ************\nchanged: [controller]\n\nTASK [vexxhost.containers.download_artifact : Extract archive] *****************\nFriday 08 May 2026  10:19:40 +0000 (0:00:00.818)       0:02:17.005 ************\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.upload_helm_chart : Include help chart upload method tasks] ***\nFriday 08 May 2026  10:19:43 +0000 (0:00:03.101)       0:02:20.107 ************\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] ***************\nFriday 08 May 2026  10:19:43 +0000 (0:00:00.037)       0:02:20.144 ************\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.cilium : Get current Kubernetes version] *************\nFriday 08 May 2026  10:19:44 +0000 (0:00:00.750)       0:02:20.894 ************\nok: [controller]\n\nTASK [vexxhost.kubernetes.cilium : Deploy Helm chart] **************************\nFriday 08 May 2026  10:19:45 +0000 (0:00:00.925)       0:02:21.819 ************\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.upload_helm_chart : Include help chart upload method tasks] ***\nFriday 08 May 2026  10:19:47 +0000 (0:00:02.155)       0:02:23.975 ************\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] ***************\nFriday 08 May 2026  10:19:47 +0000 (0:00:00.025)       0:02:24.001 ************\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.envoy_gateway : Deploy Helm chart] *******************\nFriday 08 May 2026  10:19:48 +0000 (0:00:00.600)       0:02:24.602 ************\nchanged: [controller]\n\nTASK [vexxhost.kubernetes.envoy_gateway : Create GatewayClass] *****************\nFriday 08 May 2026  10:20:19 +0000 (0:00:31.379)       0:02:55.982 ************\nchanged: [controller]\n\nPLAY RECAP *********************************************************************\ncontroller                 : ok=118  changed=54   unreachable=0    failed=0    skipped=34   rescued=0    ignored=3\n\n\nTASKS RECAP ********************************************************************\nFriday 08 May 2026  10:20:20 +0000 (0:00:00.804)       0:02:56.787 ************\n===============================================================================\nvexxhost.kubernetes.envoy_gateway : Deploy Helm chart ------------------ 31.38s\nvexxhost.kubernetes.kubernetes : Initialize cluster -------------------- 29.66s\nvexxhost.kubernetes.kubernetes : Install Kubernetes Python package using package manager on supported systems -- 16.08s\nvexxhost.containers.containerd : Install AppArmor packages -------------- 7.04s\nInstall Debian packages ------------------------------------------------- 6.22s\nvexxhost.containers.download_artifact : Extract archive ----------------- 3.95s\nvexxhost.kubernetes.kubelet : Install additional packages --------------- 3.91s\nvexxhost.containers.download_artifact : Extract archive ----------------- 3.20s\nvexxhost.containers.download_artifact : Extract archive ----------------- 3.10s\nvexxhost.kubernetes.cilium : Deploy Helm chart -------------------------- 2.16s\nvexxhost.kubernetes.kubelet : Configure sysctl values ------------------- 2.09s\nGathering Facts --------------------------------------------------------- 1.87s\nvexxhost.kubernetes.kubelet : Reload systemd ---------------------------- 1.87s\nvexxhost.containers.download_artifact : Extract archive ----------------- 1.77s\nvexxhost.containers.download_artifact : Extract archive ----------------- 1.70s\nvexxhost.containers.download_artifact : Extract archive ----------------- 1.67s\nvexxhost.containers.download_artifact : Download item ------------------- 1.63s\nvexxhost.containers.containerd : Create folders for configuration ------- 1.50s\nvexxhost.kubernetes.kube_vip : Uninstall legacy HA stack ---------------- 1.50s\nvexxhost.containers.containerd : Create folders for configuration ------- 1.46s\nINFO     [secretgen-controller > prepare] Executed: Successful\nINFO     [secretgen-controller > converge] Executing\n\nPLAY [Deploy \"secretgen-controller\"] *******************************************\n\nTASK [atmosphere.common.secretgen_controller : Deploy secretgen-controller] ****\nFriday 08 May 2026  10:20:21 +0000 (0:00:00.014)       0:00:00.014 ************\n[WARNING]: Host 'controller' is using the discovered Python interpreter at '/usr/bin/python3.12', but future installation of another Python interpreter could cause a different interpreter to be discovered. See https://docs.ansible.com/ansible-core/2.19/reference_appendices/interpreter_discovery.html for more information.\n[WARNING]: kubernetes<24.2.0 is not supported or tested. Some features may not work.\n[WARNING]: Deprecation warnings can be disabled by setting `deprecation_warnings=False` in ansible.cfg.\n[DEPRECATION WARNING]: Direct access to the `environment` attribute is deprecated. This feature will be removed from ansible-core version 2.23. Consider using `copy_with_new_env` or passing `overrides` to `template`.\nchanged: [controller]\n\nPLAY RECAP *********************************************************************\ncontroller                 : ok=1    changed=1    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0\n\n\nTASKS RECAP ********************************************************************\nFriday 08 May 2026  10:20:22 +0000 (0:00:01.418)       0:00:01.433 ************\n===============================================================================\natmosphere.common.secretgen_controller : Deploy secretgen-controller ---- 1.42s\nINFO     [secretgen-controller > converge] Executed: Successful\nINFO     [secretgen-controller > idempotence] Executing\n\nPLAY [Deploy \"secretgen-controller\"] *******************************************\n\nTASK [atmosphere.common.secretgen_controller : Deploy secretgen-controller] ****\nFriday 08 May 2026  10:20:23 +0000 (0:00:00.012)       0:00:00.012 ************\n[WARNING]: Host 'controller' is using the discovered Python interpreter at '/usr/bin/python3.12', but future installation of another Python interpreter could cause a different interpreter to be discovered. See https://docs.ansible.com/ansible-core/2.19/reference_appendices/interpreter_discovery.html for more information.\n[WARNING]: kubernetes<24.2.0 is not supported or tested. Some features may not work.\n[WARNING]: Deprecation warnings can be disabled by setting `deprecation_warnings=False` in ansible.cfg.\n[DEPRECATION WARNING]: Direct access to the `environment` attribute is deprecated. This feature will be removed from ansible-core version 2.23. Consider using `copy_with_new_env` or passing `overrides` to `template`.\nok: [controller]\n\nPLAY RECAP *********************************************************************\ncontroller                 : ok=1    changed=0    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0\n\n\nTASKS RECAP ********************************************************************\nFriday 08 May 2026  10:20:25 +0000 (0:00:01.482)       0:00:01.495 ************\n===============================================================================\natmosphere.common.secretgen_controller : Deploy secretgen-controller ---- 1.48s\nINFO     [secretgen-controller > idempotence] Executed: Successful\nINFO     [secretgen-controller > side_effect] Executing\nWARNING  [secretgen-controller > side_effect] Executed: Missing playbook (Remove from test_sequence to suppress)\nINFO     [secretgen-controller > verify] Executing\n\nPLAY [Verify] ******************************************************************\n\nTASK [Gathering Facts] *********************************************************\nFriday 08 May 2026  10:20:26 +0000 (0:00:00.008)       0:00:00.008 ************\n[WARNING]: Host 'controller' is using the discovered Python interpreter at '/usr/bin/python3.12', but future installation of another Python interpreter could cause a different interpreter to be discovered. See https://docs.ansible.com/ansible-core/2.19/reference_appendices/interpreter_discovery.html for more information.\nok: [controller]\n\nTASK [Wait for secretgen-controller deployment to be available] ****************\nFriday 08 May 2026  10:20:27 +0000 (0:00:01.352)       0:00:01.361 ************\n[WARNING]: kubernetes<24.2.0 is not supported or tested. Some features may not work.\nok: [controller]\n\nTASK [Create a test Password resource] *****************************************\nFriday 08 May 2026  10:20:28 +0000 (0:00:00.983)       0:00:02.345 ************\nchanged: [controller]\n\nTASK [Wait for test-password secret to be generated] ***************************\nFriday 08 May 2026  10:20:29 +0000 (0:00:01.030)       0:00:03.375 ************\nok: [controller]\n\nPLAY RECAP *********************************************************************\ncontroller                 : ok=4    changed=1    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0\n\n\nTASKS RECAP ********************************************************************\nFriday 08 May 2026  10:20:30 +0000 (0:00:00.798)       0:00:04.173 ************\n===============================================================================\nGathering Facts --------------------------------------------------------- 1.35s\nCreate a test Password resource ----------------------------------------- 1.03s\nWait for secretgen-controller deployment to be available ---------------- 0.98s\nWait for test-password secret to be generated --------------------------- 0.80s\nINFO     [secretgen-controller > verify] Executed: Successful\nINFO     [secretgen-controller > cleanup] Executing\nWARNING  [secretgen-controller > cleanup] Executed: Missing playbook (Remove from test_sequence to suppress)\nINFO     [secretgen-controller > destroy] Executing\nWARNING  [secretgen-controller > destroy] Skipping, '--destroy=never' requested.\nINFO     [secretgen-controller > destroy] Executed: Successful\nWARNING  Molecule executed 1 scenario (1 missing files)",
                            "stdout_lines": [
                                "Using CPython 3.12.3 interpreter at: /usr/bin/python3",
                                "Creating virtual environment at: .venv",
                                "warning: No `requires-python` value found in the workspace. Defaulting to `>=3.12`.",
                                "Downloading cryptography (4.3MiB)",
                                "Downloading kubernetes (1.9MiB)",
                                "Downloading pygments (1.2MiB)",
                                "Downloading ansible-core (2.3MiB)",
                                " Downloading cryptography",
                                " Downloading pygments",
                                " Downloading kubernetes",
                                " Downloading ansible-core",
                                "Installed 47 packages in 45ms",
                                "INFO     Collection 'atmosphere.common' detected.",
                                "INFO     Scenarios will be used from 'extensions/molecule'",
                                "INFO     [secretgen-controller > discovery] scenario test matrix: dependency, cleanup, destroy, syntax, create, prepare, converge, idempotence, side_effect, verify, cleanup, destroy",
                                "INFO     [secretgen-controller > prerun] Performing prerun with role_name_check=0...",
                                "INFO     [secretgen-controller > dependency] Executing",
                                "WARNING  [secretgen-controller > dependency] Missing roles requirements file: requirements.yml",
                                "WARNING  [secretgen-controller > dependency] Missing collections requirements file: collections.yml",
                                "WARNING  [secretgen-controller > dependency] Executed: 2 missing (Remove from test_sequence to suppress)",
                                "INFO     [secretgen-controller > cleanup] Executing",
                                "WARNING  [secretgen-controller > cleanup] Executed: Missing playbook (Remove from test_sequence to suppress)",
                                "INFO     [secretgen-controller > destroy] Executing",
                                "WARNING  [secretgen-controller > destroy] Skipping, '--destroy=never' requested.",
                                "INFO     [secretgen-controller > destroy] Executed: Successful",
                                "INFO     [secretgen-controller > syntax] Executing",
                                "",
                                "playbook: /home/zuul/src/github.com/vexxhost/atmosphere.common/extensions/molecule/secretgen-controller/converge.yml",
                                "INFO     [secretgen-controller > syntax] Executed: Successful",
                                "INFO     [secretgen-controller > create] Executing",
                                "WARNING  [secretgen-controller > create] Executed: Missing playbook (Remove from test_sequence to suppress)",
                                "INFO     [secretgen-controller > prepare] Executing",
                                "",
                                "PLAY [Prepare] *****************************************************************",
                                "",
                                "TASK [Gathering Facts] *********************************************************",
                                "Friday 08 May 2026  10:17:23 +0000 (0:00:00.032)       0:00:00.032 ************",
                                "[WARNING]: Host 'controller' is using the discovered Python interpreter at '/usr/bin/python3.12', but future installation of another Python interpreter could cause a different interpreter to be discovered. See https://docs.ansible.com/ansible-core/2.19/reference_appendices/interpreter_discovery.html for more information.",
                                "ok: [controller]",
                                "",
                                "TASK [Install Debian packages] *************************************************",
                                "Friday 08 May 2026  10:17:24 +0000 (0:00:01.329)       0:00:01.361 ************",
                                "ok: [controller]",
                                "",
                                "PLAY [Configure Kubernetes VIP] ************************************************",
                                "",
                                "TASK [Gathering Facts] *********************************************************",
                                "Friday 08 May 2026  10:17:30 +0000 (0:00:06.217)       0:00:07.579 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.directory : Create directory (/etc/kubernetes/manifests)] ***",
                                "Friday 08 May 2026  10:17:32 +0000 (0:00:01.871)       0:00:09.450 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Uninstall legacy HA stack] ****************",
                                "Friday 08 May 2026  10:17:33 +0000 (0:00:00.453)       0:00:09.904 ************",
                                "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] ****",
                                "Friday 08 May 2026  10:17:34 +0000 (0:00:01.495)       0:00:11.400 ************",
                                "[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] *********",
                                "Friday 08 May 2026  10:17:35 +0000 (0:00:00.992)       0:00:12.392 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Check if kubeadm has already run] *********",
                                "Friday 08 May 2026  10:17:36 +0000 (0:00:00.429)       0:00:12.822 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Set fact with KUBECONFIG path] ************",
                                "Friday 08 May 2026  10:17:36 +0000 (0:00:00.314)       0:00:13.136 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Set fact with KUBECONFIG path (with super-admin.conf)] ***",
                                "Friday 08 May 2026  10:17:36 +0000 (0:00:00.031)       0:00:13.168 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Upload Kubernetes manifest] ***************",
                                "Friday 08 May 2026  10:17:36 +0000 (0:00:00.043)       0:00:13.212 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Ensure kube-vip configuration file] *******",
                                "Friday 08 May 2026  10:17:37 +0000 (0:00:00.981)       0:00:14.193 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kube_vip : Flush handlers] ***************************",
                                "Friday 08 May 2026  10:17:37 +0000 (0:00:00.312)       0:00:14.506 ************",
                                "",
                                "PLAY [Install Kubernetes] ******************************************************",
                                "",
                                "TASK [Gathering Facts] *********************************************************",
                                "Friday 08 May 2026  10:17:37 +0000 (0:00:00.048)       0:00:14.554 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Friday 08 May 2026  10:17:38 +0000 (0:00:00.882)       0:00:15.436 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.package : Update state for tar] **********************",
                                "Friday 08 May 2026  10:17:39 +0000 (0:00:00.392)       0:00:15.829 ************",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.directory : Create directory (/var/lib/downloads)] ***",
                                "Friday 08 May 2026  10:17:39 +0000 (0:00:00.031)       0:00:15.861 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Friday 08 May 2026  10:17:39 +0000 (0:00:00.317)       0:00:16.179 ************",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://github.com/opencontainers/runc/releases/download/v1.4.2/runc.amd64\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Friday 08 May 2026  10:17:39 +0000 (0:00:00.073)       0:00:16.252 ************",
                                "[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 [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Friday 08 May 2026  10:17:40 +0000 (0:00:01.122)       0:00:17.374 ************",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Friday 08 May 2026  10:17:40 +0000 (0:00:00.035)       0:00:17.409 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.package : Update state for tar] **********************",
                                "Friday 08 May 2026  10:17:41 +0000 (0:00:00.306)       0:00:17.716 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Friday 08 May 2026  10:17:42 +0000 (0:00:01.045)       0:00:18.761 ************",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://github.com/containerd/containerd/releases/download/v2.2.3/containerd-2.2.3-linux-amd64.tar.gz\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Friday 08 May 2026  10:17:42 +0000 (0:00:00.073)       0:00:18.835 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Friday 08 May 2026  10:17:43 +0000 (0:00:00.904)       0:00:19.739 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Install SELinux packages] ***************",
                                "Friday 08 May 2026  10:17:46 +0000 (0:00:03.201)       0:00:22.941 ************",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Set SELinux to permissive at runtime] ***",
                                "Friday 08 May 2026  10:17:46 +0000 (0:00:00.033)       0:00:22.974 ************",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Persist SELinux permissive mode] ********",
                                "Friday 08 May 2026  10:17:46 +0000 (0:00:00.032)       0:00:23.007 ************",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Install AppArmor packages] **************",
                                "Friday 08 May 2026  10:17:46 +0000 (0:00:00.032)       0:00:23.040 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Create systemd service file for containerd] ***",
                                "Friday 08 May 2026  10:17:53 +0000 (0:00:07.039)       0:00:30.080 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Create folders for configuration] *******",
                                "Friday 08 May 2026  10:17:54 +0000 (0:00:00.705)       0:00:30.785 ************",
                                "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] **********",
                                "Friday 08 May 2026  10:17:55 +0000 (0:00:01.496)       0:00:32.281 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Force any restarts if necessary] ********",
                                "Friday 08 May 2026  10:17:56 +0000 (0:00:00.814)       0:00:33.095 ************",
                                "",
                                "RUNNING HANDLER [vexxhost.containers.containerd : Restart containerd] **********",
                                "Friday 08 May 2026  10:17:56 +0000 (0:00:00.006)       0:00:33.101 ************",
                                "changed: [controller]",
                                "",
                                "RUNNING HANDLER [vexxhost.kubernetes.kubelet : Reload systemd] *****************",
                                "Friday 08 May 2026  10:17:57 +0000 (0:00:00.873)       0:00:33.975 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Enable and start service] ***************",
                                "Friday 08 May 2026  10:17:58 +0000 (0:00:00.944)       0:00:34.920 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes_upgrade_check : Retrieve the \"kubeadm-config\" ConfigMap] ***",
                                "Friday 08 May 2026  10:17:59 +0000 (0:00:00.765)       0:00:35.685 ************",
                                "[ERROR]: Task failed: Module failed: Failed to import the required Python library (kubernetes) on np0000172681's Python /usr/bin/python3.12. 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 np0000172681's Python /usr/bin/python3.12. 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] ***",
                                "Friday 08 May 2026  10:17:59 +0000 (0:00:00.737)       0:00:36.423 ************",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes_upgrade_check : Retrieve the current Kubernetes version] ***",
                                "Friday 08 May 2026  10:17:59 +0000 (0:00:00.033)       0:00:36.457 ************",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes_upgrade_check : Extract major, minor, and patch versions] ***",
                                "Friday 08 May 2026  10:17:59 +0000 (0:00:00.035)       0:00:36.492 ************",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes_upgrade_check : Fail if we're jumping more than one minor version] ***",
                                "Friday 08 May 2026  10:17:59 +0000 (0:00:00.036)       0:00:36.529 ************",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes_upgrade_check : Set fact if we need to upgrade] ***",
                                "Friday 08 May 2026  10:17:59 +0000 (0:00:00.035)       0:00:36.564 ************",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Friday 08 May 2026  10:18:00 +0000 (0:00:00.040)       0:00:36.604 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Friday 08 May 2026  10:18:00 +0000 (0:00:00.328)       0:00:36.933 ************",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://dl.k8s.io/release/v1.28.13/bin/linux/amd64/kubeadm\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Friday 08 May 2026  10:18:00 +0000 (0:00:00.050)       0:00:36.983 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Friday 08 May 2026  10:18:02 +0000 (0:00:01.630)       0:00:38.613 ************",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Friday 08 May 2026  10:18:02 +0000 (0:00:00.040)       0:00:38.654 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Friday 08 May 2026  10:18:02 +0000 (0:00:00.305)       0:00:38.959 ************",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://dl.k8s.io/release/v1.28.13/bin/linux/amd64/kubectl\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Friday 08 May 2026  10:18:02 +0000 (0:00:00.046)       0:00:39.006 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Friday 08 May 2026  10:18:03 +0000 (0:00:01.014)       0:00:40.021 ************",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Install SELinux packages] ***************",
                                "Friday 08 May 2026  10:18:03 +0000 (0:00:00.044)       0:00:40.065 ************",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Set SELinux to permissive at runtime] ***",
                                "Friday 08 May 2026  10:18:03 +0000 (0:00:00.030)       0:00:40.096 ************",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Persist SELinux permissive mode] ********",
                                "Friday 08 May 2026  10:18:03 +0000 (0:00:00.028)       0:00:40.124 ************",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Install AppArmor packages] **************",
                                "Friday 08 May 2026  10:18:03 +0000 (0:00:00.032)       0:00:40.157 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Create systemd service file for containerd] ***",
                                "Friday 08 May 2026  10:18:04 +0000 (0:00:01.252)       0:00:41.409 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Create folders for configuration] *******",
                                "Friday 08 May 2026  10:18:05 +0000 (0:00:00.693)       0:00:42.103 ************",
                                "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] **********",
                                "Friday 08 May 2026  10:18:06 +0000 (0:00:01.462)       0:00:43.565 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.containerd : Force any restarts if necessary] ********",
                                "Friday 08 May 2026  10:18:07 +0000 (0:00:00.792)       0:00:44.357 ************",
                                "",
                                "TASK [vexxhost.containers.containerd : Enable and start service] ***************",
                                "Friday 08 May 2026  10:18:07 +0000 (0:00:00.003)       0:00:44.361 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Friday 08 May 2026  10:18:08 +0000 (0:00:00.506)       0:00:44.867 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Friday 08 May 2026  10:18:08 +0000 (0:00:00.320)       0:00:45.187 ************",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://github.com/kubernetes-sigs/cri-tools/releases/download/v1.35.0/crictl-v1.35.0-linux-amd64.tar.gz\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Friday 08 May 2026  10:18:08 +0000 (0:00:00.061)       0:00:45.249 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Friday 08 May 2026  10:18:09 +0000 (0:00:00.805)       0:00:46.054 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Friday 08 May 2026  10:18:11 +0000 (0:00:01.665)       0:00:47.720 ************",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://github.com/kubernetes-sigs/cri-tools/releases/download/v1.35.0/critest-v1.35.0-linux-amd64.tar.gz\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Friday 08 May 2026  10:18:11 +0000 (0:00:00.064)       0:00:47.784 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Friday 08 May 2026  10:18:11 +0000 (0:00:00.783)       0:00:48.567 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.cri_tools : Create crictl config] ********************",
                                "Friday 08 May 2026  10:18:13 +0000 (0:00:01.698)       0:00:50.266 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.directory : Create directory (/opt/cni/bin)] *********",
                                "Friday 08 May 2026  10:18:14 +0000 (0:00:00.706)       0:00:50.973 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Friday 08 May 2026  10:18:14 +0000 (0:00:00.324)       0:00:51.298 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Friday 08 May 2026  10:18:15 +0000 (0:00:00.313)       0:00:51.612 ************",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://github.com/containernetworking/plugins/releases/download/v1.9.1/cni-plugins-linux-amd64-v1.9.1.tgz\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Friday 08 May 2026  10:18:15 +0000 (0:00:00.062)       0:00:51.675 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Friday 08 May 2026  10:18:16 +0000 (0:00:00.996)       0:00:52.672 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.cni_plugins : Gather variables for each operating system] ***",
                                "Friday 08 May 2026  10:18:20 +0000 (0:00:03.946)       0:00:56.618 ************",
                                "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] ***********",
                                "Friday 08 May 2026  10:18:20 +0000 (0:00:00.054)       0:00:56.672 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.cni_plugins : Ensure IPv6 is enabled] ****************",
                                "Friday 08 May 2026  10:18:21 +0000 (0:00:01.269)       0:00:57.942 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.cni_plugins : Enable kernel modules on-boot] *********",
                                "Friday 08 May 2026  10:18:21 +0000 (0:00:00.447)       0:00:58.389 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.cni_plugins : Enable kernel modules in runtime] ******",
                                "Friday 08 May 2026  10:18:22 +0000 (0:00:00.710)       0:00:59.100 ************",
                                "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] *********************",
                                "Friday 08 May 2026  10:18:23 +0000 (0:00:01.365)       0:01:00.465 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Friday 08 May 2026  10:18:24 +0000 (0:00:00.313)       0:01:00.778 ************",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://dl.k8s.io/release/v1.28.13/bin/linux/amd64/kubelet\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Friday 08 May 2026  10:18:24 +0000 (0:00:00.046)       0:01:00.825 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Friday 08 May 2026  10:18:25 +0000 (0:00:01.240)       0:01:02.066 ************",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Gather variables for each operating system] ***",
                                "Friday 08 May 2026  10:18:25 +0000 (0:00:00.037)       0:01:02.104 ************",
                                "ok: [controller] => (item=/home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubelet/vars/debian.yml)",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Install coreutils] *************************",
                                "Friday 08 May 2026  10:18:25 +0000 (0:00:00.053)       0:01:02.158 ************",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Install additional packages] ***************",
                                "Friday 08 May 2026  10:18:25 +0000 (0:00:00.030)       0:01:02.188 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Configure sysctl values] *******************",
                                "Friday 08 May 2026  10:18:29 +0000 (0:00:03.914)       0:01:06.103 ************",
                                "changed: [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] ***",
                                "Friday 08 May 2026  10:18:31 +0000 (0:00:02.090)       0:01:08.193 ************",
                                "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] ********",
                                "Friday 08 May 2026  10:18:32 +0000 (0:00:00.864)       0:01:09.058 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Add kubeadm dropin for kubelet systemd service config] ***",
                                "Friday 08 May 2026  10:18:33 +0000 (0:00:00.689)       0:01:09.748 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Check swap status] *************************",
                                "Friday 08 May 2026  10:18:33 +0000 (0:00:00.706)       0:01:10.455 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Disable swap] ******************************",
                                "Friday 08 May 2026  10:18:34 +0000 (0:00:00.446)       0:01:10.901 ************",
                                "[ERROR]: Task failed: Conditional result was '' of type 'str', which evaluates to False. Conditionals must have a boolean result.",
                                "",
                                "Task failed.",
                                "Origin: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubelet/tasks/main.yml:86:7",
                                "",
                                "84       register: kubelet_swapon",
                                "85",
                                "86     - name: Disable swap",
                                "         ^ column 7",
                                "",
                                "<<< caused by >>>",
                                "",
                                "Conditional result was '' of type 'str', which evaluates to False. Conditionals must have a boolean result.",
                                "Origin: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubelet/tasks/main.yml:91:11",
                                "",
                                "89       ignore_errors: \"{{ ansible_check_mode }}\"",
                                "90       when:",
                                "91         - 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 was '' of type 'str', which evaluates to False. Conditionals must have a boolean result.\"}",
                                "...ignoring",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Remove swapfile from /etc/fstab] ***********",
                                "Friday 08 May 2026  10:18:34 +0000 (0:00:00.032)       0:01:10.933 ************",
                                "[WARNING]: Deprecation warnings can be disabled by setting `deprecation_warnings=False` in ansible.cfg.",
                                "[DEPRECATION WARNING]: Passing `warnings` to `exit_json` or `fail_json` is deprecated. This feature will be removed from ansible-core version 2.23. Use `AnsibleModule.warn` instead.",
                                "ok: [controller] => (item=swap)",
                                "ok: [controller] => (item=none)",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Create noswap systemd service config file] ***",
                                "Friday 08 May 2026  10:18:35 +0000 (0:00:00.738)       0:01:11.672 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Enable noswap service] *********************",
                                "Friday 08 May 2026  10:18:35 +0000 (0:00:00.695)       0:01:12.368 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Force any restarts if necessary] ***********",
                                "Friday 08 May 2026  10:18:36 +0000 (0:00:00.722)       0:01:13.091 ************",
                                "",
                                "RUNNING HANDLER [vexxhost.kubernetes.kubelet : Reload systemd] *****************",
                                "Friday 08 May 2026  10:18:36 +0000 (0:00:00.005)       0:01:13.096 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Enable and start kubelet service] **********",
                                "Friday 08 May 2026  10:18:37 +0000 (0:00:00.925)       0:01:14.022 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Ensure availability of dbus on Debian] *****",
                                "Friday 08 May 2026  10:18:38 +0000 (0:00:00.781)       0:01:14.803 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Configure short hostname] ******************",
                                "Friday 08 May 2026  10:18:39 +0000 (0:00:01.025)       0:01:15.829 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubelet : Ensure hostname inside hosts file] *********",
                                "Friday 08 May 2026  10:18:40 +0000 (0:00:00.877)       0:01:16.706 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Remove kubernetes repository] ***********",
                                "Friday 08 May 2026  10:18:40 +0000 (0:00:00.449)       0:01:17.155 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Setup control plane] ********************",
                                "Friday 08 May 2026  10:18:41 +0000 (0:00:00.590)       0:01:17.745 ************",
                                "included: /home/zuul/.ansible/collections/ansible_collections/vexxhost/kubernetes/roles/kubernetes/tasks/control-plane.yml for controller",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Bootstrap cluster] **********************",
                                "Friday 08 May 2026  10:18:41 +0000 (0:00:00.083)       0:01:17.829 ************",
                                "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] ***",
                                "Friday 08 May 2026  10:18:41 +0000 (0:00:00.080)       0:01:17.909 ************",
                                "ok: [controller] => (item=controller)",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Pick node from pre-existing cluster] ****",
                                "Friday 08 May 2026  10:18:41 +0000 (0:00:00.320)       0:01:18.230 ************",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Select first node to initialize cluster] ***",
                                "Friday 08 May 2026  10:18:41 +0000 (0:00:00.040)       0:01:18.271 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Print selected bootstrap node] **********",
                                "Friday 08 May 2026  10:18:41 +0000 (0:00:00.049)       0:01:18.320 ************",
                                "ok: [controller] => {",
                                "    \"msg\": \"controller\"",
                                "}",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Upload cluster configuration for bootstrap node] ***",
                                "Friday 08 May 2026  10:18:41 +0000 (0:00:00.038)       0:01:18.358 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create pki folder] **********************",
                                "Friday 08 May 2026  10:18:42 +0000 (0:00:00.739)       0:01:19.098 ************",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create kubernetes ca key] ***************",
                                "Friday 08 May 2026  10:18:42 +0000 (0:00:00.036)       0:01:19.135 ************",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create kubernetes ca cert] **************",
                                "Friday 08 May 2026  10:18:42 +0000 (0:00:00.034)       0:01:19.169 ************",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create etcd-ca key] *********************",
                                "Friday 08 May 2026  10:18:42 +0000 (0:00:00.031)       0:01:19.201 ************",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create etcd-ca cert] ********************",
                                "Friday 08 May 2026  10:18:42 +0000 (0:00:00.031)       0:01:19.233 ************",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create front-proxy-ca key] **************",
                                "Friday 08 May 2026  10:18:42 +0000 (0:00:00.031)       0:01:19.265 ************",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create front-proxy-ca cert] *************",
                                "Friday 08 May 2026  10:18:42 +0000 (0:00:00.032)       0:01:19.298 ************",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Initialize cluster] *********************",
                                "Friday 08 May 2026  10:18:42 +0000 (0:00:00.035)       0:01:19.333 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Check if the node is already part of the cluster] ***",
                                "Friday 08 May 2026  10:19:12 +0000 (0:00:29.659)       0:01:48.993 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Join cluster] ***************************",
                                "Friday 08 May 2026  10:19:12 +0000 (0:00:00.333)       0:01:49.326 ************",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Create folder for admin configuration] ***",
                                "Friday 08 May 2026  10:19:12 +0000 (0:00:00.034)       0:01:49.361 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Creating a symlink for admin configuration file] ***",
                                "Friday 08 May 2026  10:19:13 +0000 (0:00:00.332)       0:01:49.694 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Add bash autocomplete for kubectl] ******",
                                "Friday 08 May 2026  10:19:13 +0000 (0:00:00.314)       0:01:50.008 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Install PIP] ****************************",
                                "Friday 08 May 2026  10:19:13 +0000 (0:00:00.311)       0:01:50.319 ************",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Install Kubernetes Python package using pip on supported systems] ***",
                                "Friday 08 May 2026  10:19:13 +0000 (0:00:00.038)       0:01:50.357 ************",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Enable EPEL repository] *****************",
                                "Friday 08 May 2026  10:19:13 +0000 (0:00:00.036)       0:01:50.394 ************",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Install Kubernetes Python package using package manager on supported systems] ***",
                                "Friday 08 May 2026  10:19:13 +0000 (0:00:00.036)       0:01:50.431 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Allow workload on control plane node] ***",
                                "Friday 08 May 2026  10:19:29 +0000 (0:00:16.077)       0:02:06.508 ************",
                                "[WARNING]: kubernetes<24.2.0 is not supported or tested. Some features may not work.",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Remove kube-proxy resources] ************",
                                "Friday 08 May 2026  10:19:30 +0000 (0:00:00.899)       0:02:07.408 ************",
                                "skipping: [controller] => (item=DaemonSet)",
                                "skipping: [controller] => (item=ConfigMap)",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Start an upgrade] ***********************",
                                "Friday 08 May 2026  10:19:30 +0000 (0:00:00.039)       0:02:07.447 ************",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Check if the Kubernetes API services is up to date] ***",
                                "Friday 08 May 2026  10:19:30 +0000 (0:00:00.036)       0:02:07.484 ************",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Trigger an upgrade of the Kubernetes API services] ***",
                                "Friday 08 May 2026  10:19:30 +0000 (0:00:00.030)       0:02:07.515 ************",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Setup nodes] ****************************",
                                "Friday 08 May 2026  10:19:30 +0000 (0:00:00.036)       0:02:07.551 ************",
                                "skipping: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Upgrade & restart Kubelet node for upgrade (if needed)] ***",
                                "Friday 08 May 2026  10:19:30 +0000 (0:00:00.031)       0:02:07.582 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.kubernetes : Set node selector for CoreDNS components] ***",
                                "Friday 08 May 2026  10:19:31 +0000 (0:00:00.543)       0:02:08.126 ************",
                                "changed: [controller]",
                                "",
                                "PLAY [Install control-plane components] ****************************************",
                                "",
                                "TASK [Gathering Facts] *********************************************************",
                                "Friday 08 May 2026  10:19:32 +0000 (0:00:01.010)       0:02:09.136 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.forget_package : Forget package] *********************",
                                "Friday 08 May 2026  10:19:33 +0000 (0:00:00.848)       0:02:09.985 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.package : Update state for tar] **********************",
                                "Friday 08 May 2026  10:19:33 +0000 (0:00:00.314)       0:02:10.300 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.directory : Create directory (/var/lib/downloads)] ***",
                                "Friday 08 May 2026  10:19:34 +0000 (0:00:01.037)       0:02:11.337 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Friday 08 May 2026  10:19:35 +0000 (0:00:00.312)       0:02:11.650 ************",
                                "ok: [controller] => {",
                                "    \"msg\": \"https://get.helm.sh/helm-v3.11.2-linux-amd64.tar.gz\"",
                                "}",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Download item] *******************",
                                "Friday 08 May 2026  10:19:35 +0000 (0:00:00.039)       0:02:11.689 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Friday 08 May 2026  10:19:36 +0000 (0:00:00.904)       0:02:12.593 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.helm : Remove Helm repository] ***********************",
                                "Friday 08 May 2026  10:19:37 +0000 (0:00:01.774)       0:02:14.368 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.helm : Add bash autocomplete for helm] ***************",
                                "Friday 08 May 2026  10:19:38 +0000 (0:00:00.439)       0:02:14.808 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.helm : Get Helm plugins dir] *************************",
                                "Friday 08 May 2026  10:19:38 +0000 (0:00:00.310)       0:02:15.119 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.helm : Create Helm plugins directory if it does not exist] ***",
                                "Friday 08 May 2026  10:19:38 +0000 (0:00:00.354)       0:02:15.473 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.helm : Remove Helm diff plugin installed by kubernetes.core.helm_plugin] ***",
                                "Friday 08 May 2026  10:19:39 +0000 (0:00:00.309)       0:02:15.783 ************",
                                "ok: [controller]",
                                "",
                                "TASK [Install plugin] **********************************************************",
                                "Friday 08 May 2026  10:19:39 +0000 (0:00:00.314)       0:02:16.097 ************",
                                "included: vexxhost.containers.download_artifact for controller",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Starting download of file] *******",
                                "Friday 08 May 2026  10:19:39 +0000 (0:00:00.050)       0:02:16.148 ************",
                                "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] *******************",
                                "Friday 08 May 2026  10:19:39 +0000 (0:00:00.039)       0:02:16.187 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.containers.download_artifact : Extract archive] *****************",
                                "Friday 08 May 2026  10:19:40 +0000 (0:00:00.818)       0:02:17.005 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.upload_helm_chart : Include help chart upload method tasks] ***",
                                "Friday 08 May 2026  10:19:43 +0000 (0:00:03.101)       0:02:20.107 ************",
                                "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] ***************",
                                "Friday 08 May 2026  10:19:43 +0000 (0:00:00.037)       0:02:20.144 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.cilium : Get current Kubernetes version] *************",
                                "Friday 08 May 2026  10:19:44 +0000 (0:00:00.750)       0:02:20.894 ************",
                                "ok: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.cilium : Deploy Helm chart] **************************",
                                "Friday 08 May 2026  10:19:45 +0000 (0:00:00.925)       0:02:21.819 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.upload_helm_chart : Include help chart upload method tasks] ***",
                                "Friday 08 May 2026  10:19:47 +0000 (0:00:02.155)       0:02:23.975 ************",
                                "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] ***************",
                                "Friday 08 May 2026  10:19:47 +0000 (0:00:00.025)       0:02:24.001 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.envoy_gateway : Deploy Helm chart] *******************",
                                "Friday 08 May 2026  10:19:48 +0000 (0:00:00.600)       0:02:24.602 ************",
                                "changed: [controller]",
                                "",
                                "TASK [vexxhost.kubernetes.envoy_gateway : Create GatewayClass] *****************",
                                "Friday 08 May 2026  10:20:19 +0000 (0:00:31.379)       0:02:55.982 ************",
                                "changed: [controller]",
                                "",
                                "PLAY RECAP *********************************************************************",
                                "controller                 : ok=118  changed=54   unreachable=0    failed=0    skipped=34   rescued=0    ignored=3",
                                "",
                                "",
                                "TASKS RECAP ********************************************************************",
                                "Friday 08 May 2026  10:20:20 +0000 (0:00:00.804)       0:02:56.787 ************",
                                "===============================================================================",
                                "vexxhost.kubernetes.envoy_gateway : Deploy Helm chart ------------------ 31.38s",
                                "vexxhost.kubernetes.kubernetes : Initialize cluster -------------------- 29.66s",
                                "vexxhost.kubernetes.kubernetes : Install Kubernetes Python package using package manager on supported systems -- 16.08s",
                                "vexxhost.containers.containerd : Install AppArmor packages -------------- 7.04s",
                                "Install Debian packages ------------------------------------------------- 6.22s",
                                "vexxhost.containers.download_artifact : Extract archive ----------------- 3.95s",
                                "vexxhost.kubernetes.kubelet : Install additional packages --------------- 3.91s",
                                "vexxhost.containers.download_artifact : Extract archive ----------------- 3.20s",
                                "vexxhost.containers.download_artifact : Extract archive ----------------- 3.10s",
                                "vexxhost.kubernetes.cilium : Deploy Helm chart -------------------------- 2.16s",
                                "vexxhost.kubernetes.kubelet : Configure sysctl values ------------------- 2.09s",
                                "Gathering Facts --------------------------------------------------------- 1.87s",
                                "vexxhost.kubernetes.kubelet : Reload systemd ---------------------------- 1.87s",
                                "vexxhost.containers.download_artifact : Extract archive ----------------- 1.77s",
                                "vexxhost.containers.download_artifact : Extract archive ----------------- 1.70s",
                                "vexxhost.containers.download_artifact : Extract archive ----------------- 1.67s",
                                "vexxhost.containers.download_artifact : Download item ------------------- 1.63s",
                                "vexxhost.containers.containerd : Create folders for configuration ------- 1.50s",
                                "vexxhost.kubernetes.kube_vip : Uninstall legacy HA stack ---------------- 1.50s",
                                "vexxhost.containers.containerd : Create folders for configuration ------- 1.46s",
                                "INFO     [secretgen-controller > prepare] Executed: Successful",
                                "INFO     [secretgen-controller > converge] Executing",
                                "",
                                "PLAY [Deploy \"secretgen-controller\"] *******************************************",
                                "",
                                "TASK [atmosphere.common.secretgen_controller : Deploy secretgen-controller] ****",
                                "Friday 08 May 2026  10:20:21 +0000 (0:00:00.014)       0:00:00.014 ************",
                                "[WARNING]: Host 'controller' is using the discovered Python interpreter at '/usr/bin/python3.12', but future installation of another Python interpreter could cause a different interpreter to be discovered. See https://docs.ansible.com/ansible-core/2.19/reference_appendices/interpreter_discovery.html for more information.",
                                "[WARNING]: kubernetes<24.2.0 is not supported or tested. Some features may not work.",
                                "[WARNING]: Deprecation warnings can be disabled by setting `deprecation_warnings=False` in ansible.cfg.",
                                "[DEPRECATION WARNING]: Direct access to the `environment` attribute is deprecated. This feature will be removed from ansible-core version 2.23. Consider using `copy_with_new_env` or passing `overrides` to `template`.",
                                "changed: [controller]",
                                "",
                                "PLAY RECAP *********************************************************************",
                                "controller                 : ok=1    changed=1    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0",
                                "",
                                "",
                                "TASKS RECAP ********************************************************************",
                                "Friday 08 May 2026  10:20:22 +0000 (0:00:01.418)       0:00:01.433 ************",
                                "===============================================================================",
                                "atmosphere.common.secretgen_controller : Deploy secretgen-controller ---- 1.42s",
                                "INFO     [secretgen-controller > converge] Executed: Successful",
                                "INFO     [secretgen-controller > idempotence] Executing",
                                "",
                                "PLAY [Deploy \"secretgen-controller\"] *******************************************",
                                "",
                                "TASK [atmosphere.common.secretgen_controller : Deploy secretgen-controller] ****",
                                "Friday 08 May 2026  10:20:23 +0000 (0:00:00.012)       0:00:00.012 ************",
                                "[WARNING]: Host 'controller' is using the discovered Python interpreter at '/usr/bin/python3.12', but future installation of another Python interpreter could cause a different interpreter to be discovered. See https://docs.ansible.com/ansible-core/2.19/reference_appendices/interpreter_discovery.html for more information.",
                                "[WARNING]: kubernetes<24.2.0 is not supported or tested. Some features may not work.",
                                "[WARNING]: Deprecation warnings can be disabled by setting `deprecation_warnings=False` in ansible.cfg.",
                                "[DEPRECATION WARNING]: Direct access to the `environment` attribute is deprecated. This feature will be removed from ansible-core version 2.23. Consider using `copy_with_new_env` or passing `overrides` to `template`.",
                                "ok: [controller]",
                                "",
                                "PLAY RECAP *********************************************************************",
                                "controller                 : ok=1    changed=0    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0",
                                "",
                                "",
                                "TASKS RECAP ********************************************************************",
                                "Friday 08 May 2026  10:20:25 +0000 (0:00:01.482)       0:00:01.495 ************",
                                "===============================================================================",
                                "atmosphere.common.secretgen_controller : Deploy secretgen-controller ---- 1.48s",
                                "INFO     [secretgen-controller > idempotence] Executed: Successful",
                                "INFO     [secretgen-controller > side_effect] Executing",
                                "WARNING  [secretgen-controller > side_effect] Executed: Missing playbook (Remove from test_sequence to suppress)",
                                "INFO     [secretgen-controller > verify] Executing",
                                "",
                                "PLAY [Verify] ******************************************************************",
                                "",
                                "TASK [Gathering Facts] *********************************************************",
                                "Friday 08 May 2026  10:20:26 +0000 (0:00:00.008)       0:00:00.008 ************",
                                "[WARNING]: Host 'controller' is using the discovered Python interpreter at '/usr/bin/python3.12', but future installation of another Python interpreter could cause a different interpreter to be discovered. See https://docs.ansible.com/ansible-core/2.19/reference_appendices/interpreter_discovery.html for more information.",
                                "ok: [controller]",
                                "",
                                "TASK [Wait for secretgen-controller deployment to be available] ****************",
                                "Friday 08 May 2026  10:20:27 +0000 (0:00:01.352)       0:00:01.361 ************",
                                "[WARNING]: kubernetes<24.2.0 is not supported or tested. Some features may not work.",
                                "ok: [controller]",
                                "",
                                "TASK [Create a test Password resource] *****************************************",
                                "Friday 08 May 2026  10:20:28 +0000 (0:00:00.983)       0:00:02.345 ************",
                                "changed: [controller]",
                                "",
                                "TASK [Wait for test-password secret to be generated] ***************************",
                                "Friday 08 May 2026  10:20:29 +0000 (0:00:01.030)       0:00:03.375 ************",
                                "ok: [controller]",
                                "",
                                "PLAY RECAP *********************************************************************",
                                "controller                 : ok=4    changed=1    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0",
                                "",
                                "",
                                "TASKS RECAP ********************************************************************",
                                "Friday 08 May 2026  10:20:30 +0000 (0:00:00.798)       0:00:04.173 ************",
                                "===============================================================================",
                                "Gathering Facts --------------------------------------------------------- 1.35s",
                                "Create a test Password resource ----------------------------------------- 1.03s",
                                "Wait for secretgen-controller deployment to be available ---------------- 0.98s",
                                "Wait for test-password secret to be generated --------------------------- 0.80s",
                                "INFO     [secretgen-controller > verify] Executed: Successful",
                                "INFO     [secretgen-controller > cleanup] Executing",
                                "WARNING  [secretgen-controller > cleanup] Executed: Missing playbook (Remove from test_sequence to suppress)",
                                "INFO     [secretgen-controller > destroy] Executing",
                                "WARNING  [secretgen-controller > destroy] Skipping, '--destroy=never' requested.",
                                "INFO     [secretgen-controller > destroy] Executed: Successful",
                                "WARNING  Molecule executed 1 scenario (1 missing files)"
                            ],
                            "zuul_log_id": "0242ac17-0010-36d7-0626-000000000006-1-controller"
                        }
                    },
                    "task": {
                        "duration": {
                            "end": "2026-05-08T10:20:31.102086Z",
                            "start": "2026-05-08T10:16:58.447339Z"
                        },
                        "id": "0242ac17-0010-36d7-0626-000000000006",
                        "name": "Run Molecule scenario"
                    }
                }
            ]
        }
    ],
    "stats": {
        "controller": {
            "changed": 3,
            "failures": 0,
            "ignored": 0,
            "ok": 3,
            "rescued": 0,
            "skipped": 0,
            "unreachable": 0
        }
    },
    "trusted": false
},
{
    "branch": "main",
    "index": "0",
    "phase": "post",
    "playbook": "github.com/vexxhost/zuul-config/playbooks/base/post.yaml",
    "plays": [
        {
            "play": {
                "duration": {
                    "end": "2026-05-08T10:20:35.004657Z",
                    "start": "2026-05-08T10:20:31.853244Z"
                },
                "id": "0242ac17-0010-e5da-6a66-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-e5da-6a66-000000000006",
                        "name": "fetch-output",
                        "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/fetch-output"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-05-08T10:20:31.911662Z",
                            "start": "2026-05-08T10:20:31.866466Z"
                        },
                        "id": "0242ac17-0010-e5da-6a66-000000000008",
                        "name": "Set log path for multiple nodes"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "set_fact",
                            "ansible_facts": {
                                "log_path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/work/logs"
                            },
                            "changed": false
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-e5da-6a66-000000000006",
                        "name": "fetch-output",
                        "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/fetch-output"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-05-08T10:20:31.968078Z",
                            "start": "2026-05-08T10:20:31.921653Z"
                        },
                        "id": "0242ac17-0010-e5da-6a66-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/268f0dd920d14ca1b3bff4b64a2e54d3/work/logs"
                                        },
                                        "before": {
                                            "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/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/268f0dd920d14ca1b3bff4b64a2e54d3/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/268f0dd920d14ca1b3bff4b64a2e54d3/work/logs",
                                    "size": 4096,
                                    "state": "directory",
                                    "uid": 0,
                                    "zj_output_dir": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/work/logs"
                                },
                                {
                                    "ansible_loop_var": "zj_output_dir",
                                    "changed": true,
                                    "diff": {
                                        "after": {
                                            "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/work/artifacts",
                                            "state": "directory"
                                        },
                                        "before": {
                                            "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/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/268f0dd920d14ca1b3bff4b64a2e54d3/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/268f0dd920d14ca1b3bff4b64a2e54d3/work/artifacts",
                                    "size": 4096,
                                    "state": "directory",
                                    "uid": 0,
                                    "zj_output_dir": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/work/artifacts"
                                },
                                {
                                    "ansible_loop_var": "zj_output_dir",
                                    "changed": true,
                                    "diff": {
                                        "after": {
                                            "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/work/docs",
                                            "state": "directory"
                                        },
                                        "before": {
                                            "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/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/268f0dd920d14ca1b3bff4b64a2e54d3/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/268f0dd920d14ca1b3bff4b64a2e54d3/work/docs",
                                    "size": 4096,
                                    "state": "directory",
                                    "uid": 0,
                                    "zj_output_dir": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/work/docs"
                                }
                            ]
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-e5da-6a66-000000000006",
                        "name": "fetch-output",
                        "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/fetch-output"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-05-08T10:20:32.772840Z",
                            "start": "2026-05-08T10:20:31.976266Z"
                        },
                        "id": "0242ac17-0010-e5da-6a66-00000000000a",
                        "name": "Ensure local output dirs"
                    }
                },
                {
                    "hosts": {
                        "controller": {
                            "action": "synchronize",
                            "changed": true,
                            "msg": "All items completed",
                            "results": [
                                {
                                    "ansible_loop_var": "zj_output",
                                    "changed": false,
                                    "cmd": "/usr/bin/rsync --delay-updates -F --compress --archive --no-owner --no-group --rsh='/usr/bin/ssh -S none -o Port=22' --out-format='<<CHANGED>>%i %n%L' zuul@199.204.45.216:/home/zuul/zuul-output/logs/ /var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/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/268f0dd920d14ca1b3bff4b64a2e54d3/work/logs/",
                                            "dest_port": 22,
                                            "dirs": false,
                                            "existing_only": false,
                                            "group": false,
                                            "link_dest": null,
                                            "links": null,
                                            "mode": "pull",
                                            "owner": false,
                                            "partial": false,
                                            "perms": null,
                                            "private_key": null,
                                            "recursive": null,
                                            "rsync_opts": [],
                                            "rsync_path": null,
                                            "rsync_timeout": 0,
                                            "set_remote_user": true,
                                            "src": "zuul@199.204.45.216:/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/268f0dd920d14ca1b3bff4b64a2e54d3/work/logs",
                                        "src": "logs"
                                    }
                                },
                                {
                                    "ansible_loop_var": "zj_output",
                                    "changed": true,
                                    "cmd": "/usr/bin/rsync --delay-updates -F --compress --archive --no-owner --no-group --rsh='/usr/bin/ssh -S none -o Port=22' --out-format='<<CHANGED>>%i %n%L' zuul@199.204.45.216:/home/zuul/zuul-output/artifacts/ /var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/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/268f0dd920d14ca1b3bff4b64a2e54d3/work/artifacts/",
                                            "dest_port": 22,
                                            "dirs": false,
                                            "existing_only": false,
                                            "group": false,
                                            "link_dest": null,
                                            "links": null,
                                            "mode": "pull",
                                            "owner": false,
                                            "partial": false,
                                            "perms": null,
                                            "private_key": null,
                                            "recursive": null,
                                            "rsync_opts": [],
                                            "rsync_path": null,
                                            "rsync_timeout": 0,
                                            "set_remote_user": true,
                                            "src": "zuul@199.204.45.216:/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/268f0dd920d14ca1b3bff4b64a2e54d3/work/artifacts",
                                        "src": "artifacts"
                                    }
                                },
                                {
                                    "ansible_loop_var": "zj_output",
                                    "changed": true,
                                    "cmd": "/usr/bin/rsync --delay-updates -F --compress --archive --no-owner --no-group --rsh='/usr/bin/ssh -S none -o Port=22' --out-format='<<CHANGED>>%i %n%L' zuul@199.204.45.216:/home/zuul/zuul-output/docs/ /var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/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/268f0dd920d14ca1b3bff4b64a2e54d3/work/docs/",
                                            "dest_port": 22,
                                            "dirs": false,
                                            "existing_only": false,
                                            "group": false,
                                            "link_dest": null,
                                            "links": null,
                                            "mode": "pull",
                                            "owner": false,
                                            "partial": false,
                                            "perms": null,
                                            "private_key": null,
                                            "recursive": null,
                                            "rsync_opts": [],
                                            "rsync_path": null,
                                            "rsync_timeout": 0,
                                            "set_remote_user": true,
                                            "src": "zuul@199.204.45.216:/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/268f0dd920d14ca1b3bff4b64a2e54d3/work/docs",
                                        "src": "docs"
                                    }
                                }
                            ]
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-e5da-6a66-000000000006",
                        "name": "fetch-output",
                        "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/fetch-output"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-05-08T10:20:34.327291Z",
                            "start": "2026-05-08T10:20:32.782784Z"
                        },
                        "id": "0242ac17-0010-e5da-6a66-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/268f0dd920d14ca1b3bff4b64a2e54d3/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/268f0dd920d14ca1b3bff4b64a2e54d3/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/268f0dd920d14ca1b3bff4b64a2e54d3/work/artifacts/* /var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/work/logs/artifacts\nfi\n",
                                    "delta": "0:00:00.006623",
                                    "end": "2026-05-08 10:20:34.732201",
                                    "failed": false,
                                    "invocation": {
                                        "module_args": {
                                            "_raw_params": "if [ -n \"$(find /var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/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/268f0dd920d14ca1b3bff4b64a2e54d3/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/268f0dd920d14ca1b3bff4b64a2e54d3/work/artifacts/* /var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/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-05-08 10:20:34.725578",
                                    "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/268f0dd920d14ca1b3bff4b64a2e54d3/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/268f0dd920d14ca1b3bff4b64a2e54d3/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/268f0dd920d14ca1b3bff4b64a2e54d3/work/docs/* /var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/work/logs/docs\nfi\n",
                                    "delta": "0:00:00.007096",
                                    "end": "2026-05-08 10:20:34.941204",
                                    "failed": false,
                                    "invocation": {
                                        "module_args": {
                                            "_raw_params": "if [ -n \"$(find /var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/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/268f0dd920d14ca1b3bff4b64a2e54d3/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/268f0dd920d14ca1b3bff4b64a2e54d3/work/docs/* /var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/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-05-08 10:20:34.934108",
                                    "stderr": "",
                                    "stderr_lines": [],
                                    "stdout": "",
                                    "stdout_lines": [],
                                    "zj_item": "docs",
                                    "zuul_log_id": "in-loop-ignore"
                                }
                            ]
                        }
                    },
                    "role": {
                        "id": "0242ac17-0010-e5da-6a66-00000000000f",
                        "name": "merge-output-to-logs",
                        "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/merge-output-to-logs"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-05-08T10:20:35.004657Z",
                            "start": "2026-05-08T10:20:34.344700Z"
                        },
                        "id": "0242ac17-0010-e5da-6a66-000000000011",
                        "name": "Move artifacts and docs to logs dir"
                    }
                }
            ]
        },
        {
            "play": {
                "duration": {
                    "end": "2026-05-08T10:20:35.475660Z",
                    "start": "2026-05-08T10:20:35.017838Z"
                },
                "id": "0242ac17-0010-e5da-6a66-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 AAAAB3NzaC1yc2EAAAADAQABAAABgQDdK9vF0BuPVWxC7SEWZ3ALK04EhUUuPXlOF0VfiK1QI7f9ZTXBj7Mq4SCSwRuo/KRQZgf0h/gIC3R6QJreZbJmQJ7StW4Ha21RlmWAXb/rab2ILoMfa60TOdbsKKkK9RPMxVtc/Ro5jboBEJypb7rTH9M6OaDwXTz0hvM+lpaBQoEzjCXK/gchewr22jljSCxpHf0IuxeAKlKp9UIoSNtbB1Gp2c+W4eBc6VXpGjUdDQrZnCJeywAPhwroghbHDGM1MXqwvTDLiD6WFW+aN98D0lAW5LGK4kijKsdzK3j6Lyb+OcAkRfMfCA8b9L2VyBG1d9vQcGJjeEkQxJZyar+7XQW2wSjWDcFjXnW51BfuHfRkoB6mos6sEjzbw7gnWYX552VnXraCv3KdH1NI8mEjJL5/GXuGTlRAAHwSqIpRHspazxUL7wuiX6z5mSv31n8/GK3pqHLSF07s5ce36Mpx7JlZYC9bP6lbcavl8uHTjEQ5PYC8nigIWU1oS+Bikfk= 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 AAAAB3NzaC1yc2EAAAADAQABAAABgQDdK9vF0BuPVWxC7SEWZ3ALK04EhUUuPXlOF0VfiK1QI7f9ZTXBj7Mq4SCSwRuo/KRQZgf0h/gIC3R6QJreZbJmQJ7StW4Ha21RlmWAXb/rab2ILoMfa60TOdbsKKkK9RPMxVtc/Ro5jboBEJypb7rTH9M6OaDwXTz0hvM+lpaBQoEzjCXK/gchewr22jljSCxpHf0IuxeAKlKp9UIoSNtbB1Gp2c+W4eBc6VXpGjUdDQrZnCJeywAPhwroghbHDGM1MXqwvTDLiD6WFW+aN98D0lAW5LGK4kijKsdzK3j6Lyb+OcAkRfMfCA8b9L2VyBG1d9vQcGJjeEkQxJZyar+7XQW2wSjWDcFjXnW51BfuHfRkoB6mos6sEjzbw7gnWYX552VnXraCv3KdH1NI8mEjJL5/GXuGTlRAAHwSqIpRHspazxUL7wuiX6z5mSv31n8/GK3pqHLSF07s5ce36Mpx7JlZYC9bP6lbcavl8uHTjEQ5PYC8nigIWU1oS+Bikfk= 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-e5da-6a66-000000000016",
                        "name": "remove-build-sshkey",
                        "path": "/var/lib/zuul/builds/268f0dd920d14ca1b3bff4b64a2e54d3/trusted/project_1/opendev.org/zuul/zuul-jobs/roles/remove-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-05-08T10:20:35.475660Z",
                            "start": "2026-05-08T10:20:35.024376Z"
                        },
                        "id": "0242ac17-0010-e5da-6a66-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
}
]
