[
{
    "branch": "main",
    "index": "0",
    "phase": "pre",
    "playbook": "github.com/osism/zuul-config/playbooks/base/pre.yaml",
    "plays": [
        {
            "play": {
                "duration": {
                    "end": "2026-06-19T16:54:32.938029Z",
                    "start": "2026-06-19T16:53:34.696858Z"
                },
                "id": "0242ac1f-6606-1448-5b9c-000000000002",
                "name": "Base pre"
            },
            "tasks": [
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "include_role",
                            "changed": false,
                            "include_args": {
                                "name": "set-zuul-log-path-fact"
                            }
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-00000000000d",
                        "name": "emit-job-header",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_1/github.com/osism/openinfra-zuul-jobs/roles/emit-job-header"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:34.779519Z",
                            "start": "2026-06-19T16:53:34.737125Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-00000000000f",
                        "name": "Setup log path fact"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "set_fact",
                            "ansible_facts": {
                                "zuul_log_path": "bd6/osism/bd6142c67d41408594c85721f4b5574c"
                            },
                            "changed": false
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-0000000000bb",
                        "name": "set-zuul-log-path-fact",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_1/github.com/osism/openinfra-zuul-jobs/roles/set-zuul-log-path-fact"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:34.832866Z",
                            "start": "2026-06-19T16:53:34.801240Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-0000000000bd",
                        "name": "Set log path for a build"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "debug",
                            "changed": false,
                            "msg": "# Job Information\nAnsible Version: 2.16.14\nJob: mypy\nPipeline: check\nExecutor: 521e9411259a\nTriggered by: https://github.com/osism/openstack-image-manager/pull/1207\nEvent ID: 3550db40-6bff-11f1-9ec2-19db3146da3c\n"
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-00000000000d",
                        "name": "emit-job-header",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_1/github.com/osism/openinfra-zuul-jobs/roles/emit-job-header"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:34.890251Z",
                            "start": "2026-06-19T16:53:34.849021Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-000000000010",
                        "name": "Print job information"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "debug",
                            "changed": false,
                            "msg": "All items completed",
                            "results": [
                                {
                                    "ansible_loop_var": "zj_item",
                                    "changed": false,
                                    "failed": false,
                                    "msg": "# Node Information\nInventory Hostname: debian-bookworm\nHostname: debian\nUsername: zuul\nDistro: Debian 12.14\nProvider: regiocloud-a\nRegion: \nLabel: debian-bookworm\nProduct Name: OpenStack Nova\nInterface IP: 2a13:1a81:8000:3124:f816:3eff:fe6d:fdbc\n",
                                    "zj_item": "debian-bookworm"
                                }
                            ]
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-00000000000d",
                        "name": "emit-job-header",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_1/github.com/osism/openinfra-zuul-jobs/roles/emit-job-header"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:35.094944Z",
                            "start": "2026-06-19T16:53:34.895647Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-000000000011",
                        "name": "Print node information"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "file",
                            "changed": true,
                            "diff": {
                                "after": {
                                    "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/work/logs/zuul-info",
                                    "state": "directory"
                                },
                                "before": {
                                    "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/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/bd6142c67d41408594c85721f4b5574c/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/bd6142c67d41408594c85721f4b5574c/work/logs/zuul-info",
                            "size": 4096,
                            "state": "directory",
                            "uid": 0
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-000000000014",
                        "name": "log-inventory",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_1/github.com/osism/openinfra-zuul-jobs/roles/log-inventory"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:36.241926Z",
                            "start": "2026-06-19T16:53:35.108084Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-000000000016",
                        "name": "Ensure Zuul Ansible directory exists"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "copy",
                            "changed": true,
                            "checksum": "258ff36c0c10937203f7951e9d288c29b6c45a0d",
                            "dest": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/work/logs/zuul-info/inventory.yaml",
                            "diff": [],
                            "gid": 0,
                            "group": "root",
                            "invocation": {
                                "module_args": {
                                    "_original_basename": "inventory.yaml",
                                    "attributes": null,
                                    "backup": false,
                                    "checksum": "258ff36c0c10937203f7951e9d288c29b6c45a0d",
                                    "content": null,
                                    "dest": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/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/bd6142c67d41408594c85721f4b5574c/work/.ansible/tmp/ansible-tmp-1781888016.3437774-34-207726272594934/source",
                                    "unsafe_writes": false,
                                    "validate": null
                                }
                            },
                            "md5sum": "d3ff6a4d530d9e9c586961a96660b9a7",
                            "mode": "0644",
                            "owner": "root",
                            "size": 15438,
                            "src": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/work/.ansible/tmp/ansible-tmp-1781888016.3437774-34-207726272594934/source",
                            "state": "file",
                            "uid": 0
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-000000000014",
                        "name": "log-inventory",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_1/github.com/osism/openinfra-zuul-jobs/roles/log-inventory"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:38.184466Z",
                            "start": "2026-06-19T16:53:36.251287Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-000000000017",
                        "name": "Copy ansible inventory to logs dir"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "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/bd6142c67d41408594c85721f4b5574c/work/bd6142c67d41408594c85721f4b5574c_id_rsa"
                                }
                            },
                            "stat": {
                                "exists": false
                            }
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-000000000019",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_1/github.com/osism/openinfra-zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:38.639334Z",
                            "start": "2026-06-19T16:53:38.197016Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-00000000001b",
                        "name": "Check to see if ssh key was already created for this build"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "include_tasks",
                            "changed": false,
                            "include": "create-key-and-replace.yaml",
                            "include_args": {}
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-000000000019",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_1/github.com/osism/openinfra-zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:38.686379Z",
                            "start": "2026-06-19T16:53:38.645121Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-00000000001c",
                        "name": "Create a new key in workspace based on build UUID"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "command",
                            "changed": true,
                            "cmd": [
                                "ssh-keygen",
                                "-t",
                                "rsa",
                                "-N",
                                "",
                                "-C",
                                "zuul-build-sshkey",
                                "-f",
                                "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/work/bd6142c67d41408594c85721f4b5574c_id_rsa",
                                "-b",
                                "3072"
                            ],
                            "delta": "0:00:00.817595",
                            "end": "2026-06-19 16:53:40.245362",
                            "invocation": {
                                "module_args": {
                                    "_raw_params": "ssh-keygen -t rsa -N '' -C 'zuul-build-sshkey' -f /var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/work/bd6142c67d41408594c85721f4b5574c_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": "0242ac1f-6606-1448-5b9c-0000000000de-0-debianbookworm",
                                    "zuul_output_max_bytes": 1073741824
                                }
                            },
                            "msg": "",
                            "rc": 0,
                            "start": "2026-06-19 16:53:39.427767",
                            "stderr": "",
                            "stderr_lines": [],
                            "stdout": "Generating public/private rsa key pair.\nYour identification has been saved in /var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/work/bd6142c67d41408594c85721f4b5574c_id_rsa\nYour public key has been saved in /var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/work/bd6142c67d41408594c85721f4b5574c_id_rsa.pub\nThe key fingerprint is:\nSHA256:4cs2zXwbChosTJd54zLAJ/gadxzPOLFoTloaLqNd+fA zuul-build-sshkey\nThe key's randomart image is:\n+---[RSA 3072]----+\n|                 |\n|                 |\n|        .        |\n|   o   + .       |\n|  . = B S        |\n|   + X @ *       |\n|  o & @ X + o    |\n|oo & * B o o o   |\n|oo* . E   . .    |\n+----[SHA256]-----+",
                            "stdout_lines": [
                                "Generating public/private rsa key pair.",
                                "Your identification has been saved in /var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/work/bd6142c67d41408594c85721f4b5574c_id_rsa",
                                "Your public key has been saved in /var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/work/bd6142c67d41408594c85721f4b5574c_id_rsa.pub",
                                "The key fingerprint is:",
                                "SHA256:4cs2zXwbChosTJd54zLAJ/gadxzPOLFoTloaLqNd+fA zuul-build-sshkey",
                                "The key's randomart image is:",
                                "+---[RSA 3072]----+",
                                "|                 |",
                                "|                 |",
                                "|        .        |",
                                "|   o   + .       |",
                                "|  . = B S        |",
                                "|   + X @ *       |",
                                "|  o & @ X + o    |",
                                "|oo & * B o o o   |",
                                "|oo* . E   . .    |",
                                "+----[SHA256]-----+"
                            ],
                            "zuul_log_id": "0242ac1f-6606-1448-5b9c-0000000000de-0-debianbookworm"
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-000000000019",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_1/github.com/osism/openinfra-zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:40.331865Z",
                            "start": "2026-06-19T16:53:38.735774Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-0000000000de",
                        "name": "Create Temp SSH key"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "include_tasks",
                            "changed": false,
                            "include": "remote-linux.yaml",
                            "include_args": {}
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-000000000019",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_1/github.com/osism/openinfra-zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:40.395322Z",
                            "start": "2026-06-19T16:53:40.361403Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-0000000000df",
                        "name": "Remote setup ssh keys (linux)"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "lineinfile",
                            "changed": false,
                            "false_condition": "zuul_build_sshkey_cleanup",
                            "skip_reason": "Conditional result was False",
                            "skipped": true
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-000000000019",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_1/github.com/osism/openinfra-zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:40.481963Z",
                            "start": "2026-06-19T16:53:40.441378Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-0000000000fe",
                        "name": "Remove previously added zuul-build-sshkey"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "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 AAAAB3NzaC1yc2EAAAADAQABAAABgQCtnTD9QpX8KVUgeb6xiupD+OwC3aLjzyqY+t7XsjmVIihuBVrL/kr1mQN6TUca3CmxEtNtOUfG0M2XXiswV3oZ8zCVR5sP9dCYaEm3VsOKZshK6IRLfa+rKURsfCDAm1M2wbpByLaJ+qW/dc6iGmoqKeUFAcTtcTNUilcF+QDLPn65yD/t140NutYHiNWx/pLoSyIpXZF0h78SA/rvEUg28Xqo8kvWlnVqsGm8NUgZOinPwPLRl7qG8Y+H1ea57c4KMCu9KWuQ/DXJwuyNZbCvN2ofyrgmfB2+KXWeZVkaL1Epfy+hUv0ZoLpKSFHPRh7ghQ2pyvZ5/dqBeaRdQgiE6WFiC3tFPFqzwKx0ye+h+jCDCUG+g8QXj1p42J+89aAd3HL17DMrU0VI0p8XSCgmuUAELJGoyJTlme0Tdw+m+L4h7cFR/E43gJBk+sICfVoMtksg6S35/cwJApiFCMOnNQqZ7yzqNAdACePq17buNTudIbo8jBibacLm9MQyEHM= 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 AAAAB3NzaC1yc2EAAAADAQABAAABgQCtnTD9QpX8KVUgeb6xiupD+OwC3aLjzyqY+t7XsjmVIihuBVrL/kr1mQN6TUca3CmxEtNtOUfG0M2XXiswV3oZ8zCVR5sP9dCYaEm3VsOKZshK6IRLfa+rKURsfCDAm1M2wbpByLaJ+qW/dc6iGmoqKeUFAcTtcTNUilcF+QDLPn65yD/t140NutYHiNWx/pLoSyIpXZF0h78SA/rvEUg28Xqo8kvWlnVqsGm8NUgZOinPwPLRl7qG8Y+H1ea57c4KMCu9KWuQ/DXJwuyNZbCvN2ofyrgmfB2+KXWeZVkaL1Epfy+hUv0ZoLpKSFHPRh7ghQ2pyvZ5/dqBeaRdQgiE6WFiC3tFPFqzwKx0ye+h+jCDCUG+g8QXj1p42J+89aAd3HL17DMrU0VI0p8XSCgmuUAELJGoyJTlme0Tdw+m+L4h7cFR/E43gJBk+sICfVoMtksg6S35/cwJApiFCMOnNQqZ7yzqNAdACePq17buNTudIbo8jBibacLm9MQyEHM= 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": "0242ac1f-6606-1448-5b9c-000000000019",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_1/github.com/osism/openinfra-zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:41.160565Z",
                            "start": "2026-06-19T16:53:40.488817Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-0000000000ff",
                        "name": "Enable access via build key on all nodes"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "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": "0242ac1f-6606-1448-5b9c-000000000019",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_1/github.com/osism/openinfra-zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:41.429574Z",
                            "start": "2026-06-19T16:53:41.166661Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-000000000100",
                        "name": "Make sure user has a .ssh"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "copy",
                            "changed": true,
                            "checksum": "74c93c6938085a2409303f1034864014e9897893",
                            "dest": "/home/zuul/.ssh/id_rsa",
                            "diff": [],
                            "gid": 1000,
                            "group": "zuul",
                            "invocation": {
                                "module_args": {
                                    "_original_basename": "bd6142c67d41408594c85721f4b5574c_id_rsa",
                                    "attributes": null,
                                    "backup": false,
                                    "checksum": "74c93c6938085a2409303f1034864014e9897893",
                                    "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-1781888021.4904552-139-234070750884283/source",
                                    "unsafe_writes": false,
                                    "validate": null
                                }
                            },
                            "md5sum": "ca999ff1a12599516c3411ebb24e2444",
                            "mode": "0600",
                            "owner": "zuul",
                            "size": 2602,
                            "src": "/home/zuul/.ansible/tmp/ansible-tmp-1781888021.4904552-139-234070750884283/source",
                            "state": "file",
                            "uid": 1000
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-000000000019",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_1/github.com/osism/openinfra-zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:42.104432Z",
                            "start": "2026-06-19T16:53:41.434868Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-000000000101",
                        "name": "Install build private key as SSH key on all nodes"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "copy",
                            "changed": true,
                            "checksum": "787c62dd1d0b23f96b7a82737b1e815b62423e34",
                            "dest": "/home/zuul/.ssh/id_rsa.pub",
                            "diff": [],
                            "gid": 1000,
                            "group": "zuul",
                            "invocation": {
                                "module_args": {
                                    "_original_basename": "bd6142c67d41408594c85721f4b5574c_id_rsa.pub",
                                    "attributes": null,
                                    "backup": false,
                                    "checksum": "787c62dd1d0b23f96b7a82737b1e815b62423e34",
                                    "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-1781888022.1523166-149-35745958946512/source",
                                    "unsafe_writes": false,
                                    "validate": null
                                }
                            },
                            "md5sum": "4d1408cac33c6e81b43b5d13d84b8391",
                            "mode": "0644",
                            "owner": "zuul",
                            "size": 571,
                            "src": "/home/zuul/.ansible/tmp/ansible-tmp-1781888022.1523166-149-35745958946512/source",
                            "state": "file",
                            "uid": 1000
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-000000000019",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_1/github.com/osism/openinfra-zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:42.741517Z",
                            "start": "2026-06-19T16:53:42.110648Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-000000000102",
                        "name": "Install build public key as SSH key on all nodes"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "include_tasks",
                            "changed": false,
                            "false_condition": "ansible_os_family == \"Windows\"",
                            "skip_reason": "Conditional result was False",
                            "skipped": true
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-000000000019",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_1/github.com/osism/openinfra-zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:42.770430Z",
                            "start": "2026-06-19T16:53:42.746597Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-0000000000e0",
                        "name": "Remote setup ssh keys (windows)"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "sshagent_remove_keys",
                            "changed": true,
                            "invocation": {
                                "module_args": {
                                    "remove": "^(?!\\(stdin\\)).*"
                                }
                            },
                            "removed": [
                                "/var/ssh/nodepool"
                            ]
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-0000000000e5",
                        "name": "remove-zuul-sshkey",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_1/github.com/osism/openinfra-zuul-jobs/roles/remove-zuul-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:43.680091Z",
                            "start": "2026-06-19T16:53:42.777351Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-0000000000e7",
                        "name": "Remove master key from local agent"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "command",
                            "changed": true,
                            "cmd": [
                                "ssh-add",
                                "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/work/bd6142c67d41408594c85721f4b5574c_id_rsa"
                            ],
                            "delta": "0:00:00.013122",
                            "end": "2026-06-19 16:53:44.533720",
                            "invocation": {
                                "module_args": {
                                    "_raw_params": "ssh-add /var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/work/bd6142c67d41408594c85721f4b5574c_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": "0242ac1f-6606-1448-5b9c-0000000000ed-0-debianbookworm",
                                    "zuul_output_max_bytes": 1073741824
                                }
                            },
                            "msg": "",
                            "rc": 0,
                            "start": "2026-06-19 16:53:44.520598",
                            "stderr": "",
                            "stderr_lines": [],
                            "stdout": "Identity added: /var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/work/bd6142c67d41408594c85721f4b5574c_id_rsa (zuul-build-sshkey)",
                            "stdout_lines": [
                                "Identity added: /var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/work/bd6142c67d41408594c85721f4b5574c_id_rsa (zuul-build-sshkey)"
                            ],
                            "zuul_log_id": "0242ac1f-6606-1448-5b9c-0000000000ed-0-debianbookworm"
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-000000000019",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_1/github.com/osism/openinfra-zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:44.620776Z",
                            "start": "2026-06-19T16:53:43.697098Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-0000000000ed",
                        "name": "Add back temp key"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "ping",
                            "changed": false,
                            "invocation": {
                                "module_args": {
                                    "data": "pong"
                                }
                            },
                            "ping": "pong"
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-000000000019",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_1/github.com/osism/openinfra-zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:45.079463Z",
                            "start": "2026-06-19T16:53:44.630379Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-0000000000ee",
                        "name": "Verify we can still SSH to all nodes"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "command",
                            "changed": false,
                            "false_condition": "ansible_os_family == \"Windows\"",
                            "skip_reason": "Conditional result was False",
                            "skipped": true
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-000000000019",
                        "name": "add-build-sshkey",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_1/github.com/osism/openinfra-zuul-jobs/roles/add-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:45.144523Z",
                            "start": "2026-06-19T16:53:45.085663Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-0000000000ef",
                        "name": "Verify we can still SSH to all nodes (windows)"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "zuul_console",
                            "changed": false,
                            "invocation": {
                                "module_args": {
                                    "path": "/tmp/console-{log_uuid}.log",
                                    "port": 19885,
                                    "state": "present"
                                }
                            }
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-00000000001e",
                        "name": "start-zuul-console",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_1/github.com/osism/openinfra-zuul-jobs/roles/start-zuul-console"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:45.623041Z",
                            "start": "2026-06-19T16:53:45.156685Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-000000000020",
                        "name": "Start zuul_console daemon."
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "set_fact",
                            "ansible_facts": {
                                "zuul_info_dir": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/work/logs/zuul-info"
                            },
                            "changed": false
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-000000000022",
                        "name": "validate-host",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_1/github.com/osism/openinfra-zuul-jobs/roles/validate-host"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:45.667708Z",
                            "start": "2026-06-19T16:53:45.635385Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-000000000024",
                        "name": "Define zuul_info_dir fact"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "file",
                            "changed": false,
                            "diff": {
                                "after": {
                                    "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/work/logs/zuul-info"
                                },
                                "before": {
                                    "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/work/logs/zuul-info"
                                }
                            },
                            "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/bd6142c67d41408594c85721f4b5574c/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/bd6142c67d41408594c85721f4b5574c/work/logs/zuul-info",
                            "size": 4096,
                            "state": "directory",
                            "uid": 0
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-000000000022",
                        "name": "validate-host",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_1/github.com/osism/openinfra-zuul-jobs/roles/validate-host"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:46.170340Z",
                            "start": "2026-06-19T16:53:45.675167Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-000000000025",
                        "name": "Ensure Zuul Ansible directory exists"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "setup",
                            "ansible_facts": {
                                "ansible_all_ipv4_addresses": [
                                    "10.128.0.102"
                                ],
                                "ansible_all_ipv6_addresses": [
                                    "2a13:1a81:8000:3124:f816:3eff:fe6d:fdbc",
                                    "fe80::f816:3eff:fe6d:fdbc"
                                ],
                                "ansible_apparmor": {
                                    "status": "enabled"
                                },
                                "ansible_architecture": "x86_64",
                                "ansible_bios_date": "04/01/2014",
                                "ansible_bios_vendor": "SeaBIOS",
                                "ansible_bios_version": "1.15.0-1",
                                "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": "QEMU",
                                "ansible_chassis_version": "pc-i440fx-6.2",
                                "ansible_cmdline": {
                                    "BOOT_IMAGE": "/boot/vmlinuz-6.1.0-49-amd64",
                                    "console": "ttyS0,115200",
                                    "gfxpayload": "text",
                                    "no_timer_check": true,
                                    "nofb": true,
                                    "nomodeset": true,
                                    "ro": true,
                                    "root": "LABEL=cloudimg-rootfs"
                                },
                                "ansible_date_time": {
                                    "date": "2026-06-19",
                                    "day": "19",
                                    "epoch": "1781888027",
                                    "epoch_int": "1781888027",
                                    "hour": "16",
                                    "iso8601": "2026-06-19T16:53:47Z",
                                    "iso8601_basic": "20260619T165347413086",
                                    "iso8601_basic_short": "20260619T165347",
                                    "iso8601_micro": "2026-06-19T16:53:47.413086Z",
                                    "minute": "53",
                                    "month": "06",
                                    "second": "47",
                                    "time": "16:53:47",
                                    "tz": "UTC",
                                    "tz_dst": "UTC",
                                    "tz_offset": "+0000",
                                    "weekday": "Friday",
                                    "weekday_number": "5",
                                    "weeknumber": "24",
                                    "year": "2026"
                                },
                                "ansible_default_ipv4": {
                                    "address": "10.128.0.102",
                                    "alias": "ens3",
                                    "broadcast": "10.128.0.111",
                                    "gateway": "10.128.0.97",
                                    "interface": "ens3",
                                    "macaddress": "fa:16:3e:6d:fd:bc",
                                    "mtu": 1500,
                                    "netmask": "255.255.255.240",
                                    "network": "10.128.0.96",
                                    "prefix": "28",
                                    "type": "ether"
                                },
                                "ansible_default_ipv6": {
                                    "address": "2a13:1a81:8000:3124:f816:3eff:fe6d:fdbc",
                                    "gateway": "fe80::f816:3eff:fe92:ad10",
                                    "interface": "ens3",
                                    "macaddress": "fa:16:3e:6d:fd:bc",
                                    "mtu": 1500,
                                    "prefix": "64",
                                    "scope": "global",
                                    "type": "ether"
                                },
                                "ansible_device_links": {
                                    "ids": {},
                                    "labels": {
                                        "vda1": [
                                            "cloudimg-rootfs"
                                        ]
                                    },
                                    "masters": {},
                                    "uuids": {
                                        "vda1": [
                                            "b2f6d9ee-1810-49c3-be6c-b2d2c9267bd2"
                                        ]
                                    }
                                },
                                "ansible_devices": {
                                    "loop0": {
                                        "holders": [],
                                        "host": "",
                                        "links": {
                                            "ids": [],
                                            "labels": [],
                                            "masters": [],
                                            "uuids": []
                                        },
                                        "model": null,
                                        "partitions": {},
                                        "removable": "0",
                                        "rotational": "1",
                                        "sas_address": null,
                                        "sas_device_handle": null,
                                        "scheduler_mode": "none",
                                        "sectors": "0",
                                        "sectorsize": "512",
                                        "size": "0.00 Bytes",
                                        "support_discard": "0",
                                        "vendor": null,
                                        "virtual": 1
                                    },
                                    "loop1": {
                                        "holders": [],
                                        "host": "",
                                        "links": {
                                            "ids": [],
                                            "labels": [],
                                            "masters": [],
                                            "uuids": []
                                        },
                                        "model": null,
                                        "partitions": {},
                                        "removable": "0",
                                        "rotational": "1",
                                        "sas_address": null,
                                        "sas_device_handle": null,
                                        "scheduler_mode": "none",
                                        "sectors": "0",
                                        "sectorsize": "512",
                                        "size": "0.00 Bytes",
                                        "support_discard": "0",
                                        "vendor": null,
                                        "virtual": 1
                                    },
                                    "loop2": {
                                        "holders": [],
                                        "host": "",
                                        "links": {
                                            "ids": [],
                                            "labels": [],
                                            "masters": [],
                                            "uuids": []
                                        },
                                        "model": null,
                                        "partitions": {},
                                        "removable": "0",
                                        "rotational": "1",
                                        "sas_address": null,
                                        "sas_device_handle": null,
                                        "scheduler_mode": "none",
                                        "sectors": "0",
                                        "sectorsize": "512",
                                        "size": "0.00 Bytes",
                                        "support_discard": "0",
                                        "vendor": null,
                                        "virtual": 1
                                    },
                                    "loop3": {
                                        "holders": [],
                                        "host": "",
                                        "links": {
                                            "ids": [],
                                            "labels": [],
                                            "masters": [],
                                            "uuids": []
                                        },
                                        "model": null,
                                        "partitions": {},
                                        "removable": "0",
                                        "rotational": "1",
                                        "sas_address": null,
                                        "sas_device_handle": null,
                                        "scheduler_mode": "none",
                                        "sectors": "0",
                                        "sectorsize": "512",
                                        "size": "0.00 Bytes",
                                        "support_discard": "0",
                                        "vendor": null,
                                        "virtual": 1
                                    },
                                    "loop4": {
                                        "holders": [],
                                        "host": "",
                                        "links": {
                                            "ids": [],
                                            "labels": [],
                                            "masters": [],
                                            "uuids": []
                                        },
                                        "model": null,
                                        "partitions": {},
                                        "removable": "0",
                                        "rotational": "1",
                                        "sas_address": null,
                                        "sas_device_handle": null,
                                        "scheduler_mode": "none",
                                        "sectors": "0",
                                        "sectorsize": "512",
                                        "size": "0.00 Bytes",
                                        "support_discard": "0",
                                        "vendor": null,
                                        "virtual": 1
                                    },
                                    "loop5": {
                                        "holders": [],
                                        "host": "",
                                        "links": {
                                            "ids": [],
                                            "labels": [],
                                            "masters": [],
                                            "uuids": []
                                        },
                                        "model": null,
                                        "partitions": {},
                                        "removable": "0",
                                        "rotational": "1",
                                        "sas_address": null,
                                        "sas_device_handle": null,
                                        "scheduler_mode": "none",
                                        "sectors": "0",
                                        "sectorsize": "512",
                                        "size": "0.00 Bytes",
                                        "support_discard": "0",
                                        "vendor": null,
                                        "virtual": 1
                                    },
                                    "loop6": {
                                        "holders": [],
                                        "host": "",
                                        "links": {
                                            "ids": [],
                                            "labels": [],
                                            "masters": [],
                                            "uuids": []
                                        },
                                        "model": null,
                                        "partitions": {},
                                        "removable": "0",
                                        "rotational": "1",
                                        "sas_address": null,
                                        "sas_device_handle": null,
                                        "scheduler_mode": "none",
                                        "sectors": "0",
                                        "sectorsize": "512",
                                        "size": "0.00 Bytes",
                                        "support_discard": "0",
                                        "vendor": null,
                                        "virtual": 1
                                    },
                                    "loop7": {
                                        "holders": [],
                                        "host": "",
                                        "links": {
                                            "ids": [],
                                            "labels": [],
                                            "masters": [],
                                            "uuids": []
                                        },
                                        "model": null,
                                        "partitions": {},
                                        "removable": "0",
                                        "rotational": "1",
                                        "sas_address": null,
                                        "sas_device_handle": null,
                                        "scheduler_mode": "none",
                                        "sectors": "0",
                                        "sectorsize": "512",
                                        "size": "0.00 Bytes",
                                        "support_discard": "0",
                                        "vendor": null,
                                        "virtual": 1
                                    },
                                    "vda": {
                                        "holders": [],
                                        "host": "",
                                        "links": {
                                            "ids": [],
                                            "labels": [],
                                            "masters": [],
                                            "uuids": []
                                        },
                                        "model": null,
                                        "partitions": {
                                            "vda1": {
                                                "holders": [],
                                                "links": {
                                                    "ids": [],
                                                    "labels": [
                                                        "cloudimg-rootfs"
                                                    ],
                                                    "masters": [],
                                                    "uuids": [
                                                        "b2f6d9ee-1810-49c3-be6c-b2d2c9267bd2"
                                                    ]
                                                },
                                                "sectors": "20969439",
                                                "sectorsize": 512,
                                                "size": "10.00 GB",
                                                "start": "2048",
                                                "uuid": "b2f6d9ee-1810-49c3-be6c-b2d2c9267bd2"
                                            }
                                        },
                                        "removable": "0",
                                        "rotational": "1",
                                        "sas_address": null,
                                        "sas_device_handle": null,
                                        "scheduler_mode": "none",
                                        "sectors": "20971520",
                                        "sectorsize": "512",
                                        "size": "10.00 GB",
                                        "support_discard": "512",
                                        "vendor": "0x1af4",
                                        "virtual": 1
                                    }
                                },
                                "ansible_distribution": "Debian",
                                "ansible_distribution_file_parsed": true,
                                "ansible_distribution_file_path": "/etc/os-release",
                                "ansible_distribution_file_variety": "Debian",
                                "ansible_distribution_major_version": "12",
                                "ansible_distribution_minor_version": "14",
                                "ansible_distribution_release": "bookworm",
                                "ansible_distribution_version": "12.14",
                                "ansible_dns": {
                                    "domain": "a.customers.regiocloud.tech.",
                                    "nameservers": [
                                        "81.163.194.9",
                                        "81.163.194.10"
                                    ],
                                    "search": [
                                        "a.customers.regiocloud.tech."
                                    ]
                                },
                                "ansible_domain": "",
                                "ansible_effective_group_id": 1000,
                                "ansible_effective_user_id": 1000,
                                "ansible_ens3": {
                                    "active": true,
                                    "device": "ens3",
                                    "ipv4": {
                                        "address": "10.128.0.102",
                                        "broadcast": "10.128.0.111",
                                        "netmask": "255.255.255.240",
                                        "network": "10.128.0.96",
                                        "prefix": "28"
                                    },
                                    "ipv6": [
                                        {
                                            "address": "2a13:1a81:8000:3124:f816:3eff:fe6d:fdbc",
                                            "prefix": "64",
                                            "scope": "global"
                                        },
                                        {
                                            "address": "fe80::f816:3eff:fe6d:fdbc",
                                            "prefix": "64",
                                            "scope": "link"
                                        }
                                    ],
                                    "macaddress": "fa:16:3e:6d:fd:bc",
                                    "module": "virtio_net",
                                    "mtu": 1500,
                                    "pciid": "virtio1",
                                    "promisc": false,
                                    "speed": -1,
                                    "type": "ether"
                                },
                                "ansible_env": {
                                    "DBUS_SESSION_BUS_ADDRESS": "unix:path=/run/user/1000/bus",
                                    "HOME": "/home/zuul",
                                    "LANG": "C.UTF-8",
                                    "LC_ALL": "C.UTF-8",
                                    "LOGNAME": "zuul",
                                    "MOTD_SHOWN": "pam",
                                    "PATH": "/usr/local/bin:/usr/bin:/bin:/usr/games",
                                    "PWD": "/home/zuul",
                                    "SHELL": "/bin/bash",
                                    "SHLVL": "0",
                                    "SSH_CLIENT": "2a13:1a81:8000:2::38d 33362 22",
                                    "SSH_CONNECTION": "2a13:1a81:8000:2::38d 33362 2a13:1a81:8000:3124:f816:3eff:fe6d:fdbc 22",
                                    "USER": "zuul",
                                    "XDG_RUNTIME_DIR": "/run/user/1000",
                                    "XDG_SESSION_CLASS": "user",
                                    "XDG_SESSION_ID": "1",
                                    "XDG_SESSION_TYPE": "tty",
                                    "_": "/bin/sh"
                                },
                                "ansible_fibre_channel_wwn": [],
                                "ansible_fips": false,
                                "ansible_form_factor": "Other",
                                "ansible_fqdn": "debian",
                                "ansible_hostname": "debian",
                                "ansible_hostnqn": "",
                                "ansible_interfaces": [
                                    "lo",
                                    "ens3"
                                ],
                                "ansible_is_chroot": false,
                                "ansible_iscsi_iqn": "",
                                "ansible_kernel": "6.1.0-49-amd64",
                                "ansible_kernel_version": "#1 SMP PREEMPT_DYNAMIC Debian 6.1.174-1 (2026-05-26)",
                                "ansible_lo": {
                                    "active": true,
                                    "device": "lo",
                                    "ipv4": {
                                        "address": "127.0.0.1",
                                        "broadcast": "",
                                        "netmask": "255.0.0.0",
                                        "network": "127.0.0.0",
                                        "prefix": "8"
                                    },
                                    "ipv6": [
                                        {
                                            "address": "::1",
                                            "prefix": "128",
                                            "scope": "host"
                                        }
                                    ],
                                    "mtu": 65536,
                                    "promisc": false,
                                    "type": "loopback"
                                },
                                "ansible_loadavg": {
                                    "15m": 0.02392578125,
                                    "1m": 0.2578125,
                                    "5m": 0.0751953125
                                },
                                "ansible_local": {},
                                "ansible_locally_reachable_ips": {
                                    "ipv4": [
                                        "10.128.0.102",
                                        "127.0.0.0/8",
                                        "127.0.0.1"
                                    ],
                                    "ipv6": [
                                        "::1",
                                        "2a13:1a81:8000:3124:f816:3eff:fe6d:fdbc",
                                        "fe80::f816:3eff:fe6d:fdbc"
                                    ]
                                },
                                "ansible_lsb": {
                                    "codename": "bookworm",
                                    "description": "Debian GNU/Linux 12 (bookworm)",
                                    "id": "Debian",
                                    "major_release": "12",
                                    "release": "12"
                                },
                                "ansible_lvm": "N/A",
                                "ansible_machine": "x86_64",
                                "ansible_machine_id": "907d6bfbcfcf467b9a3d8c5a21f463c7",
                                "ansible_memfree_mb": 3660,
                                "ansible_memory_mb": {
                                    "nocache": {
                                        "free": 3746,
                                        "used": 167
                                    },
                                    "real": {
                                        "free": 3660,
                                        "total": 3913,
                                        "used": 253
                                    },
                                    "swap": {
                                        "cached": 0,
                                        "free": 0,
                                        "total": 0,
                                        "used": 0
                                    }
                                },
                                "ansible_memtotal_mb": 3913,
                                "ansible_mounts": [
                                    {
                                        "block_available": 1944088,
                                        "block_size": 4096,
                                        "block_total": 2443542,
                                        "block_used": 499454,
                                        "device": "/dev/vda1",
                                        "fstype": "ext4",
                                        "inode_available": 2494832,
                                        "inode_total": 2531088,
                                        "inode_used": 36256,
                                        "mount": "/",
                                        "options": "rw,relatime",
                                        "size_available": 7962984448,
                                        "size_total": 10008748032,
                                        "uuid": "b2f6d9ee-1810-49c3-be6c-b2d2c9267bd2"
                                    }
                                ],
                                "ansible_nodename": "debian",
                                "ansible_os_family": "Debian",
                                "ansible_pkg_mgr": "apt",
                                "ansible_proc_cmdline": {
                                    "BOOT_IMAGE": "/boot/vmlinuz-6.1.0-49-amd64",
                                    "console": [
                                        "tty0",
                                        "ttyS0,115200"
                                    ],
                                    "gfxpayload": "text",
                                    "no_timer_check": true,
                                    "nofb": true,
                                    "nomodeset": true,
                                    "ro": true,
                                    "root": "LABEL=cloudimg-rootfs"
                                },
                                "ansible_processor": [
                                    "0",
                                    "GenuineIntel",
                                    "Intel Xeon Processor (Icelake)",
                                    "1",
                                    "GenuineIntel",
                                    "Intel Xeon Processor (Icelake)"
                                ],
                                "ansible_processor_cores": 1,
                                "ansible_processor_count": 2,
                                "ansible_processor_nproc": 2,
                                "ansible_processor_threads_per_core": 1,
                                "ansible_processor_vcpus": 2,
                                "ansible_product_name": "OpenStack Nova",
                                "ansible_product_serial": "NA",
                                "ansible_product_uuid": "NA",
                                "ansible_product_version": "29.2.1",
                                "ansible_python": {
                                    "executable": "/usr/bin/python3",
                                    "has_sslcontext": true,
                                    "type": "cpython",
                                    "version": {
                                        "major": 3,
                                        "micro": 2,
                                        "minor": 11,
                                        "releaselevel": "final",
                                        "serial": 0
                                    },
                                    "version_info": [
                                        3,
                                        11,
                                        2,
                                        "final",
                                        0
                                    ]
                                },
                                "ansible_python_version": "3.11.2",
                                "ansible_real_group_id": 1000,
                                "ansible_real_user_id": 1000,
                                "ansible_selinux": {
                                    "status": "disabled"
                                },
                                "ansible_selinux_python_present": true,
                                "ansible_service_mgr": "systemd",
                                "ansible_ssh_host_key_dsa_public": "AAAAB3NzaC1kc3MAAACBALE5ZwjSun80XgBKn+kUyA5Xu6LDCrpNECzgazjm7izT+7QHYAkfn+FoSAJjwgue2J5m3H8SU1UOfx1ECiEJf0iiqwdB1KmEluoODAgP4ChfZw8JOeumA+p5YOp51zfPSTrMlC9mBZNUv8Y8KpqCpkX+5msQ3cFRUY/0biGr+HaNAAAAFQDoTUA3rCoAa46zPm/FfdCA7Ig0EQAAAIBaNiN3oLug5DITmGDAD7runHFz//W+H8duHKntU7MwGw5ozq93drCniLmLuYX6FNzi1R0H10c7SGa6c5PWePrfr0koRp0lpscEaDhZv2ed7SyXb6go43LdkeRApFRUeKsGl1JECQq7Ykwd/tlBM4sWWxmNZjb3HJDSguECbdbYMgAAAIEAoxdHoNbW8CdL7TYWiqgC32IMuwzHRkCI4aGigDy+GIwXB2Z3/GHpVmHK4uc8uyFntIO52VK5Qm1csg5lj3Jyz7W+0JxdS2cvs4a0wyLIrNiifbjdo982JtTw1rsT7nPcgv8HFSezMlMjnSy2O2l+clQuhQG/26ipCnKrGWKwRFU=",
                                "ansible_ssh_host_key_dsa_public_keytype": "ssh-dss",
                                "ansible_ssh_host_key_ecdsa_public": "AAAAE2VjZHNhLXNoYTItbmlzdHAyNTYAAAAIbmlzdHAyNTYAAABBBEtSw0qtrFloIxl8OrPfvWDKXFKTwf0QHq+/gf6fuOcVIgaIl8CEgpI66HICVyJy4GiNhI9/x0KWjvAkc4+NooA=",
                                "ansible_ssh_host_key_ecdsa_public_keytype": "ecdsa-sha2-nistp256",
                                "ansible_ssh_host_key_ed25519_public": "AAAAC3NzaC1lZDI1NTE5AAAAIGucKojmH1la/RMGtmg7XCkP4W60HuTJ0aCHOJojVYej",
                                "ansible_ssh_host_key_ed25519_public_keytype": "ssh-ed25519",
                                "ansible_ssh_host_key_rsa_public": "AAAAB3NzaC1yc2EAAAADAQABAAABgQCoJcttKr54GA/l8icvZn7fiskOC35QKwR9qW6AfcfvouDUwitP+GcXUL8nGkChGN6MgZY/PiDb2CACy5k6AMPZL22REetVGwDKEw6FeFa2YQPHsLFih4zo6HAi3g5CG2+JGPR1F9p6xauxmj7CDFaF7ETcXdPAa8JPWYAtwAssrONlXjOoZLWDJhH6xnDMnW9YIZ6Zv7M2k/N1CGOIteTo0PIEjgZJrujaHzip63PjmMr3K3/XbMJRRdEeq7+IzDp7Jvxi1ffAa28LeP77h4kKOM9kCf+J2E8qv9LHJakQHYLhSDCJ4QPNYPgdRXR6bkmPRLNbpqjKZUw4OnPNZvVz4nvxWnBY8Ujzc/a+tiNdA5EkQ0+MxMuZmgZnod0nietLTxNSRphmxj6bUbLAjmeTE3rHu7EZI3wIZYEe/SR/hsDencfkVJUcy2ZMc2BD9dWcOvneuIuqzVvOx7wiiPVoYRg2yir16mTTyIPq2g/sY+dDdEYIjiYCoOQ2FS+DJEk=",
                                "ansible_ssh_host_key_rsa_public_keytype": "ssh-rsa",
                                "ansible_swapfree_mb": 0,
                                "ansible_swaptotal_mb": 0,
                                "ansible_system": "Linux",
                                "ansible_system_capabilities": [
                                    ""
                                ],
                                "ansible_system_capabilities_enforced": "True",
                                "ansible_system_vendor": "OpenStack Foundation",
                                "ansible_uptime_seconds": 42,
                                "ansible_user_dir": "/home/zuul",
                                "ansible_user_gecos": "",
                                "ansible_user_gid": 1000,
                                "ansible_user_id": "zuul",
                                "ansible_user_shell": "/bin/bash",
                                "ansible_user_uid": 1000,
                                "ansible_userspace_architecture": "x86_64",
                                "ansible_userspace_bits": "64",
                                "ansible_virtualization_role": "guest",
                                "ansible_virtualization_tech_guest": [
                                    "openstack"
                                ],
                                "ansible_virtualization_tech_host": [
                                    "kvm"
                                ],
                                "ansible_virtualization_type": "openstack",
                                "gather_subset": [
                                    "all"
                                ],
                                "module_setup": true
                            },
                            "changed": false,
                            "invocation": {
                                "module_args": {
                                    "fact_path": "/etc/ansible/facts.d",
                                    "filter": [],
                                    "gather_subset": [
                                        "all"
                                    ],
                                    "gather_timeout": 10
                                }
                            }
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-000000000022",
                        "name": "validate-host",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_1/github.com/osism/openinfra-zuul-jobs/roles/validate-host"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:47.493831Z",
                            "start": "2026-06-19T16:53:46.176886Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-000000000026",
                        "name": "Collect information about the host"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "set_fact",
                            "ansible_facts": {
                                "validate_host_hostname_sanitized": "debian-bookworm"
                            },
                            "changed": false
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-000000000022",
                        "name": "validate-host",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_1/github.com/osism/openinfra-zuul-jobs/roles/validate-host"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:47.894754Z",
                            "start": "2026-06-19T16:53:47.501871Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-000000000027",
                        "name": "Sanitize hostname"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "template",
                            "changed": true,
                            "checksum": "ebd719f4834a856782bd80d6d11d9a11338dd7d0",
                            "dest": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/work/logs/zuul-info/host-info.debian-bookworm.yaml",
                            "diff": [],
                            "gid": 0,
                            "group": "root",
                            "invocation": {
                                "module_args": {
                                    "_original_basename": "host-info.j2",
                                    "attributes": null,
                                    "backup": false,
                                    "checksum": "ebd719f4834a856782bd80d6d11d9a11338dd7d0",
                                    "content": null,
                                    "dest": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/work/logs/zuul-info/host-info.debian-bookworm.yaml",
                                    "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/bd6142c67d41408594c85721f4b5574c/work/.ansible/tmp/ansible-tmp-1781888027.9809225-246-149667384781827/source",
                                    "unsafe_writes": false,
                                    "validate": null
                                }
                            },
                            "md5sum": "ee6aadbe4c448117aff3768276bc6346",
                            "mode": "0644",
                            "owner": "root",
                            "size": 13292,
                            "src": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/work/.ansible/tmp/ansible-tmp-1781888027.9809225-246-149667384781827/source",
                            "state": "file",
                            "uid": 0
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-000000000022",
                        "name": "validate-host",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_1/github.com/osism/openinfra-zuul-jobs/roles/validate-host"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:48.695737Z",
                            "start": "2026-06-19T16:53:47.907559Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-000000000028",
                        "name": "Write out all ansible variables/facts known for each host"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "_zuul_nolog_return": true,
                            "action": "zuul_debug_info",
                            "changed": false,
                            "df_i": "Filesystem      Inodes IUsed   IFree IUse% Mounted on\nudev            495369   343  495026    1% /dev\ntmpfs           500890   458  500432    1% /run\n/dev/vda1      2531088 36256 2494832    2% /\ntmpfs           500890     1  500889    1% /dev/shm\ntmpfs           500890     3  500887    1% /run/lock\ntmpfs           100178    20  100158    1% /run/user/1000\n",
                            "df_m": "Filesystem     1M-blocks  Used Available Use% Mounted on\nudev                1936     0      1936   0% /dev\ntmpfs                392     1       391   1% /run\n/dev/vda1           9546  1505      7595  17% /\ntmpfs               1957     0      1957   0% /dev/shm\ntmpfs                  5     0         5   0% /run/lock\ntmpfs                392     0       392   0% /run/user/1000\n",
                            "image_manifest_files": [],
                            "invocation": {
                                "module_args": {
                                    "image_manifest": null,
                                    "image_manifest_files": [
                                        "/etc/dib-builddate.txt",
                                        "/etc/image-hostname.txt"
                                    ],
                                    "ipv4_route_required": false,
                                    "ipv6_route_required": false,
                                    "traceroute_host": null
                                }
                            },
                            "network_interfaces": "1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000\n    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00\n    inet 127.0.0.1/8 scope host lo\n       valid_lft forever preferred_lft forever\n    inet6 ::1/128 scope host noprefixroute \n       valid_lft forever preferred_lft forever\n2: ens3: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc fq_codel state UP group default qlen 1000\n    link/ether fa:16:3e:6d:fd:bc brd ff:ff:ff:ff:ff:ff\n    altname enp0s3\n    inet 10.128.0.102/28 brd 10.128.0.111 scope global dynamic ens3\n       valid_lft 43161sec preferred_lft 43161sec\n    inet6 2a13:1a81:8000:3124:f816:3eff:fe6d:fdbc/64 scope global dynamic mngtmpaddr \n       valid_lft forever preferred_lft forever\n    inet6 fe80::f816:3eff:fe6d:fdbc/64 scope link \n       valid_lft forever preferred_lft forever\n",
                            "network_neighbors": "10.128.0.97 dev ens3 lladdr fa:16:3e:90:1b:03 REACHABLE \nfe80::f816:3eff:fe92:ad10 dev ens3 lladdr fa:16:3e:92:ad:10 router REACHABLE \n",
                            "network_routing_v4": "default via 10.128.0.97 dev ens3 \n10.128.0.96/28 dev ens3 proto kernel scope link src 10.128.0.102 \n169.254.169.254 via 10.128.0.98 dev ens3 \n",
                            "network_routing_v6": "2a13:1a81:8000:3124::/64 dev ens3 proto kernel metric 256 pref medium\nfe80::/64 dev ens3 proto kernel metric 256 pref medium\ndefault via fe80::f816:3eff:fe92:ad10 dev ens3 proto ra metric 1024 expires 65497sec hoplimit 255 pref medium\n",
                            "proc_cpuinfo": "processor\t: 0\nvendor_id\t: GenuineIntel\ncpu family\t: 6\nmodel\t\t: 134\nmodel name\t: Intel Xeon Processor (Icelake)\nstepping\t: 0\nmicrocode\t: 0x1\ncpu MHz\t\t: 2299.998\ncache size\t: 16384 KB\nphysical id\t: 0\nsiblings\t: 1\ncore id\t\t: 0\ncpu cores\t: 1\napicid\t\t: 0\ninitial apicid\t: 0\nfpu\t\t: yes\nfpu_exception\t: yes\ncpuid level\t: 13\nwp\t\t: yes\nflags\t\t: fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush dts mmx fxsr sse sse2 ss syscall nx pdpe1gb rdtscp lm constant_tsc pebs bts rep_good nopl xtopology cpuid tsc_known_freq pni pclmulqdq dtes64 vmx ssse3 fma cx16 pcid sse4_1 sse4_2 x2apic movbe popcnt tsc_deadline_timer aes xsave avx f16c rdrand hypervisor lahf_lm abm 3dnowprefetch cpuid_fault invpcid_single ssbd ibrs ibpb stibp ibrs_enhanced tpr_shadow vnmi flexpriority ept vpid ept_ad fsgsbase tsc_adjust bmi1 avx2 smep bmi2 erms invpcid avx512f avx512dq rdseed adx smap avx512ifma clflushopt clwb avx512cd sha_ni avx512bw avx512vl xsaveopt xsavec xgetbv1 xsaves wbnoinvd arat avx512vbmi umip pku ospke avx512_vbmi2 gfni vaes vpclmulqdq avx512_vnni avx512_bitalg avx512_vpopcntdq la57 rdpid fsrm md_clear arch_capabilities\nvmx flags\t: vnmi preemption_timer posted_intr invvpid ept_x_only ept_ad ept_1gb flexpriority apicv tsc_offset vtpr mtf vapic ept vpid unrestricted_guest vapic_reg vid shadow_vmcs\nbugs\t\t: spectre_v1 spectre_v2 spec_store_bypass swapgs taa mmio_stale_data rfds bhi ibpb_no_ret its\nbogomips\t: 4599.99\nclflush size\t: 64\ncache_alignment\t: 64\naddress sizes\t: 40 bits physical, 57 bits virtual\npower management:\n\nprocessor\t: 1\nvendor_id\t: GenuineIntel\ncpu family\t: 6\nmodel\t\t: 134\nmodel name\t: Intel Xeon Processor (Icelake)\nstepping\t: 0\nmicrocode\t: 0x1\ncpu MHz\t\t: 2299.998\ncache size\t: 16384 KB\nphysical id\t: 1\nsiblings\t: 1\ncore id\t\t: 0\ncpu cores\t: 1\napicid\t\t: 1\ninitial apicid\t: 1\nfpu\t\t: yes\nfpu_exception\t: yes\ncpuid level\t: 13\nwp\t\t: yes\nflags\t\t: fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush dts mmx fxsr sse sse2 ss syscall nx pdpe1gb rdtscp lm constant_tsc pebs bts rep_good nopl xtopology cpuid tsc_known_freq pni pclmulqdq dtes64 vmx ssse3 fma cx16 pcid sse4_1 sse4_2 x2apic movbe popcnt tsc_deadline_timer aes xsave avx f16c rdrand hypervisor lahf_lm abm 3dnowprefetch cpuid_fault invpcid_single ssbd ibrs ibpb stibp ibrs_enhanced tpr_shadow vnmi flexpriority ept vpid ept_ad fsgsbase tsc_adjust bmi1 avx2 smep bmi2 erms invpcid avx512f avx512dq rdseed adx smap avx512ifma clflushopt clwb avx512cd sha_ni avx512bw avx512vl xsaveopt xsavec xgetbv1 xsaves wbnoinvd arat avx512vbmi umip pku ospke avx512_vbmi2 gfni vaes vpclmulqdq avx512_vnni avx512_bitalg avx512_vpopcntdq la57 rdpid fsrm md_clear arch_capabilities\nvmx flags\t: vnmi preemption_timer posted_intr invvpid ept_x_only ept_ad ept_1gb flexpriority apicv tsc_offset vtpr mtf vapic ept vpid unrestricted_guest vapic_reg vid shadow_vmcs\nbugs\t\t: spectre_v1 spectre_v2 spec_store_bypass swapgs taa mmio_stale_data rfds bhi ibpb_no_ret its\nbogomips\t: 4599.99\nclflush size\t: 64\ncache_alignment\t: 64\naddress sizes\t: 40 bits physical, 57 bits virtual\npower management:\n\n",
                            "traceroute": null,
                            "uname": "Linux debian 6.1.0-49-amd64 #1 SMP PREEMPT_DYNAMIC Debian 6.1.174-1 (2026-05-26) x86_64 GNU/Linux\n"
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-000000000022",
                        "name": "validate-host",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_1/github.com/osism/openinfra-zuul-jobs/roles/validate-host"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:49.276684Z",
                            "start": "2026-06-19T16:53:48.728255Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-00000000002a",
                        "name": "Collect information about zuul worker"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "template",
                            "changed": true,
                            "checksum": "812df3429e206cc0e6ae0f5395b00f132c1b06d1",
                            "dest": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/work/logs/zuul-info/zuul-info.debian-bookworm.txt",
                            "diff": [],
                            "gid": 0,
                            "group": "root",
                            "invocation": {
                                "module_args": {
                                    "_original_basename": "zuul-info.j2",
                                    "attributes": null,
                                    "backup": false,
                                    "checksum": "812df3429e206cc0e6ae0f5395b00f132c1b06d1",
                                    "content": null,
                                    "dest": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/work/logs/zuul-info/zuul-info.debian-bookworm.txt",
                                    "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/bd6142c67d41408594c85721f4b5574c/work/.ansible/tmp/ansible-tmp-1781888029.3675914-285-265013438239958/source",
                                    "unsafe_writes": false,
                                    "validate": null
                                }
                            },
                            "md5sum": "03b991cddae17791984881841a8c396c",
                            "mode": "0644",
                            "owner": "root",
                            "size": 2524,
                            "src": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/work/.ansible/tmp/ansible-tmp-1781888029.3675914-285-265013438239958/source",
                            "state": "file",
                            "uid": 0
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-000000000022",
                        "name": "validate-host",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_1/github.com/osism/openinfra-zuul-jobs/roles/validate-host"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:50.191727Z",
                            "start": "2026-06-19T16:53:49.284760Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-00000000002b",
                        "name": "Write out all zuul information for each host"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "zuul_console",
                            "changed": false,
                            "invocation": {
                                "module_args": {
                                    "path": "/tmp/console-{log_uuid}.log",
                                    "port": 19885,
                                    "state": "present"
                                }
                            }
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-00000000002d",
                        "name": "prepare-workspace-log",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_0/github.com/osism/zuul-config/roles/prepare-workspace-log"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:50.509219Z",
                            "start": "2026-06-19T16:53:50.201491Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-00000000002f",
                        "name": "Start zuul_console daemon."
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "synchronize",
                            "changed": true,
                            "cmd": "/usr/bin/rsync --compress --delete-after --archive --no-owner --no-group --rsh='/usr/bin/ssh -S none -o Port=22 -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null' --out-format='<<CHANGED>>%i %n%L' /var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/work/src '[zuul@2a13:1a81:8000:3124:f816:3eff:fe6d:fdbc]:.'",
                            "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": false,
                                    "delete": true,
                                    "dest": "[zuul@2a13:1a81:8000:3124:f816:3eff:fe6d:fdbc]:.",
                                    "dest_port": 22,
                                    "dirs": false,
                                    "existing_only": false,
                                    "group": false,
                                    "link_dest": null,
                                    "links": null,
                                    "mode": "push",
                                    "owner": false,
                                    "partial": false,
                                    "perms": null,
                                    "private_key": null,
                                    "recursive": true,
                                    "rsync_opts": [],
                                    "rsync_path": null,
                                    "rsync_timeout": 0,
                                    "set_remote_user": true,
                                    "src": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/work/src",
                                    "ssh_connection_multiplexing": false,
                                    "times": null,
                                    "use_ssh_args": false,
                                    "verify_host": false
                                }
                            },
                            "msg": "cd+++++++++ src/\ncd+++++++++ src/github.com/\ncd+++++++++ src/github.com/osism/\ncd+++++++++ src/github.com/osism/openstack-image-manager/\n<f+++++++++ src/github.com/osism/openstack-image-manager/.clouds.yml\n<f+++++++++ src/github.com/osism/openstack-image-manager/.flake8\n<f+++++++++ src/github.com/osism/openstack-image-manager/.gitignore\n<f+++++++++ src/github.com/osism/openstack-image-manager/.yamllint.yml\n<f+++++++++ src/github.com/osism/openstack-image-manager/.zuul.yaml\n<f+++++++++ src/github.com/osism/openstack-image-manager/LICENSE\n<f+++++++++ src/github.com/osism/openstack-image-manager/MANIFEST.in\n<f+++++++++ src/github.com/osism/openstack-image-manager/Pipfile\n<f+++++++++ src/github.com/osism/openstack-image-manager/Pipfile.lock\n<f+++++++++ src/github.com/osism/openstack-image-manager/README.md\n<f+++++++++ src/github.com/osism/openstack-image-manager/_config.yml\n<f+++++++++ src/github.com/osism/openstack-image-manager/clouds.yml.sample\n<f+++++++++ src/github.com/osism/openstack-image-manager/pyproject.toml\n<f+++++++++ src/github.com/osism/openstack-image-manager/requirements.txt\n<f+++++++++ src/github.com/osism/openstack-image-manager/secure.yml.sample\n<f+++++++++ src/github.com/osism/openstack-image-manager/tox.ini\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/COMMIT_EDITMSG\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/FETCH_HEAD\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/HEAD\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/ORIG_HEAD\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/config\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/config.worktree\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/description\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/index\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/packed-refs\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/branches/\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/hooks/\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/hooks/applypatch-msg.sample\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/hooks/commit-msg.sample\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/hooks/fsmonitor-watchman.sample\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/hooks/post-update.sample\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/hooks/pre-applypatch.sample\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/hooks/pre-commit.sample\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/hooks/pre-merge-commit.sample\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/hooks/pre-push.sample\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/hooks/pre-rebase.sample\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/hooks/pre-receive.sample\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/hooks/prepare-commit-msg.sample\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/hooks/push-to-checkout.sample\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/hooks/update.sample\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/info/\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/info/exclude\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/logs/\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/logs/HEAD\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/00/\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/00/a958d903b74421e4a9019c11c99a85a4fa0608\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/06/\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/06/690e4836b0c73ea8c86b0a2698271de920363b\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/07/\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/07/6c311b111bbcf88c3e1ea7d0dcf492edb56ac1\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/09/\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/09/6df5d1ca188b48575f61375f15763fd2f1df47\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/10/\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/10/9fe1942ea09aa075776b285e5d56a37bc84cf2\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/12/\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/12/c1a16b8a42f9f927f48383ef91f439e2f715fb\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/17/\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/17/267baa25ae95a6ac0902eb6ef9ad692113f013\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/17/4d88a541ec8477175986e565ec76faff5a2566\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/20/\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/20/c633e40afdd44d417dbe6e303454a1995398dc\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/33/\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/33/69f6f77d11f1d87d9b233a8a1b34b8ce139c6c\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/5d/\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/5d/233a7b27c3ead3b5fdc0ec54401593803d81a5\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/60/\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/60/4ef8c08304f2f074d5e172cd88c69be7202e4a\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/64/\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/64/df4f17fe67f3ce0e2ffb187d54582e25c44c28\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/7c/\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/7c/b21270622d9bf03a7cea358b070be69cb26dc4\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/89/\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/89/e53ff1d8dda6af37d4abfeaa46f8bc66914d4a\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/9e/\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/9e/65c2a4e3597a931f9539017505468a34009907\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/a7/\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/a7/f1205a5e6b02ad2a7b89e8b0d8b8af75f51a59\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/ae/\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/ae/60a82f113d2ca600f34d69abf07613ef894d42\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/bb/\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/bb/ca5612ee836b443c73c24d2a7dbe7abc0d7a98\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/c5/\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/c5/a1ef01de7d6b198944500894f4c7bd4f29d204\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/c8/\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/c8/6edb1a92e85a0417ef7f11105645890026eabf\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/e3/\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/e3/e6e74642ff3a1667ea777e9ba2da8ec1fe3134\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/eb/\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/eb/aa55692fae46946f49f7089ff685e46d8e9f0e\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/info/\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/info/commit-graph\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/info/packs\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/pack/\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/pack/pack-0e532d33940d721561bcb5903a5ecc93d6775616.idx\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/pack/pack-0e532d33940d721561bcb5903a5ecc93d6775616.pack\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/pack/pack-11b7b4f1899fa98fbbece2e005cea2589ea4a858.idx\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/pack/pack-11b7b4f1899fa98fbbece2e005cea2589ea4a858.pack\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/pack/pack-2933011e4cfa300245f13eb4bf72fdc8fcf38662.idx\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/pack/pack-2933011e4cfa300245f13eb4bf72fdc8fcf38662.pack\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/pack/pack-a3c202ddeac0354bb12f95de6999775180595d65.idx\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/pack/pack-a3c202ddeac0354bb12f95de6999775180595d65.pack\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/pack/pack-a7880012d31da3a934b2d3352d5b79a7635f2bc6.idx\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/pack/pack-a7880012d31da3a934b2d3352d5b79a7635f2bc6.pack\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/pack/pack-b5665b8364376eb14f9c446f0e948d988dc0bf7a.idx\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/pack/pack-b5665b8364376eb14f9c446f0e948d988dc0bf7a.pack\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/refs/\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/refs/heads/\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/refs/heads/main\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/refs/remotes/\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/refs/remotes/origin/\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/refs/remotes/origin/main\ncd+++++++++ src/github.com/osism/openstack-image-manager/.git/refs/zuul/\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/refs/zuul/b28b7af69320201d1cf206ebf28373980add1451\n<f+++++++++ src/github.com/osism/openstack-image-manager/.git/refs/zuul/fetch\ncd+++++++++ src/github.com/osism/openstack-image-manager/.github/\n<f+++++++++ src/github.com/osism/openstack-image-manager/.github/renovate.json\ncd+++++++++ src/github.com/osism/openstack-image-manager/.github/workflows/\n<f+++++++++ src/github.com/osism/openstack-image-manager/.github/workflows/add-to-project.yml\n<f+++++++++ src/github.com/osism/openstack-image-manager/.github/workflows/publish.yml\n<f+++++++++ src/github.com/osism/openstack-image-manager/.github/workflows/update-image-gardenlinux.yml\n<f+++++++++ src/github.com/osism/openstack-image-manager/.github/workflows/update-images.yml\n<f+++++++++ src/github.com/osism/openstack-image-manager/.github/workflows/validate-configuration.yml\ncd+++++++++ src/github.com/osism/openstack-image-manager/contrib/\n<f+++++++++ src/github.com/osism/openstack-image-manager/contrib/mirror.py\n<f+++++++++ src/github.com/osism/openstack-image-manager/contrib/table.py\n<f+++++++++ src/github.com/osism/openstack-image-manager/contrib/update-gardenlinux.py\n<f+++++++++ src/github.com/osism/openstack-image-manager/contrib/update.py\ncd+++++++++ src/github.com/osism/openstack-image-manager/etc/\n<f+++++++++ src/github.com/osism/openstack-image-manager/etc/__init__.py\n<f+++++++++ src/github.com/osism/openstack-image-manager/etc/schema.yaml\ncd+++++++++ src/github.com/osism/openstack-image-manager/etc/images/\n<f+++++++++ src/github.com/osism/openstack-image-manager/etc/images/almalinux.yml\n<f+++++++++ src/github.com/osism/openstack-image-manager/etc/images/centos.yml\n<f+++++++++ src/github.com/osism/openstack-image-manager/etc/images/cirros.yml\n<f+++++++++ src/github.com/osism/openstack-image-manager/etc/images/debian.yml\n<f+++++++++ src/github.com/osism/openstack-image-manager/etc/images/fedora.yml\n<f+++++++++ src/github.com/osism/openstack-image-manager/etc/images/flatcar.yml\n<f+++++++++ src/github.com/osism/openstack-image-manager/etc/images/gardenlinux.yml\n<f+++++++++ src/github.com/osism/openstack-image-manager/etc/images/opensuse.yml\n<f+++++++++ src/github.com/osism/openstack-image-manager/etc/images/opnsense.yml\n<f+++++++++ src/github.com/osism/openstack-image-manager/etc/images/rockylinux.yml\n<f+++++++++ src/github.com/osism/openstack-image-manager/etc/images/talos.yml\n<f+++++++++ src/github.com/osism/openstack-image-manager/etc/images/ubuntu.yml\ncd+++++++++ src/github.com/osism/openstack-image-manager/openstack_image_manager/\n<f+++++++++ src/github.com/osism/openstack-image-manager/openstack_image_manager/__init__.py\n<f+++++++++ src/github.com/osism/openstack-image-manager/openstack_image_manager/main.py\ncd+++++++++ src/github.com/osism/openstack-image-manager/playbooks/\n<f+++++++++ src/github.com/osism/openstack-image-manager/playbooks/integration-test.yml\n<f+++++++++ src/github.com/osism/openstack-image-manager/playbooks/pre-integration-test.yml\ncd+++++++++ src/github.com/osism/openstack-image-manager/scripts/\n<f+++++++++ src/github.com/osism/openstack-image-manager/scripts/build.sh\n<f+++++++++ src/github.com/osism/openstack-image-manager/scripts/push.sh\ncd+++++++++ src/github.com/osism/openstack-image-manager/test/\n<f+++++++++ src/github.com/osism/openstack-image-manager/test/__init__.py\ncd+++++++++ src/github.com/osism/openstack-image-manager/test/integration/\n<f+++++++++ src/github.com/osism/openstack-image-manager/test/integration/__init__.py\n<f+++++++++ src/github.com/osism/openstack-image-manager/test/integration/test_manage_api.py\ncd+++++++++ src/github.com/osism/openstack-image-manager/test/integration/fixtures/\n<f+++++++++ src/github.com/osism/openstack-image-manager/test/integration/fixtures/fake_image.img\n<f+++++++++ src/github.com/osism/openstack-image-manager/test/integration/fixtures/test_image.yml\ncd+++++++++ src/github.com/osism/openstack-image-manager/test/unit/\n<f+++++++++ src/github.com/osism/openstack-image-manager/test/unit/__init__.py\n<f+++++++++ src/github.com/osism/openstack-image-manager/test/unit/test_manage.py\n",
                            "rc": 0,
                            "stdout_lines": [
                                "cd+++++++++ src/",
                                "cd+++++++++ src/github.com/",
                                "cd+++++++++ src/github.com/osism/",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.clouds.yml",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.flake8",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.gitignore",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.yamllint.yml",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.zuul.yaml",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/LICENSE",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/MANIFEST.in",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/Pipfile",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/Pipfile.lock",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/README.md",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/_config.yml",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/clouds.yml.sample",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/pyproject.toml",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/requirements.txt",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/secure.yml.sample",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/tox.ini",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/COMMIT_EDITMSG",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/FETCH_HEAD",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/HEAD",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/ORIG_HEAD",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/config",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/config.worktree",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/description",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/index",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/packed-refs",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/branches/",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/hooks/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/hooks/applypatch-msg.sample",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/hooks/commit-msg.sample",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/hooks/fsmonitor-watchman.sample",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/hooks/post-update.sample",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/hooks/pre-applypatch.sample",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/hooks/pre-commit.sample",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/hooks/pre-merge-commit.sample",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/hooks/pre-push.sample",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/hooks/pre-rebase.sample",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/hooks/pre-receive.sample",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/hooks/prepare-commit-msg.sample",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/hooks/push-to-checkout.sample",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/hooks/update.sample",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/info/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/info/exclude",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/logs/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/logs/HEAD",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/00/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/00/a958d903b74421e4a9019c11c99a85a4fa0608",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/06/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/06/690e4836b0c73ea8c86b0a2698271de920363b",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/07/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/07/6c311b111bbcf88c3e1ea7d0dcf492edb56ac1",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/09/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/09/6df5d1ca188b48575f61375f15763fd2f1df47",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/10/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/10/9fe1942ea09aa075776b285e5d56a37bc84cf2",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/12/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/12/c1a16b8a42f9f927f48383ef91f439e2f715fb",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/17/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/17/267baa25ae95a6ac0902eb6ef9ad692113f013",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/17/4d88a541ec8477175986e565ec76faff5a2566",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/20/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/20/c633e40afdd44d417dbe6e303454a1995398dc",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/33/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/33/69f6f77d11f1d87d9b233a8a1b34b8ce139c6c",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/5d/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/5d/233a7b27c3ead3b5fdc0ec54401593803d81a5",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/60/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/60/4ef8c08304f2f074d5e172cd88c69be7202e4a",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/64/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/64/df4f17fe67f3ce0e2ffb187d54582e25c44c28",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/7c/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/7c/b21270622d9bf03a7cea358b070be69cb26dc4",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/89/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/89/e53ff1d8dda6af37d4abfeaa46f8bc66914d4a",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/9e/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/9e/65c2a4e3597a931f9539017505468a34009907",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/a7/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/a7/f1205a5e6b02ad2a7b89e8b0d8b8af75f51a59",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/ae/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/ae/60a82f113d2ca600f34d69abf07613ef894d42",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/bb/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/bb/ca5612ee836b443c73c24d2a7dbe7abc0d7a98",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/c5/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/c5/a1ef01de7d6b198944500894f4c7bd4f29d204",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/c8/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/c8/6edb1a92e85a0417ef7f11105645890026eabf",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/e3/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/e3/e6e74642ff3a1667ea777e9ba2da8ec1fe3134",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/eb/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/eb/aa55692fae46946f49f7089ff685e46d8e9f0e",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/info/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/info/commit-graph",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/info/packs",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/pack/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/pack/pack-0e532d33940d721561bcb5903a5ecc93d6775616.idx",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/pack/pack-0e532d33940d721561bcb5903a5ecc93d6775616.pack",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/pack/pack-11b7b4f1899fa98fbbece2e005cea2589ea4a858.idx",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/pack/pack-11b7b4f1899fa98fbbece2e005cea2589ea4a858.pack",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/pack/pack-2933011e4cfa300245f13eb4bf72fdc8fcf38662.idx",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/pack/pack-2933011e4cfa300245f13eb4bf72fdc8fcf38662.pack",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/pack/pack-a3c202ddeac0354bb12f95de6999775180595d65.idx",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/pack/pack-a3c202ddeac0354bb12f95de6999775180595d65.pack",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/pack/pack-a7880012d31da3a934b2d3352d5b79a7635f2bc6.idx",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/pack/pack-a7880012d31da3a934b2d3352d5b79a7635f2bc6.pack",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/pack/pack-b5665b8364376eb14f9c446f0e948d988dc0bf7a.idx",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/objects/pack/pack-b5665b8364376eb14f9c446f0e948d988dc0bf7a.pack",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/refs/",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/refs/heads/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/refs/heads/main",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/refs/remotes/",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/refs/remotes/origin/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/refs/remotes/origin/main",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.git/refs/zuul/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/refs/zuul/b28b7af69320201d1cf206ebf28373980add1451",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.git/refs/zuul/fetch",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.github/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.github/renovate.json",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/.github/workflows/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.github/workflows/add-to-project.yml",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.github/workflows/publish.yml",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.github/workflows/update-image-gardenlinux.yml",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.github/workflows/update-images.yml",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/.github/workflows/validate-configuration.yml",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/contrib/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/contrib/mirror.py",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/contrib/table.py",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/contrib/update-gardenlinux.py",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/contrib/update.py",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/etc/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/etc/__init__.py",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/etc/schema.yaml",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/etc/images/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/etc/images/almalinux.yml",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/etc/images/centos.yml",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/etc/images/cirros.yml",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/etc/images/debian.yml",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/etc/images/fedora.yml",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/etc/images/flatcar.yml",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/etc/images/gardenlinux.yml",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/etc/images/opensuse.yml",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/etc/images/opnsense.yml",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/etc/images/rockylinux.yml",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/etc/images/talos.yml",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/etc/images/ubuntu.yml",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/openstack_image_manager/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/openstack_image_manager/__init__.py",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/openstack_image_manager/main.py",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/playbooks/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/playbooks/integration-test.yml",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/playbooks/pre-integration-test.yml",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/scripts/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/scripts/build.sh",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/scripts/push.sh",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/test/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/test/__init__.py",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/test/integration/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/test/integration/__init__.py",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/test/integration/test_manage_api.py",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/test/integration/fixtures/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/test/integration/fixtures/fake_image.img",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/test/integration/fixtures/test_image.yml",
                                "cd+++++++++ src/github.com/osism/openstack-image-manager/test/unit/",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/test/unit/__init__.py",
                                "<f+++++++++ src/github.com/osism/openstack-image-manager/test/unit/test_manage.py"
                            ]
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-00000000002d",
                        "name": "prepare-workspace-log",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_0/github.com/osism/zuul-config/roles/prepare-workspace-log"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:51.823698Z",
                            "start": "2026-06-19T16:53:50.514351Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-000000000030",
                        "name": "Synchronize src repos to workspace directory."
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "ansible.builtin.file",
                            "changed": true,
                            "msg": "All items completed",
                            "results": [
                                {
                                    "ansible_loop_var": "zj_output_dir",
                                    "changed": true,
                                    "diff": {
                                        "after": {
                                            "path": "/home/zuul/zuul-output/logs",
                                            "state": "directory"
                                        },
                                        "before": {
                                            "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": "0755",
                                            "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": {
                                            "path": "/home/zuul/zuul-output/artifacts",
                                            "state": "directory"
                                        },
                                        "before": {
                                            "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": "0755",
                                            "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": {
                                            "path": "/home/zuul/zuul-output/docs",
                                            "state": "directory"
                                        },
                                        "before": {
                                            "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": "0755",
                                            "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": "0242ac1f-6606-1448-5b9c-000000000032",
                        "name": "ensure-output-dirs-present",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_0/github.com/osism/zuul-config/roles/ensure-output-dirs-present"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:52.652544Z",
                            "start": "2026-06-19T16:53:51.833476Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-000000000034",
                        "name": "Ensure Zuul output directories exist"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "ansible.builtin.file",
                            "changed": false,
                            "diff": {
                                "after": {
                                    "path": "/home/zuul/zuul-output/logs"
                                },
                                "before": {
                                    "path": "/home/zuul/zuul-output/logs"
                                }
                            },
                            "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": "0755",
                                    "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
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-000000000037",
                        "name": "diagnose-first-sudo",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_0/github.com/osism/zuul-config/roles/diagnose-first-sudo"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:53.003497Z",
                            "start": "2026-06-19T16:53:52.662374Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-000000000039",
                        "name": "Ensure log directory exists"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "ansible.builtin.shell",
                            "changed": false,
                            "cmd": "set +e\nout=/home/zuul/zuul-output/logs/sudo-strace.log\n: > \"$out\"\nif command -v strace >/dev/null 2>&1; then\n  cmd=(timeout 40 strace -f -tt -T -y       -o \"$out\"       sudo -n true)\nelse\n  echo \"strace not installed; running bare sudo probe\" > \"$out\"\n  cmd=(timeout 40 sudo -n true)\nfi\n{ TIMEFORMAT='WALL: %3R s'; time \"${cmd[@]}\"; } 2> \"$out.time\"\necho \"EXIT: $?\" >> \"$out.time\"\n",
                            "delta": "0:00:00.071242",
                            "end": "2026-06-19 16:53:53.452355",
                            "failed_when_result": false,
                            "invocation": {
                                "module_args": {
                                    "_raw_params": "set +e\nout=/home/zuul/zuul-output/logs/sudo-strace.log\n: > \"$out\"\nif command -v strace >/dev/null 2>&1; then\n  cmd=(timeout 40 strace -f -tt -T -y       -o \"$out\"       sudo -n true)\nelse\n  echo \"strace not installed; running bare sudo probe\" > \"$out\"\n  cmd=(timeout 40 sudo -n true)\nfi\n{ TIMEFORMAT='WALL: %3R s'; time \"${cmd[@]}\"; } 2> \"$out.time\"\necho \"EXIT: $?\" >> \"$out.time\"\n",
                                    "_uses_shell": true,
                                    "argv": null,
                                    "chdir": null,
                                    "creates": null,
                                    "executable": "/bin/bash",
                                    "expand_argument_vars": true,
                                    "removes": null,
                                    "stdin": null,
                                    "stdin_add_newline": true,
                                    "strip_empty_ends": true,
                                    "zuul_ansible_split_streams": false,
                                    "zuul_log_id": "0242ac1f-6606-1448-5b9c-00000000003a-1-debianbookworm",
                                    "zuul_output_max_bytes": 1073741824
                                }
                            },
                            "msg": "",
                            "rc": 0,
                            "start": "2026-06-19 16:53:53.381113",
                            "stderr": "",
                            "stderr_lines": [],
                            "stdout": "",
                            "stdout_lines": [],
                            "zuul_log_id": "0242ac1f-6606-1448-5b9c-00000000003a-1-debianbookworm"
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-000000000037",
                        "name": "diagnose-first-sudo",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_0/github.com/osism/zuul-config/roles/diagnose-first-sudo"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:53.578413Z",
                            "start": "2026-06-19T16:53:53.064324Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-00000000003a",
                        "name": "Probe first sudo invocation under strace"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "ansible.builtin.shell",
                            "changed": false,
                            "cmd": "set +e\nout=/home/zuul/zuul-output/logs/sudo-debug.txt\n{\n  echo \"== date ==\";            date -Iseconds\n  echo \"== uptime ==\";          uptime\n  echo \"== boot age (s) ==\";    awk '{print int($1)}' /proc/uptime\n  echo \"== /etc/hostname ==\"; cat /etc/hostname\n  echo \"== /etc/hosts ==\";      cat /etc/hosts\n  echo \"== nsswitch.conf ==\";   cat /etc/nsswitch.conf\n  echo \"== resolv.conf ==\";     cat /etc/resolv.conf 2>/dev/null\n  echo \"== ping 8.8.8.8 ==\"\n  ping -c1 -W2 8.8.8.8 2>&1 || true\n  echo \"== ping 81.163.194.9 ==\"\n  ping -c1 -W2 81.163.194.9 2>&1 || true\n  echo \"== ping 81.163.194.10 ==\"\n  ping -c1 -W2 81.163.194.10 2>&1 || true\n  echo \"== getent ahosts ==\"\n  getent ahosts \"$(cat /etc/hostname)\"\n  echo \"== timed getent hosts ==\"\n  { TIMEFORMAT='getent: %3R s'; time getent hosts \"$(cat /etc/hostname)\"; } 2>&1\n  echo \"== systemd-logind active ==\"\n  systemctl is-active systemd-logind\n  echo \"== systemd-logind ActiveEnterTimestampMonotonic ==\"\n  systemctl show systemd-logind -p ActiveEnterTimestampMonotonic\n  echo \"== systemd-resolved active ==\"\n  systemctl is-active systemd-resolved 2>/dev/null\n  echo \"== /etc/pam.d/sudo ==\"\n  cat /etc/pam.d/sudo 2>/dev/null\n  echo \"== sudoers.d listing ==\"\n  ls -la /etc/sudoers.d/ 2>/dev/null\n} > \"$out\" 2>&1\n",
                            "delta": "0:00:00.131803",
                            "end": "2026-06-19 16:53:54.033938",
                            "failed_when_result": false,
                            "invocation": {
                                "module_args": {
                                    "_raw_params": "set +e\nout=/home/zuul/zuul-output/logs/sudo-debug.txt\n{\n  echo \"== date ==\";            date -Iseconds\n  echo \"== uptime ==\";          uptime\n  echo \"== boot age (s) ==\";    awk '{print int($1)}' /proc/uptime\n  echo \"== /etc/hostname ==\"; cat /etc/hostname\n  echo \"== /etc/hosts ==\";      cat /etc/hosts\n  echo \"== nsswitch.conf ==\";   cat /etc/nsswitch.conf\n  echo \"== resolv.conf ==\";     cat /etc/resolv.conf 2>/dev/null\n  echo \"== ping 8.8.8.8 ==\"\n  ping -c1 -W2 8.8.8.8 2>&1 || true\n  echo \"== ping 81.163.194.9 ==\"\n  ping -c1 -W2 81.163.194.9 2>&1 || true\n  echo \"== ping 81.163.194.10 ==\"\n  ping -c1 -W2 81.163.194.10 2>&1 || true\n  echo \"== getent ahosts ==\"\n  getent ahosts \"$(cat /etc/hostname)\"\n  echo \"== timed getent hosts ==\"\n  { TIMEFORMAT='getent: %3R s'; time getent hosts \"$(cat /etc/hostname)\"; } 2>&1\n  echo \"== systemd-logind active ==\"\n  systemctl is-active systemd-logind\n  echo \"== systemd-logind ActiveEnterTimestampMonotonic ==\"\n  systemctl show systemd-logind -p ActiveEnterTimestampMonotonic\n  echo \"== systemd-resolved active ==\"\n  systemctl is-active systemd-resolved 2>/dev/null\n  echo \"== /etc/pam.d/sudo ==\"\n  cat /etc/pam.d/sudo 2>/dev/null\n  echo \"== sudoers.d listing ==\"\n  ls -la /etc/sudoers.d/ 2>/dev/null\n} > \"$out\" 2>&1\n",
                                    "_uses_shell": true,
                                    "argv": null,
                                    "chdir": null,
                                    "creates": null,
                                    "executable": "/bin/bash",
                                    "expand_argument_vars": true,
                                    "removes": null,
                                    "stdin": null,
                                    "stdin_add_newline": true,
                                    "strip_empty_ends": true,
                                    "zuul_ansible_split_streams": false,
                                    "zuul_log_id": "0242ac1f-6606-1448-5b9c-00000000003b-1-debianbookworm",
                                    "zuul_output_max_bytes": 1073741824
                                }
                            },
                            "msg": "",
                            "rc": 0,
                            "start": "2026-06-19 16:53:53.902135",
                            "stderr": "",
                            "stderr_lines": [],
                            "stdout": "",
                            "stdout_lines": [],
                            "zuul_log_id": "0242ac1f-6606-1448-5b9c-00000000003b-1-debianbookworm"
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-000000000037",
                        "name": "diagnose-first-sudo",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_0/github.com/osism/zuul-config/roles/diagnose-first-sudo"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:54.126371Z",
                            "start": "2026-06-19T16:53:53.614525Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-00000000003b",
                        "name": "Snapshot DNS / PAM / logind state (no become)"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "ansible.builtin.file",
                            "changed": false,
                            "diff": {
                                "after": {
                                    "path": "/home/zuul/zuul-output/logs"
                                },
                                "before": {
                                    "path": "/home/zuul/zuul-output/logs"
                                }
                            },
                            "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": "0755",
                                    "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
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-00000000003d",
                        "name": "diagnose-network",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_0/github.com/osism/zuul-config/roles/diagnose-network"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:53:54.486678Z",
                            "start": "2026-06-19T16:53:54.133344Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-00000000003f",
                        "name": "Ensure log directory exists"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "ansible.builtin.shell",
                            "ansible_job_id": "j439908645575.919",
                            "changed": false,
                            "cmd": "set +e\nset -o pipefail\nphase=pre\nout=/home/zuul/zuul-output/logs/net-debug.$phase.txt\ntargets=\"tarballs.opendev.org galaxy.ansible.com\"\niface=$(ip -6 route show default 2>/dev/null        | awk '{for(i=1;i<=NF;i++) if($i==\"dev\"){print $(i+1); exit}}')\n: \"${iface:=eth0}\"\ngw=$(ip -6 route show default 2>/dev/null     | awk '{for(i=1;i<=NF;i++) if($i==\"via\"){print $(i+1); exit}}')\n{\n  echo \"== date ==\";    date -Is\n  echo \"== iface / gw ==\"; echo \"iface=$iface gw=$gw\"\n  echo \"== ip -6 addr (lifetimes = SLAAC evidence) ==\"; ip -6 addr show\n  echo \"== ip -6 route show ==\"; ip -6 route show\n  echo \"== ip -6 route show default (expires/proto ra = RA evidence) ==\"\n  ip -6 route show default\n  echo \"== ip -4 route show default ==\"; ip -4 route show default\n  echo \"== accept_ra / forwarding (procfs; RA-suppression evidence) ==\"\n  for k in all default \"$iface\"; do\n    for s in forwarding accept_ra; do\n      v=$(cat \"/proc/sys/net/ipv6/conf/$k/$s\" 2>/dev/null)\n      echo \"net.ipv6.conf.$k.$s = ${v:-<unavailable>}\"\n    done\n  done\n  echo \"== resolvectl status ==\"\n  if command -v resolvectl >/dev/null 2>&1; then resolvectl status 2>&1\n  else echo \"resolvectl not installed\"; fi\n  echo \"== /etc/resolv.conf (resolver stub) ==\"\n  cat /etc/resolv.conf 2>/dev/null || echo \"(absent)\"\n  echo \"== /run/systemd/resolve/resolv.conf (upstreams) ==\"\n  cat /run/systemd/resolve/resolv.conf 2>/dev/null    || echo \"(no systemd-resolved upstream file)\"\n  for d in $targets; do\n    echo \"== target: $d ==\"\n    echo \"-- getent ahosts (families glibc returns) --\"\n    getent ahosts \"$d\" 2>&1\n    if command -v resolvectl >/dev/null 2>&1; then\n      echo \"-- resolvectl query --\"; resolvectl query --cache=no \"$d\" 2>&1\n    fi\n    v6=$(getent ahosts \"$d\" 2>/dev/null | awk '$1~/:/{print $1; exit}')\n    v4=$(getent ahosts \"$d\" 2>/dev/null         | awk '$1~/^[0-9]+(\\.[0-9]+){3}$/{print $1; exit}')\n    if [ -n \"$v6\" ]; then\n      echo \"-- ip -6 route get $v6 --\"; ip -6 route get \"$v6\" 2>&1\n    fi\n    if [ -n \"$v4\" ]; then\n      echo \"-- ip -4 route get $v4 --\"; ip -4 route get \"$v4\" 2>&1\n    fi\n    # Several attempts per family: a single sample misclassifies a\n    # ~50%-loss path as healthy or dead by coin flip, defeating the\n    # pre/post bracket. Bounded and in-line -- not a background sampler.\n    for fam in 6 4; do\n      echo \"-- curl -$fam (3 attempts) --\"\n      ok=0\n      for n in 1 2 3; do\n        curl -$fam -sS -m 10 -o /dev/null          -w \"  #$n http=%{http_code} ip=%{remote_ip} t=%{time_total}s\\n\"          \"https://$d/\" 2>&1 && ok=1 || echo \"  #$n curl -$fam FAILED\"\n      done\n      # Trace only the family that failed, to its resolved address:\n      # localises WHERE the failing path dies instead of tracing the\n      # healthy family. v4 via traceroute, v6 via traceroute6.\n      if [ \"$ok\" = 0 ]; then\n        addr=$v6; [ \"$fam\" = 4 ] && addr=$v4\n        tr=traceroute6; [ \"$fam\" = 4 ] && tr=traceroute\n        if [ -n \"$addr\" ] && command -v \"$tr\" >/dev/null 2>&1; then\n          echo \"  !! curl -$fam failed 3x; $tr to $addr\"\n          timeout 30 \"$tr\" -q1 -w2 \"$addr\" 2>&1\n        fi\n      fi\n    done\n  done\n  echo \"== ping -6 gateway ==\"\n  if [ -n \"$gw\" ]; then\n    ping -6 -c1 -W2 \"${gw}%${iface}\" 2>&1\n  else echo \"no v6 gw\"; fi\n} > \"$out\" 2>&1\n",
                            "delta": "0:00:34.810687",
                            "end": "2026-06-19 16:54:30.345980",
                            "failed_when_result": false,
                            "finished": 1,
                            "invocation": {
                                "module_args": {
                                    "_raw_params": "set +e\nset -o pipefail\nphase=pre\nout=/home/zuul/zuul-output/logs/net-debug.$phase.txt\ntargets=\"tarballs.opendev.org galaxy.ansible.com\"\niface=$(ip -6 route show default 2>/dev/null        | awk '{for(i=1;i<=NF;i++) if($i==\"dev\"){print $(i+1); exit}}')\n: \"${iface:=eth0}\"\ngw=$(ip -6 route show default 2>/dev/null     | awk '{for(i=1;i<=NF;i++) if($i==\"via\"){print $(i+1); exit}}')\n{\n  echo \"== date ==\";    date -Is\n  echo \"== iface / gw ==\"; echo \"iface=$iface gw=$gw\"\n  echo \"== ip -6 addr (lifetimes = SLAAC evidence) ==\"; ip -6 addr show\n  echo \"== ip -6 route show ==\"; ip -6 route show\n  echo \"== ip -6 route show default (expires/proto ra = RA evidence) ==\"\n  ip -6 route show default\n  echo \"== ip -4 route show default ==\"; ip -4 route show default\n  echo \"== accept_ra / forwarding (procfs; RA-suppression evidence) ==\"\n  for k in all default \"$iface\"; do\n    for s in forwarding accept_ra; do\n      v=$(cat \"/proc/sys/net/ipv6/conf/$k/$s\" 2>/dev/null)\n      echo \"net.ipv6.conf.$k.$s = ${v:-<unavailable>}\"\n    done\n  done\n  echo \"== resolvectl status ==\"\n  if command -v resolvectl >/dev/null 2>&1; then resolvectl status 2>&1\n  else echo \"resolvectl not installed\"; fi\n  echo \"== /etc/resolv.conf (resolver stub) ==\"\n  cat /etc/resolv.conf 2>/dev/null || echo \"(absent)\"\n  echo \"== /run/systemd/resolve/resolv.conf (upstreams) ==\"\n  cat /run/systemd/resolve/resolv.conf 2>/dev/null    || echo \"(no systemd-resolved upstream file)\"\n  for d in $targets; do\n    echo \"== target: $d ==\"\n    echo \"-- getent ahosts (families glibc returns) --\"\n    getent ahosts \"$d\" 2>&1\n    if command -v resolvectl >/dev/null 2>&1; then\n      echo \"-- resolvectl query --\"; resolvectl query --cache=no \"$d\" 2>&1\n    fi\n    v6=$(getent ahosts \"$d\" 2>/dev/null | awk '$1~/:/{print $1; exit}')\n    v4=$(getent ahosts \"$d\" 2>/dev/null         | awk '$1~/^[0-9]+(\\.[0-9]+){3}$/{print $1; exit}')\n    if [ -n \"$v6\" ]; then\n      echo \"-- ip -6 route get $v6 --\"; ip -6 route get \"$v6\" 2>&1\n    fi\n    if [ -n \"$v4\" ]; then\n      echo \"-- ip -4 route get $v4 --\"; ip -4 route get \"$v4\" 2>&1\n    fi\n    # Several attempts per family: a single sample misclassifies a\n    # ~50%-loss path as healthy or dead by coin flip, defeating the\n    # pre/post bracket. Bounded and in-line -- not a background sampler.\n    for fam in 6 4; do\n      echo \"-- curl -$fam (3 attempts) --\"\n      ok=0\n      for n in 1 2 3; do\n        curl -$fam -sS -m 10 -o /dev/null          -w \"  #$n http=%{http_code} ip=%{remote_ip} t=%{time_total}s\\n\"          \"https://$d/\" 2>&1 && ok=1 || echo \"  #$n curl -$fam FAILED\"\n      done\n      # Trace only the family that failed, to its resolved address:\n      # localises WHERE the failing path dies instead of tracing the\n      # healthy family. v4 via traceroute, v6 via traceroute6.\n      if [ \"$ok\" = 0 ]; then\n        addr=$v6; [ \"$fam\" = 4 ] && addr=$v4\n        tr=traceroute6; [ \"$fam\" = 4 ] && tr=traceroute\n        if [ -n \"$addr\" ] && command -v \"$tr\" >/dev/null 2>&1; then\n          echo \"  !! curl -$fam failed 3x; $tr to $addr\"\n          timeout 30 \"$tr\" -q1 -w2 \"$addr\" 2>&1\n        fi\n      fi\n    done\n  done\n  echo \"== ping -6 gateway ==\"\n  if [ -n \"$gw\" ]; then\n    ping -6 -c1 -W2 \"${gw}%${iface}\" 2>&1\n  else echo \"no v6 gw\"; fi\n} > \"$out\" 2>&1\n",
                                    "_uses_shell": true,
                                    "argv": null,
                                    "chdir": null,
                                    "creates": null,
                                    "executable": "/bin/bash",
                                    "expand_argument_vars": true,
                                    "removes": null,
                                    "stdin": null,
                                    "stdin_add_newline": true,
                                    "strip_empty_ends": true,
                                    "zuul_ansible_split_streams": false,
                                    "zuul_log_id": "0242ac1f-6606-1448-5b9c-000000000040-0-debianbookworm",
                                    "zuul_output_max_bytes": 1073741824
                                }
                            },
                            "msg": "non-zero return code",
                            "rc": 1,
                            "results_file": "/home/zuul/.ansible_async/j439908645575.919",
                            "start": "2026-06-19 16:53:55.535293",
                            "started": 1,
                            "stderr": "",
                            "stderr_lines": [],
                            "stdout": "",
                            "stdout_lines": [],
                            "zuul_log_id": "0242ac1f-6606-1448-5b9c-000000000040-0-debianbookworm"
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-00000000003d",
                        "name": "diagnose-network",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_0/github.com/osism/zuul-config/roles/diagnose-network"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:54:32.629323Z",
                            "start": "2026-06-19T16:53:54.492078Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-000000000040",
                        "name": "Snapshot dual-stack network state (pre)"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "ansible.builtin.shell",
                            "changed": false,
                            "false_condition": "diagnose_network_phase == \"post\"",
                            "skip_reason": "Conditional result was False",
                            "skipped": true
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-00000000003d",
                        "name": "diagnose-network",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_0/github.com/osism/zuul-config/roles/diagnose-network"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:54:32.802444Z",
                            "start": "2026-06-19T16:54:32.635366Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-000000000041",
                        "name": "Snapshot Docker/BuildKit IPv6 config (teardown)"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "ansible.builtin.shell",
                            "changed": false,
                            "false_condition": "diagnose_network_phase == \"post\"",
                            "skip_reason": "Conditional result was False",
                            "skipped": true
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-1448-5b9c-00000000003d",
                        "name": "diagnose-network",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_0/github.com/osism/zuul-config/roles/diagnose-network"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:54:32.938029Z",
                            "start": "2026-06-19T16:54:32.808890Z"
                        },
                        "id": "0242ac1f-6606-1448-5b9c-000000000042",
                        "name": "Probe container network namespace (teardown)"
                    }
                }
            ]
        }
    ],
    "stats": {
        "debian-bookworm": {
            "changed": 12,
            "failures": 0,
            "ignored": 0,
            "ok": 32,
            "rescued": 0,
            "skipped": 5,
            "unreachable": 0
        }
    },
    "trusted": true
},
{
    "branch": "main",
    "index": "0",
    "phase": "run",
    "playbook": "github.com/osism/zuul-jobs/playbooks/mypy/run.yaml",
    "plays": [
        {
            "play": {
                "duration": {
                    "end": "2026-06-19T16:55:25.588171Z",
                    "start": "2026-06-19T16:54:34.642963Z"
                },
                "id": "0242ac1f-6606-d2c4-a06b-000000000002",
                "name": "Run mypy"
            },
            "tasks": [
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "ansible.builtin.include_role",
                            "changed": false,
                            "msg": "All items completed",
                            "results": [
                                {
                                    "ansible_loop_var": "item",
                                    "include_args": {
                                        "name": "{{ item }}"
                                    },
                                    "item": "ensure-python"
                                },
                                {
                                    "ansible_loop_var": "item",
                                    "include_args": {
                                        "name": "{{ item }}"
                                    },
                                    "item": "ensure-pip"
                                }
                            ]
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-d2c4-a06b-000000000005",
                        "name": "mypy",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/untrusted/project_0/github.com/osism/zuul-jobs/roles/mypy"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:54:34.750043Z",
                            "start": "2026-06-19T16:54:34.671069Z"
                        },
                        "id": "0242ac1f-6606-d2c4-a06b-000000000007",
                        "name": "Install python"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "assert",
                            "changed": false,
                            "false_condition": "python_version is defined",
                            "skip_reason": "Conditional result was False",
                            "skipped": true
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-d2c4-a06b-00000000003f",
                        "name": "ensure-python",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/untrusted/project_2/github.com/osism/openinfra-zuul-jobs/roles/ensure-python"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:54:34.932238Z",
                            "start": "2026-06-19T16:54:34.875954Z"
                        },
                        "id": "0242ac1f-6606-d2c4-a06b-000000000041",
                        "name": "Validate python_version value"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "package",
                            "changed": false,
                            "false_condition": "python_version is defined",
                            "skip_reason": "Conditional result was False",
                            "skipped": true
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-d2c4-a06b-00000000003f",
                        "name": "ensure-python",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/untrusted/project_2/github.com/osism/openinfra-zuul-jobs/roles/ensure-python"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:54:34.992362Z",
                            "start": "2026-06-19T16:54:34.938994Z"
                        },
                        "id": "0242ac1f-6606-d2c4-a06b-000000000043",
                        "name": "Install specified version of python interpreter and development files (DEB)"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "package",
                            "changed": false,
                            "false_condition": "python_version is defined",
                            "skip_reason": "Conditional result was False",
                            "skipped": true
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-d2c4-a06b-00000000003f",
                        "name": "ensure-python",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/untrusted/project_2/github.com/osism/openinfra-zuul-jobs/roles/ensure-python"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:54:35.069548Z",
                            "start": "2026-06-19T16:54:34.999615Z"
                        },
                        "id": "0242ac1f-6606-d2c4-a06b-000000000044",
                        "name": "Pull in venv package"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "set_fact",
                            "changed": false,
                            "false_condition": "python_version is defined",
                            "skip_reason": "Conditional result was False",
                            "skipped": true
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-d2c4-a06b-00000000003f",
                        "name": "ensure-python",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/untrusted/project_2/github.com/osism/openinfra-zuul-jobs/roles/ensure-python"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:54:35.181354Z",
                            "start": "2026-06-19T16:54:35.081307Z"
                        },
                        "id": "0242ac1f-6606-d2c4-a06b-000000000046",
                        "name": "Set default RPM package name"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "set_fact",
                            "changed": false,
                            "false_condition": "python_version is defined",
                            "skip_reason": "Conditional result was False",
                            "skipped": true
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-d2c4-a06b-00000000003f",
                        "name": "ensure-python",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/untrusted/project_2/github.com/osism/openinfra-zuul-jobs/roles/ensure-python"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:54:35.218241Z",
                            "start": "2026-06-19T16:54:35.187587Z"
                        },
                        "id": "0242ac1f-6606-d2c4-a06b-000000000047",
                        "name": "Set RPM package name for CentOS/RHEL 9/10"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "package",
                            "changed": false,
                            "false_condition": "python_version is defined",
                            "skip_reason": "Conditional result was False",
                            "skipped": true
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-d2c4-a06b-00000000003f",
                        "name": "ensure-python",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/untrusted/project_2/github.com/osism/openinfra-zuul-jobs/roles/ensure-python"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:54:35.273191Z",
                            "start": "2026-06-19T16:54:35.227920Z"
                        },
                        "id": "0242ac1f-6606-d2c4-a06b-000000000048",
                        "name": "Install RPM package"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "include_tasks",
                            "changed": false,
                            "false_condition": "python_use_pyenv",
                            "skip_reason": "Conditional result was False",
                            "skipped": true
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-d2c4-a06b-00000000003f",
                        "name": "ensure-python",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/untrusted/project_2/github.com/osism/openinfra-zuul-jobs/roles/ensure-python"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:54:35.316391Z",
                            "start": "2026-06-19T16:54:35.281547Z"
                        },
                        "id": "0242ac1f-6606-d2c4-a06b-00000000004a",
                        "name": "Install python using pyenv"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "include_tasks",
                            "changed": false,
                            "false_condition": "python_version is defined",
                            "skip_reason": "Conditional result was False",
                            "skipped": true
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-d2c4-a06b-00000000003f",
                        "name": "ensure-python",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/untrusted/project_2/github.com/osism/openinfra-zuul-jobs/roles/ensure-python"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:54:35.368523Z",
                            "start": "2026-06-19T16:54:35.325321Z"
                        },
                        "id": "0242ac1f-6606-d2c4-a06b-00000000004b",
                        "name": "Activate python using stow"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "shell",
                            "changed": true,
                            "cmd": "PYTHON2=0\nPYTHON3=1\n\n# Not all platforms install a `pip` when installing python\n# specific pip packages. We first check if pip$VERSION is\n# available and if not fallback to checking if just `pip`\n# is present.\nif [ \"$PYTHON2\" -eq \"1\" ] ; then\n    command -v pip2 || command -v pip || exit 1\n    python2 -m wheel --help || exit 1\nfi\nif [ \"$PYTHON3\" -eq \"1\" ] ; then\n    command -v pip3 || command -v pip || exit 1\n    python3 -m wheel --help || exit 1\nfi\n",
                            "delta": "0:00:00.009557",
                            "end": "2026-06-19 16:54:36.277020",
                            "failed_when_result": false,
                            "invocation": {
                                "module_args": {
                                    "_raw_params": "PYTHON2=0\nPYTHON3=1\n\n# Not all platforms install a `pip` when installing python\n# specific pip packages. We first check if pip$VERSION is\n# available and if not fallback to checking if just `pip`\n# is present.\nif [ \"$PYTHON2\" -eq \"1\" ] ; then\n    command -v pip2 || command -v pip || exit 1\n    python2 -m wheel --help || exit 1\nfi\nif [ \"$PYTHON3\" -eq \"1\" ] ; then\n    command -v pip3 || command -v pip || exit 1\n    python3 -m wheel --help || exit 1\nfi\n",
                                    "_uses_shell": true,
                                    "argv": null,
                                    "chdir": null,
                                    "creates": null,
                                    "executable": "/bin/bash",
                                    "expand_argument_vars": true,
                                    "removes": null,
                                    "stdin": null,
                                    "stdin_add_newline": true,
                                    "strip_empty_ends": true,
                                    "zuul_ansible_split_streams": false,
                                    "zuul_log_id": "0242ac1f-6606-d2c4-a06b-000000000070-1-debianbookworm",
                                    "zuul_output_max_bytes": 1073741824
                                }
                            },
                            "msg": "non-zero return code",
                            "rc": 1,
                            "start": "2026-06-19 16:54:36.267463",
                            "stderr": "",
                            "stderr_lines": [],
                            "stdout": "",
                            "stdout_lines": [],
                            "zuul_log_id": "0242ac1f-6606-d2c4-a06b-000000000070-1-debianbookworm"
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-d2c4-a06b-00000000006e",
                        "name": "ensure-pip",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/untrusted/project_2/github.com/osism/openinfra-zuul-jobs/roles/ensure-pip"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:54:36.471711Z",
                            "start": "2026-06-19T16:54:35.447139Z"
                        },
                        "id": "0242ac1f-6606-d2c4-a06b-000000000070",
                        "name": "Check if pip is installed"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "include_tasks",
                            "changed": false,
                            "msg": "All items completed",
                            "results": [
                                {
                                    "ansible_loop_var": "zj_distro_os",
                                    "include": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/untrusted/project_2/github.com/osism/openinfra-zuul-jobs/roles/ensure-pip/tasks/Debian.yaml",
                                    "include_args": {},
                                    "zj_distro_os": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/untrusted/project_2/github.com/osism/openinfra-zuul-jobs/roles/ensure-pip/tasks/Debian.yaml"
                                }
                            ]
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-d2c4-a06b-00000000006e",
                        "name": "ensure-pip",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/untrusted/project_2/github.com/osism/openinfra-zuul-jobs/roles/ensure-pip"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:54:36.535476Z",
                            "start": "2026-06-19T16:54:36.477307Z"
                        },
                        "id": "0242ac1f-6606-d2c4-a06b-000000000071",
                        "name": "Install pip from packages"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "apt",
                            "cache_update_time": 1781888079,
                            "cache_updated": true,
                            "changed": true,
                            "invocation": {
                                "module_args": {
                                    "allow_change_held_packages": false,
                                    "allow_downgrade": false,
                                    "allow_unauthenticated": false,
                                    "autoclean": false,
                                    "autoremove": false,
                                    "cache_valid_time": 0,
                                    "clean": false,
                                    "deb": null,
                                    "default_release": null,
                                    "dpkg_options": "force-confdef,force-confold",
                                    "fail_on_autoremove": false,
                                    "force": false,
                                    "force_apt_get": false,
                                    "install_recommends": null,
                                    "lock_timeout": 60,
                                    "only_upgrade": false,
                                    "package": null,
                                    "policy_rc_d": null,
                                    "purge": false,
                                    "state": "present",
                                    "update_cache": true,
                                    "update_cache_retries": 5,
                                    "update_cache_retry_max_delay": 12,
                                    "upgrade": null
                                }
                            }
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-d2c4-a06b-00000000006e",
                        "name": "ensure-pip",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/untrusted/project_2/github.com/osism/openinfra-zuul-jobs/roles/ensure-pip"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:54:40.995377Z",
                            "start": "2026-06-19T16:54:36.558581Z"
                        },
                        "id": "0242ac1f-6606-d2c4-a06b-0000000000bf",
                        "name": "Update package lists"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "package",
                            "cache_update_time": 1781888079,
                            "cache_updated": false,
                            "changed": true,
                            "diff": {},
                            "invocation": {
                                "module_args": {
                                    "allow_change_held_packages": false,
                                    "allow_downgrade": false,
                                    "allow_unauthenticated": false,
                                    "autoclean": false,
                                    "autoremove": false,
                                    "cache_valid_time": 0,
                                    "clean": false,
                                    "deb": null,
                                    "default_release": null,
                                    "dpkg_options": "force-confdef,force-confold",
                                    "fail_on_autoremove": false,
                                    "force": false,
                                    "force_apt_get": false,
                                    "install_recommends": null,
                                    "lock_timeout": 60,
                                    "name": [
                                        "python3-pip",
                                        "python3-setuptools",
                                        "python3-venv",
                                        "python3-wheel"
                                    ],
                                    "only_upgrade": false,
                                    "package": [
                                        "python3-pip",
                                        "python3-setuptools",
                                        "python3-venv",
                                        "python3-wheel"
                                    ],
                                    "policy_rc_d": null,
                                    "purge": false,
                                    "state": "present",
                                    "update_cache": null,
                                    "update_cache_retries": 5,
                                    "update_cache_retry_max_delay": 12,
                                    "upgrade": null
                                }
                            },
                            "stderr": "debconf: delaying package configuration, since apt-utils is not installed\n",
                            "stderr_lines": [
                                "debconf: delaying package configuration, since apt-utils is not installed"
                            ],
                            "stdout": "Reading package lists...\nBuilding dependency tree...\nReading state information...\nSuggested packages:\n  python-setuptools-doc\nThe following NEW packages will be installed:\n  python3-pip python3-setuptools python3-wheel\n0 upgraded, 3 newly installed, 0 to remove and 0 not upgraded.\nNeed to get 1877 kB of archives.\nAfter this operation, 9567 kB of additional disk space will be used.\nGet:1 http://deb.debian.org/debian bookworm/main amd64 python3-setuptools all 66.1.1-1+deb12u2 [522 kB]\nGet:2 http://deb.debian.org/debian bookworm/main amd64 python3-wheel all 0.38.4-2 [30.8 kB]\nGet:3 http://deb.debian.org/debian bookworm/main amd64 python3-pip all 23.0.1+dfsg-1 [1325 kB]\nFetched 1877 kB in 0s (16.6 MB/s)\nSelecting previously unselected package python3-setuptools.\r\n(Reading database ... \r(Reading database ... 5%\r(Reading database ... 10%\r(Reading database ... 15%\r(Reading database ... 20%\r(Reading database ... 25%\r(Reading database ... 30%\r(Reading database ... 35%\r(Reading database ... 40%\r(Reading database ... 45%\r(Reading database ... 50%\r(Reading database ... 55%\r(Reading database ... 60%\r(Reading database ... 65%\r(Reading database ... 70%\r(Reading database ... 75%\r(Reading database ... 80%\r(Reading database ... 85%\r(Reading database ... 90%\r(Reading database ... 95%\r(Reading database ... 100%\r(Reading database ... 27768 files and directories currently installed.)\r\nPreparing to unpack .../python3-setuptools_66.1.1-1+deb12u2_all.deb ...\r\nUnpacking python3-setuptools (66.1.1-1+deb12u2) ...\r\nSelecting previously unselected package python3-wheel.\r\nPreparing to unpack .../python3-wheel_0.38.4-2_all.deb ...\r\nUnpacking python3-wheel (0.38.4-2) ...\r\nSelecting previously unselected package python3-pip.\r\nPreparing to unpack .../python3-pip_23.0.1+dfsg-1_all.deb ...\r\nUnpacking python3-pip (23.0.1+dfsg-1) ...\r\nSetting up python3-setuptools (66.1.1-1+deb12u2) ...\r\nSetting up python3-wheel (0.38.4-2) ...\r\nSetting up python3-pip (23.0.1+dfsg-1) ...\r\n",
                            "stdout_lines": [
                                "Reading package lists...",
                                "Building dependency tree...",
                                "Reading state information...",
                                "Suggested packages:",
                                "  python-setuptools-doc",
                                "The following NEW packages will be installed:",
                                "  python3-pip python3-setuptools python3-wheel",
                                "0 upgraded, 3 newly installed, 0 to remove and 0 not upgraded.",
                                "Need to get 1877 kB of archives.",
                                "After this operation, 9567 kB of additional disk space will be used.",
                                "Get:1 http://deb.debian.org/debian bookworm/main amd64 python3-setuptools all 66.1.1-1+deb12u2 [522 kB]",
                                "Get:2 http://deb.debian.org/debian bookworm/main amd64 python3-wheel all 0.38.4-2 [30.8 kB]",
                                "Get:3 http://deb.debian.org/debian bookworm/main amd64 python3-pip all 23.0.1+dfsg-1 [1325 kB]",
                                "Fetched 1877 kB in 0s (16.6 MB/s)",
                                "Selecting previously unselected package python3-setuptools.",
                                "(Reading database ... ",
                                "(Reading database ... 5%",
                                "(Reading database ... 10%",
                                "(Reading database ... 15%",
                                "(Reading database ... 20%",
                                "(Reading database ... 25%",
                                "(Reading database ... 30%",
                                "(Reading database ... 35%",
                                "(Reading database ... 40%",
                                "(Reading database ... 45%",
                                "(Reading database ... 50%",
                                "(Reading database ... 55%",
                                "(Reading database ... 60%",
                                "(Reading database ... 65%",
                                "(Reading database ... 70%",
                                "(Reading database ... 75%",
                                "(Reading database ... 80%",
                                "(Reading database ... 85%",
                                "(Reading database ... 90%",
                                "(Reading database ... 95%",
                                "(Reading database ... 100%",
                                "(Reading database ... 27768 files and directories currently installed.)",
                                "Preparing to unpack .../python3-setuptools_66.1.1-1+deb12u2_all.deb ...",
                                "Unpacking python3-setuptools (66.1.1-1+deb12u2) ...",
                                "Selecting previously unselected package python3-wheel.",
                                "Preparing to unpack .../python3-wheel_0.38.4-2_all.deb ...",
                                "Unpacking python3-wheel (0.38.4-2) ...",
                                "Selecting previously unselected package python3-pip.",
                                "Preparing to unpack .../python3-pip_23.0.1+dfsg-1_all.deb ...",
                                "Unpacking python3-pip (23.0.1+dfsg-1) ...",
                                "Setting up python3-setuptools (66.1.1-1+deb12u2) ...",
                                "Setting up python3-wheel (0.38.4-2) ...",
                                "Setting up python3-pip (23.0.1+dfsg-1) ..."
                            ]
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-d2c4-a06b-00000000006e",
                        "name": "ensure-pip",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/untrusted/project_2/github.com/osism/openinfra-zuul-jobs/roles/ensure-pip"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:54:45.924054Z",
                            "start": "2026-06-19T16:54:41.000232Z"
                        },
                        "id": "0242ac1f-6606-d2c4-a06b-0000000000c0",
                        "name": "Install Python 3 pip"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "package",
                            "changed": false,
                            "false_condition": "ensure_pip_from_packages_with_python2",
                            "skip_reason": "Conditional result was False",
                            "skipped": true
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-d2c4-a06b-00000000006e",
                        "name": "ensure-pip",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/untrusted/project_2/github.com/osism/openinfra-zuul-jobs/roles/ensure-pip"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:54:46.070995Z",
                            "start": "2026-06-19T16:54:45.949348Z"
                        },
                        "id": "0242ac1f-6606-d2c4-a06b-0000000000c1",
                        "name": "Install Python 2 pip"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "package",
                            "changed": false,
                            "false_condition": "ansible_python.version.major == 2",
                            "skip_reason": "Conditional result was False",
                            "skipped": true
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-d2c4-a06b-00000000006e",
                        "name": "ensure-pip",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/untrusted/project_2/github.com/osism/openinfra-zuul-jobs/roles/ensure-pip"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:54:46.124107Z",
                            "start": "2026-06-19T16:54:46.078541Z"
                        },
                        "id": "0242ac1f-6606-d2c4-a06b-000000000076",
                        "name": "Ensure setuptools"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "command",
                            "changed": true,
                            "cmd": [
                                "python3",
                                "-m",
                                "ensurepip",
                                "--help"
                            ],
                            "delta": "0:00:00.072507",
                            "end": "2026-06-19 16:54:46.535295",
                            "failed_when_result": false,
                            "invocation": {
                                "module_args": {
                                    "_raw_params": "python3 -m ensurepip --help",
                                    "_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": "0242ac1f-6606-d2c4-a06b-000000000077-1-debianbookworm",
                                    "zuul_output_max_bytes": 1073741824
                                }
                            },
                            "msg": "",
                            "rc": 0,
                            "start": "2026-06-19 16:54:46.462788",
                            "stderr": "",
                            "stderr_lines": [],
                            "stdout": "usage: python -m ensurepip [-h] [--version] [-v] [-U] [--user] [--root ROOT]\n                           [--altinstall] [--default-pip]\n\noptions:\n  -h, --help     show this help message and exit\n  --version      Show the version of pip that is bundled with this Python.\n  -v, --verbose  Give more output. Option is additive, and can be used up to 3\n                 times.\n  -U, --upgrade  Upgrade pip and dependencies, even if already installed.\n  --user         Install using the user scheme.\n  --root ROOT    Install everything relative to this alternate root directory.\n  --altinstall   Make an alternate install, installing only the X.Y versioned\n                 scripts (Default: pipX, pipX.Y, easy_install-X.Y).\n  --default-pip  Make a default pip install, installing the unqualified pip\n                 and easy_install in addition to the versioned scripts.",
                            "stdout_lines": [
                                "usage: python -m ensurepip [-h] [--version] [-v] [-U] [--user] [--root ROOT]",
                                "                           [--altinstall] [--default-pip]",
                                "",
                                "options:",
                                "  -h, --help     show this help message and exit",
                                "  --version      Show the version of pip that is bundled with this Python.",
                                "  -v, --verbose  Give more output. Option is additive, and can be used up to 3",
                                "                 times.",
                                "  -U, --upgrade  Upgrade pip and dependencies, even if already installed.",
                                "  --user         Install using the user scheme.",
                                "  --root ROOT    Install everything relative to this alternate root directory.",
                                "  --altinstall   Make an alternate install, installing only the X.Y versioned",
                                "                 scripts (Default: pipX, pipX.Y, easy_install-X.Y).",
                                "  --default-pip  Make a default pip install, installing the unqualified pip",
                                "                 and easy_install in addition to the versioned scripts."
                            ],
                            "zuul_log_id": "0242ac1f-6606-d2c4-a06b-000000000077-1-debianbookworm"
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-d2c4-a06b-00000000006e",
                        "name": "ensure-pip",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/untrusted/project_2/github.com/osism/openinfra-zuul-jobs/roles/ensure-pip"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:54:46.701657Z",
                            "start": "2026-06-19T16:54:46.186215Z"
                        },
                        "id": "0242ac1f-6606-d2c4-a06b-000000000077",
                        "name": "Check for ensurepip module"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "package",
                            "changed": false,
                            "false_condition": "_ensurepip_module.rc != 0",
                            "skip_reason": "Conditional result was False",
                            "skipped": true
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-d2c4-a06b-00000000006e",
                        "name": "ensure-pip",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/untrusted/project_2/github.com/osism/openinfra-zuul-jobs/roles/ensure-pip"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:54:46.757602Z",
                            "start": "2026-06-19T16:54:46.708164Z"
                        },
                        "id": "0242ac1f-6606-d2c4-a06b-000000000078",
                        "name": "Ensure python3-venv"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "include_tasks",
                            "changed": false,
                            "false_condition": "ensure_pip_from_upstream",
                            "skip_reason": "Conditional result was False",
                            "skipped": true
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-d2c4-a06b-00000000006e",
                        "name": "ensure-pip",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/untrusted/project_2/github.com/osism/openinfra-zuul-jobs/roles/ensure-pip"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:54:46.791978Z",
                            "start": "2026-06-19T16:54:46.764269Z"
                        },
                        "id": "0242ac1f-6606-d2c4-a06b-000000000079",
                        "name": "Install pip from source"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "shell",
                            "changed": true,
                            "cmd": "command -v python3\n",
                            "delta": "0:00:00.008195",
                            "end": "2026-06-19 16:54:47.091045",
                            "failed_when_result": false,
                            "invocation": {
                                "module_args": {
                                    "_raw_params": "command -v python3\n",
                                    "_uses_shell": true,
                                    "argv": null,
                                    "chdir": null,
                                    "creates": null,
                                    "executable": "/bin/bash",
                                    "expand_argument_vars": true,
                                    "removes": null,
                                    "stdin": null,
                                    "stdin_add_newline": true,
                                    "strip_empty_ends": true,
                                    "zuul_ansible_split_streams": false,
                                    "zuul_log_id": "0242ac1f-6606-d2c4-a06b-00000000007a-1-debianbookworm",
                                    "zuul_output_max_bytes": 1073741824
                                }
                            },
                            "msg": "",
                            "rc": 0,
                            "start": "2026-06-19 16:54:47.082850",
                            "stderr": "",
                            "stderr_lines": [],
                            "stdout": "/usr/bin/python3",
                            "stdout_lines": [
                                "/usr/bin/python3"
                            ],
                            "zuul_log_id": "0242ac1f-6606-d2c4-a06b-00000000007a-1-debianbookworm"
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-d2c4-a06b-00000000006e",
                        "name": "ensure-pip",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/untrusted/project_2/github.com/osism/openinfra-zuul-jobs/roles/ensure-pip"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:54:47.331562Z",
                            "start": "2026-06-19T16:54:46.818397Z"
                        },
                        "id": "0242ac1f-6606-d2c4-a06b-00000000007a",
                        "name": "Probe for venv python full path"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "set_fact",
                            "ansible_facts": {
                                "_host_virtualenv": "/usr/bin/python3 -m venv"
                            },
                            "changed": false
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-d2c4-a06b-00000000006e",
                        "name": "ensure-pip",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/untrusted/project_2/github.com/osism/openinfra-zuul-jobs/roles/ensure-pip"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:54:47.399459Z",
                            "start": "2026-06-19T16:54:47.338423Z"
                        },
                        "id": "0242ac1f-6606-d2c4-a06b-00000000007b",
                        "name": "Set host default"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "set_fact",
                            "ansible_facts": {
                                "ensure_pip_virtualenv_command": "/usr/bin/python3 -m venv"
                            },
                            "changed": false
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-d2c4-a06b-00000000006e",
                        "name": "ensure-pip",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/untrusted/project_2/github.com/osism/openinfra-zuul-jobs/roles/ensure-pip"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:54:47.480777Z",
                            "start": "2026-06-19T16:54:47.406520Z"
                        },
                        "id": "0242ac1f-6606-d2c4-a06b-00000000007c",
                        "name": "Set ensure_pip_virtualenv_command"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "ansible.builtin.pip",
                            "changed": true,
                            "cmd": [
                                "/tmp/venv/bin/pip3",
                                "install",
                                "mypy==1.20.2"
                            ],
                            "invocation": {
                                "module_args": {
                                    "chdir": null,
                                    "editable": false,
                                    "executable": null,
                                    "extra_args": null,
                                    "name": [
                                        "mypy==1.20.2"
                                    ],
                                    "requirements": null,
                                    "state": "present",
                                    "umask": null,
                                    "version": null,
                                    "virtualenv": "/tmp/venv",
                                    "virtualenv_command": "python3 -m venv",
                                    "virtualenv_python": null,
                                    "virtualenv_site_packages": false
                                }
                            },
                            "name": [
                                "mypy==1.20.2"
                            ],
                            "requirements": null,
                            "state": "present",
                            "stderr": "",
                            "stderr_lines": [],
                            "stdout": "Collecting mypy==1.20.2\n  Downloading mypy-1.20.2-cp311-cp311-manylinux2014_x86_64.manylinux_2_17_x86_64.manylinux_2_28_x86_64.whl (14.6 MB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 14.6/14.6 MB 18.2 MB/s eta 0:00:00\nCollecting typing_extensions>=4.6.0\n  Downloading typing_extensions-4.15.0-py3-none-any.whl (44 kB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 44.6/44.6 kB 2.0 MB/s eta 0:00:00\nCollecting mypy_extensions>=1.0.0\n  Downloading mypy_extensions-1.1.0-py3-none-any.whl (5.0 kB)\nCollecting pathspec>=1.0.0\n  Downloading pathspec-1.1.1-py3-none-any.whl (57 kB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 57.3/57.3 kB 9.4 MB/s eta 0:00:00\nCollecting librt>=0.8.0\n  Downloading librt-0.11.0-cp311-cp311-manylinux2014_x86_64.manylinux_2_17_x86_64.manylinux_2_28_x86_64.whl (497 kB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 497.1/497.1 kB 18.1 MB/s eta 0:00:00\nInstalling collected packages: typing_extensions, pathspec, mypy_extensions, librt, mypy\nSuccessfully installed librt-0.11.0 mypy-1.20.2 mypy_extensions-1.1.0 pathspec-1.1.1 typing_extensions-4.15.0\n",
                            "stdout_lines": [
                                "Collecting mypy==1.20.2",
                                "  Downloading mypy-1.20.2-cp311-cp311-manylinux2014_x86_64.manylinux_2_17_x86_64.manylinux_2_28_x86_64.whl (14.6 MB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 14.6/14.6 MB 18.2 MB/s eta 0:00:00",
                                "Collecting typing_extensions>=4.6.0",
                                "  Downloading typing_extensions-4.15.0-py3-none-any.whl (44 kB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 44.6/44.6 kB 2.0 MB/s eta 0:00:00",
                                "Collecting mypy_extensions>=1.0.0",
                                "  Downloading mypy_extensions-1.1.0-py3-none-any.whl (5.0 kB)",
                                "Collecting pathspec>=1.0.0",
                                "  Downloading pathspec-1.1.1-py3-none-any.whl (57 kB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 57.3/57.3 kB 9.4 MB/s eta 0:00:00",
                                "Collecting librt>=0.8.0",
                                "  Downloading librt-0.11.0-cp311-cp311-manylinux2014_x86_64.manylinux_2_17_x86_64.manylinux_2_28_x86_64.whl (497 kB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 497.1/497.1 kB 18.1 MB/s eta 0:00:00",
                                "Installing collected packages: typing_extensions, pathspec, mypy_extensions, librt, mypy",
                                "Successfully installed librt-0.11.0 mypy-1.20.2 mypy_extensions-1.1.0 pathspec-1.1.1 typing_extensions-4.15.0"
                            ],
                            "version": null,
                            "virtualenv": "/tmp/venv"
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-d2c4-a06b-000000000005",
                        "name": "mypy",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/untrusted/project_0/github.com/osism/zuul-jobs/roles/mypy"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:54:56.794772Z",
                            "start": "2026-06-19T16:54:47.551876Z"
                        },
                        "id": "0242ac1f-6606-d2c4-a06b-000000000008",
                        "name": "Install mypy"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "ansible.builtin.pip",
                            "changed": true,
                            "cmd": [
                                "/tmp/venv/bin/pip3",
                                "install",
                                "-r",
                                "requirements.txt"
                            ],
                            "invocation": {
                                "module_args": {
                                    "chdir": "src/github.com/osism/openstack-image-manager",
                                    "editable": false,
                                    "executable": null,
                                    "extra_args": null,
                                    "name": null,
                                    "requirements": "requirements.txt",
                                    "state": "present",
                                    "umask": null,
                                    "version": null,
                                    "virtualenv": "/tmp/venv",
                                    "virtualenv_command": "virtualenv",
                                    "virtualenv_python": null,
                                    "virtualenv_site_packages": false
                                }
                            },
                            "name": null,
                            "requirements": "requirements.txt",
                            "state": "present",
                            "stderr": "WARNING: typer 0.26.6 does not provide the extra 'all'\n",
                            "stderr_lines": [
                                "WARNING: typer 0.26.6 does not provide the extra 'all'"
                            ],
                            "stdout": "Collecting loguru==0.7.3\n  Downloading loguru-0.7.3-py3-none-any.whl (61 kB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 61.6/61.6 kB 2.3 MB/s eta 0:00:00\nCollecting minio==7.2.20\n  Downloading minio-7.2.20-py3-none-any.whl (93 kB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 93.8/93.8 kB 5.8 MB/s eta 0:00:00\nCollecting munch==4.0.0\n  Downloading munch-4.0.0-py2.py3-none-any.whl (9.9 kB)\nCollecting natsort==8.4.0\n  Downloading natsort-8.4.0-py3-none-any.whl (38 kB)\nCollecting openstacksdk==4.15.0\n  Downloading openstacksdk-4.15.0-py3-none-any.whl (2.0 MB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 2.0/2.0 MB 24.5 MB/s eta 0:00:00\nCollecting paramiko==5.0.0\n  Downloading paramiko-5.0.0-py3-none-any.whl (208 kB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 208.9/208.9 kB 25.3 MB/s eta 0:00:00\nCollecting patool==4.0.5\n  Downloading patool-4.0.5-py2.py3-none-any.whl (101 kB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 101.4/101.4 kB 18.4 MB/s eta 0:00:00\nCollecting requests==2.34.2\n  Downloading requests-2.34.2-py3-none-any.whl (73 kB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 73.1/73.1 kB 11.4 MB/s eta 0:00:00\nCollecting ruamel.yaml==0.19.1\n  Downloading ruamel_yaml-0.19.1-py3-none-any.whl (118 kB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 118.1/118.1 kB 18.4 MB/s eta 0:00:00\nCollecting setuptools==82.0.1\n  Downloading setuptools-82.0.1-py3-none-any.whl (1.0 MB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 1.0/1.0 MB 23.9 MB/s eta 0:00:00\nCollecting tabulate==0.10.0\n  Downloading tabulate-0.10.0-py3-none-any.whl (39 kB)\nCollecting typer[all]==0.26.6\n  Downloading typer-0.26.6-py3-none-any.whl (122 kB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 122.5/122.5 kB 21.5 MB/s eta 0:00:00\nCollecting yamale==6.1.0\n  Downloading yamale-6.1.0-py3-none-any.whl (58 kB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 58.2/58.2 kB 9.6 MB/s eta 0:00:00\nCollecting argon2-cffi\n  Downloading argon2_cffi-25.1.0-py3-none-any.whl (14 kB)\nCollecting certifi\n  Downloading certifi-2026.6.17-py3-none-any.whl (133 kB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 133.3/133.3 kB 16.4 MB/s eta 0:00:00\nCollecting pycryptodome\n  Downloading pycryptodome-3.23.0-cp37-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (2.3 MB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 2.3/2.3 MB 15.4 MB/s eta 0:00:00\nRequirement already satisfied: typing-extensions in /tmp/venv/lib/python3.11/site-packages (from minio==7.2.20->-r requirements.txt (line 2)) (4.15.0)\nCollecting urllib3\n  Downloading urllib3-2.7.0-py3-none-any.whl (131 kB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 131.1/131.1 kB 19.9 MB/s eta 0:00:00\nCollecting cryptography>=2.7\n  Downloading cryptography-49.0.0-cp311-abi3-manylinux_2_34_x86_64.whl (4.7 MB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 4.7/4.7 MB 23.6 MB/s eta 0:00:00\nCollecting decorator>=4.4.1\n  Downloading decorator-5.3.1-py3-none-any.whl (10 kB)\nCollecting dogpile.cache>=0.6.5\n  Downloading dogpile_cache-1.5.0-py3-none-any.whl (64 kB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 64.4/64.4 kB 5.2 MB/s eta 0:00:00\nCollecting iso8601>=0.1.11\n  Downloading iso8601-2.1.0-py3-none-any.whl (7.5 kB)\nCollecting jmespath>=0.9.0\n  Downloading jmespath-1.1.0-py3-none-any.whl (20 kB)\nCollecting jsonpatch!=1.20,>=1.16\n  Downloading jsonpatch-1.33-py2.py3-none-any.whl (12 kB)\nCollecting keystoneauth1>=5.10.0\n  Downloading keystoneauth1-5.14.0-py3-none-any.whl (343 kB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 343.3/343.3 kB 21.8 MB/s eta 0:00:00\nCollecting os-service-types>=1.8.1\n  Downloading os_service_types-1.8.2-py3-none-any.whl (24 kB)\nCollecting pbr!=2.1.0,>=2.0.0\n  Downloading pbr-7.0.3-py2.py3-none-any.whl (131 kB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 131.9/131.9 kB 18.1 MB/s eta 0:00:00\nCollecting platformdirs>=3\n  Downloading platformdirs-4.10.0-py3-none-any.whl (22 kB)\nCollecting psutil>=3.2.2\n  Downloading psutil-7.2.2-cp36-abi3-manylinux2010_x86_64.manylinux_2_12_x86_64.manylinux_2_28_x86_64.whl (155 kB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 155.6/155.6 kB 22.0 MB/s eta 0:00:00\nCollecting PyYAML>=3.13\n  Downloading pyyaml-6.0.3-cp311-cp311-manylinux2014_x86_64.manylinux_2_17_x86_64.manylinux_2_28_x86_64.whl (806 kB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 806.6/806.6 kB 21.5 MB/s eta 0:00:00\nCollecting bcrypt>=3.2\n  Downloading bcrypt-5.0.0-cp39-abi3-manylinux_2_34_x86_64.whl (278 kB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 278.2/278.2 kB 25.4 MB/s eta 0:00:00\nCollecting invoke>=2.0\n  Downloading invoke-3.0.3-py3-none-any.whl (160 kB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 161.0/161.0 kB 23.7 MB/s eta 0:00:00\nCollecting pynacl>=1.5\n  Downloading pynacl-1.6.2-cp38-abi3-manylinux_2_34_x86_64.whl (1.4 MB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 1.4/1.4 MB 26.7 MB/s eta 0:00:00\nCollecting charset_normalizer<4,>=2\n  Downloading charset_normalizer-3.4.7-cp311-cp311-manylinux2014_x86_64.manylinux_2_17_x86_64.manylinux_2_28_x86_64.whl (214 kB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 214.1/214.1 kB 25.1 MB/s eta 0:00:00\nCollecting idna<4,>=2.5\n  Downloading idna-3.18-py3-none-any.whl (65 kB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 65.5/65.5 kB 8.2 MB/s eta 0:00:00\nCollecting shellingham>=1.3.0\n  Downloading shellingham-1.5.4-py2.py3-none-any.whl (9.8 kB)\nCollecting rich>=13.8.0\n  Downloading rich-15.0.0-py3-none-any.whl (310 kB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 310.7/310.7 kB 26.1 MB/s eta 0:00:00\nCollecting annotated-doc>=0.0.2\n  Downloading annotated_doc-0.0.4-py3-none-any.whl (5.3 kB)\nCollecting cffi>=2.0.0\n  Downloading cffi-2.0.0-cp311-cp311-manylinux2014_x86_64.manylinux_2_17_x86_64.whl (215 kB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 215.6/215.6 kB 24.9 MB/s eta 0:00:00\nCollecting stevedore>=3.0.0\n  Downloading stevedore-5.8.0-py3-none-any.whl (54 kB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 54.6/54.6 kB 5.2 MB/s eta 0:00:00\nCollecting jsonpointer>=1.9\n  Downloading jsonpointer-3.1.1-py3-none-any.whl (7.7 kB)\nCollecting markdown-it-py>=2.2.0\n  Downloading markdown_it_py-4.2.0-py3-none-any.whl (91 kB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 91.7/91.7 kB 15.9 MB/s eta 0:00:00\nCollecting pygments<3.0.0,>=2.13.0\n  Downloading pygments-2.20.0-py3-none-any.whl (1.2 MB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 1.2/1.2 MB 25.1 MB/s eta 0:00:00\nCollecting argon2-cffi-bindings\n  Downloading argon2_cffi_bindings-25.1.0-cp39-abi3-manylinux_2_26_x86_64.manylinux_2_28_x86_64.whl (87 kB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 87.1/87.1 kB 14.8 MB/s eta 0:00:00\nCollecting pycparser\n  Downloading pycparser-3.0-py3-none-any.whl (48 kB)\n     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 48.2/48.2 kB 8.1 MB/s eta 0:00:00\nCollecting mdurl~=0.1\n  Downloading mdurl-0.1.2-py3-none-any.whl (10.0 kB)\nInstalling collected packages: urllib3, tabulate, stevedore, shellingham, setuptools, ruamel.yaml, PyYAML, pygments, pycryptodome, pycparser, psutil, platformdirs, patool, natsort, munch, mdurl, loguru, jsonpointer, jmespath, iso8601, invoke, idna, decorator, charset_normalizer, certifi, bcrypt, annotated-doc, yamale, requests, pbr, markdown-it-py, jsonpatch, dogpile.cache, cffi, rich, pynacl, os-service-types, cryptography, argon2-cffi-bindings, typer, paramiko, keystoneauth1, argon2-cffi, openstacksdk, minio\n  Attempting uninstall: setuptools\n    Found existing installation: setuptools 66.1.1\n    Uninstalling setuptools-66.1.1:\n      Successfully uninstalled setuptools-66.1.1\nSuccessfully installed PyYAML-6.0.3 annotated-doc-0.0.4 argon2-cffi-25.1.0 argon2-cffi-bindings-25.1.0 bcrypt-5.0.0 certifi-2026.6.17 cffi-2.0.0 charset_normalizer-3.4.7 cryptography-49.0.0 decorator-5.3.1 dogpile.cache-1.5.0 idna-3.18 invoke-3.0.3 iso8601-2.1.0 jmespath-1.1.0 jsonpatch-1.33 jsonpointer-3.1.1 keystoneauth1-5.14.0 loguru-0.7.3 markdown-it-py-4.2.0 mdurl-0.1.2 minio-7.2.20 munch-4.0.0 natsort-8.4.0 openstacksdk-4.15.0 os-service-types-1.8.2 paramiko-5.0.0 patool-4.0.5 pbr-7.0.3 platformdirs-4.10.0 psutil-7.2.2 pycparser-3.0 pycryptodome-3.23.0 pygments-2.20.0 pynacl-1.6.2 requests-2.34.2 rich-15.0.0 ruamel.yaml-0.19.1 setuptools-82.0.1 shellingham-1.5.4 stevedore-5.8.0 tabulate-0.10.0 typer-0.26.6 urllib3-2.7.0 yamale-6.1.0\n",
                            "stdout_lines": [
                                "Collecting loguru==0.7.3",
                                "  Downloading loguru-0.7.3-py3-none-any.whl (61 kB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 61.6/61.6 kB 2.3 MB/s eta 0:00:00",
                                "Collecting minio==7.2.20",
                                "  Downloading minio-7.2.20-py3-none-any.whl (93 kB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 93.8/93.8 kB 5.8 MB/s eta 0:00:00",
                                "Collecting munch==4.0.0",
                                "  Downloading munch-4.0.0-py2.py3-none-any.whl (9.9 kB)",
                                "Collecting natsort==8.4.0",
                                "  Downloading natsort-8.4.0-py3-none-any.whl (38 kB)",
                                "Collecting openstacksdk==4.15.0",
                                "  Downloading openstacksdk-4.15.0-py3-none-any.whl (2.0 MB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 2.0/2.0 MB 24.5 MB/s eta 0:00:00",
                                "Collecting paramiko==5.0.0",
                                "  Downloading paramiko-5.0.0-py3-none-any.whl (208 kB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 208.9/208.9 kB 25.3 MB/s eta 0:00:00",
                                "Collecting patool==4.0.5",
                                "  Downloading patool-4.0.5-py2.py3-none-any.whl (101 kB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 101.4/101.4 kB 18.4 MB/s eta 0:00:00",
                                "Collecting requests==2.34.2",
                                "  Downloading requests-2.34.2-py3-none-any.whl (73 kB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 73.1/73.1 kB 11.4 MB/s eta 0:00:00",
                                "Collecting ruamel.yaml==0.19.1",
                                "  Downloading ruamel_yaml-0.19.1-py3-none-any.whl (118 kB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 118.1/118.1 kB 18.4 MB/s eta 0:00:00",
                                "Collecting setuptools==82.0.1",
                                "  Downloading setuptools-82.0.1-py3-none-any.whl (1.0 MB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 1.0/1.0 MB 23.9 MB/s eta 0:00:00",
                                "Collecting tabulate==0.10.0",
                                "  Downloading tabulate-0.10.0-py3-none-any.whl (39 kB)",
                                "Collecting typer[all]==0.26.6",
                                "  Downloading typer-0.26.6-py3-none-any.whl (122 kB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 122.5/122.5 kB 21.5 MB/s eta 0:00:00",
                                "Collecting yamale==6.1.0",
                                "  Downloading yamale-6.1.0-py3-none-any.whl (58 kB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 58.2/58.2 kB 9.6 MB/s eta 0:00:00",
                                "Collecting argon2-cffi",
                                "  Downloading argon2_cffi-25.1.0-py3-none-any.whl (14 kB)",
                                "Collecting certifi",
                                "  Downloading certifi-2026.6.17-py3-none-any.whl (133 kB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 133.3/133.3 kB 16.4 MB/s eta 0:00:00",
                                "Collecting pycryptodome",
                                "  Downloading pycryptodome-3.23.0-cp37-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (2.3 MB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 2.3/2.3 MB 15.4 MB/s eta 0:00:00",
                                "Requirement already satisfied: typing-extensions in /tmp/venv/lib/python3.11/site-packages (from minio==7.2.20->-r requirements.txt (line 2)) (4.15.0)",
                                "Collecting urllib3",
                                "  Downloading urllib3-2.7.0-py3-none-any.whl (131 kB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 131.1/131.1 kB 19.9 MB/s eta 0:00:00",
                                "Collecting cryptography>=2.7",
                                "  Downloading cryptography-49.0.0-cp311-abi3-manylinux_2_34_x86_64.whl (4.7 MB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 4.7/4.7 MB 23.6 MB/s eta 0:00:00",
                                "Collecting decorator>=4.4.1",
                                "  Downloading decorator-5.3.1-py3-none-any.whl (10 kB)",
                                "Collecting dogpile.cache>=0.6.5",
                                "  Downloading dogpile_cache-1.5.0-py3-none-any.whl (64 kB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 64.4/64.4 kB 5.2 MB/s eta 0:00:00",
                                "Collecting iso8601>=0.1.11",
                                "  Downloading iso8601-2.1.0-py3-none-any.whl (7.5 kB)",
                                "Collecting jmespath>=0.9.0",
                                "  Downloading jmespath-1.1.0-py3-none-any.whl (20 kB)",
                                "Collecting jsonpatch!=1.20,>=1.16",
                                "  Downloading jsonpatch-1.33-py2.py3-none-any.whl (12 kB)",
                                "Collecting keystoneauth1>=5.10.0",
                                "  Downloading keystoneauth1-5.14.0-py3-none-any.whl (343 kB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 343.3/343.3 kB 21.8 MB/s eta 0:00:00",
                                "Collecting os-service-types>=1.8.1",
                                "  Downloading os_service_types-1.8.2-py3-none-any.whl (24 kB)",
                                "Collecting pbr!=2.1.0,>=2.0.0",
                                "  Downloading pbr-7.0.3-py2.py3-none-any.whl (131 kB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 131.9/131.9 kB 18.1 MB/s eta 0:00:00",
                                "Collecting platformdirs>=3",
                                "  Downloading platformdirs-4.10.0-py3-none-any.whl (22 kB)",
                                "Collecting psutil>=3.2.2",
                                "  Downloading psutil-7.2.2-cp36-abi3-manylinux2010_x86_64.manylinux_2_12_x86_64.manylinux_2_28_x86_64.whl (155 kB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 155.6/155.6 kB 22.0 MB/s eta 0:00:00",
                                "Collecting PyYAML>=3.13",
                                "  Downloading pyyaml-6.0.3-cp311-cp311-manylinux2014_x86_64.manylinux_2_17_x86_64.manylinux_2_28_x86_64.whl (806 kB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 806.6/806.6 kB 21.5 MB/s eta 0:00:00",
                                "Collecting bcrypt>=3.2",
                                "  Downloading bcrypt-5.0.0-cp39-abi3-manylinux_2_34_x86_64.whl (278 kB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 278.2/278.2 kB 25.4 MB/s eta 0:00:00",
                                "Collecting invoke>=2.0",
                                "  Downloading invoke-3.0.3-py3-none-any.whl (160 kB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 161.0/161.0 kB 23.7 MB/s eta 0:00:00",
                                "Collecting pynacl>=1.5",
                                "  Downloading pynacl-1.6.2-cp38-abi3-manylinux_2_34_x86_64.whl (1.4 MB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 1.4/1.4 MB 26.7 MB/s eta 0:00:00",
                                "Collecting charset_normalizer<4,>=2",
                                "  Downloading charset_normalizer-3.4.7-cp311-cp311-manylinux2014_x86_64.manylinux_2_17_x86_64.manylinux_2_28_x86_64.whl (214 kB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 214.1/214.1 kB 25.1 MB/s eta 0:00:00",
                                "Collecting idna<4,>=2.5",
                                "  Downloading idna-3.18-py3-none-any.whl (65 kB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 65.5/65.5 kB 8.2 MB/s eta 0:00:00",
                                "Collecting shellingham>=1.3.0",
                                "  Downloading shellingham-1.5.4-py2.py3-none-any.whl (9.8 kB)",
                                "Collecting rich>=13.8.0",
                                "  Downloading rich-15.0.0-py3-none-any.whl (310 kB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 310.7/310.7 kB 26.1 MB/s eta 0:00:00",
                                "Collecting annotated-doc>=0.0.2",
                                "  Downloading annotated_doc-0.0.4-py3-none-any.whl (5.3 kB)",
                                "Collecting cffi>=2.0.0",
                                "  Downloading cffi-2.0.0-cp311-cp311-manylinux2014_x86_64.manylinux_2_17_x86_64.whl (215 kB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 215.6/215.6 kB 24.9 MB/s eta 0:00:00",
                                "Collecting stevedore>=3.0.0",
                                "  Downloading stevedore-5.8.0-py3-none-any.whl (54 kB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 54.6/54.6 kB 5.2 MB/s eta 0:00:00",
                                "Collecting jsonpointer>=1.9",
                                "  Downloading jsonpointer-3.1.1-py3-none-any.whl (7.7 kB)",
                                "Collecting markdown-it-py>=2.2.0",
                                "  Downloading markdown_it_py-4.2.0-py3-none-any.whl (91 kB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 91.7/91.7 kB 15.9 MB/s eta 0:00:00",
                                "Collecting pygments<3.0.0,>=2.13.0",
                                "  Downloading pygments-2.20.0-py3-none-any.whl (1.2 MB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 1.2/1.2 MB 25.1 MB/s eta 0:00:00",
                                "Collecting argon2-cffi-bindings",
                                "  Downloading argon2_cffi_bindings-25.1.0-cp39-abi3-manylinux_2_26_x86_64.manylinux_2_28_x86_64.whl (87 kB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 87.1/87.1 kB 14.8 MB/s eta 0:00:00",
                                "Collecting pycparser",
                                "  Downloading pycparser-3.0-py3-none-any.whl (48 kB)",
                                "     \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501 48.2/48.2 kB 8.1 MB/s eta 0:00:00",
                                "Collecting mdurl~=0.1",
                                "  Downloading mdurl-0.1.2-py3-none-any.whl (10.0 kB)",
                                "Installing collected packages: urllib3, tabulate, stevedore, shellingham, setuptools, ruamel.yaml, PyYAML, pygments, pycryptodome, pycparser, psutil, platformdirs, patool, natsort, munch, mdurl, loguru, jsonpointer, jmespath, iso8601, invoke, idna, decorator, charset_normalizer, certifi, bcrypt, annotated-doc, yamale, requests, pbr, markdown-it-py, jsonpatch, dogpile.cache, cffi, rich, pynacl, os-service-types, cryptography, argon2-cffi-bindings, typer, paramiko, keystoneauth1, argon2-cffi, openstacksdk, minio",
                                "  Attempting uninstall: setuptools",
                                "    Found existing installation: setuptools 66.1.1",
                                "    Uninstalling setuptools-66.1.1:",
                                "      Successfully uninstalled setuptools-66.1.1",
                                "Successfully installed PyYAML-6.0.3 annotated-doc-0.0.4 argon2-cffi-25.1.0 argon2-cffi-bindings-25.1.0 bcrypt-5.0.0 certifi-2026.6.17 cffi-2.0.0 charset_normalizer-3.4.7 cryptography-49.0.0 decorator-5.3.1 dogpile.cache-1.5.0 idna-3.18 invoke-3.0.3 iso8601-2.1.0 jmespath-1.1.0 jsonpatch-1.33 jsonpointer-3.1.1 keystoneauth1-5.14.0 loguru-0.7.3 markdown-it-py-4.2.0 mdurl-0.1.2 minio-7.2.20 munch-4.0.0 natsort-8.4.0 openstacksdk-4.15.0 os-service-types-1.8.2 paramiko-5.0.0 patool-4.0.5 pbr-7.0.3 platformdirs-4.10.0 psutil-7.2.2 pycparser-3.0 pycryptodome-3.23.0 pygments-2.20.0 pynacl-1.6.2 requests-2.34.2 rich-15.0.0 ruamel.yaml-0.19.1 setuptools-82.0.1 shellingham-1.5.4 stevedore-5.8.0 tabulate-0.10.0 typer-0.26.6 urllib3-2.7.0 yamale-6.1.0"
                            ],
                            "version": null,
                            "virtualenv": "/tmp/venv"
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-d2c4-a06b-000000000005",
                        "name": "mypy",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/untrusted/project_0/github.com/osism/zuul-jobs/roles/mypy"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:55:13.516785Z",
                            "start": "2026-06-19T16:54:56.800365Z"
                        },
                        "id": "0242ac1f-6606-d2c4-a06b-000000000009",
                        "name": "Install repo requirements"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "ansible.builtin.command",
                            "changed": false,
                            "cmd": [
                                "/tmp/venv/bin/python3",
                                "-m",
                                "mypy",
                                "--ignore-missing-imports",
                                "--install-types",
                                "--non-interactive",
                                "."
                            ],
                            "delta": "0:00:11.367745",
                            "end": "2026-06-19 16:55:25.184433",
                            "failed": true,
                            "invocation": {
                                "module_args": {
                                    "_raw_params": "/tmp/venv/bin/python3 -m mypy --ignore-missing-imports --install-types --non-interactive .",
                                    "_uses_shell": false,
                                    "argv": null,
                                    "chdir": "src/github.com/osism/openstack-image-manager",
                                    "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": "0242ac1f-6606-d2c4-a06b-00000000000a-1-debianbookworm",
                                    "zuul_output_max_bytes": 1073741824
                                }
                            },
                            "msg": "non-zero return code",
                            "rc": 1,
                            "start": "2026-06-19 16:55:13.816688",
                            "stderr": "",
                            "stderr_lines": [],
                            "stdout": "Collecting types-PyYAML\n  Downloading types_pyyaml-6.0.12.20260518-py3-none-any.whl (20 kB)\nCollecting types-simplejson\n  Downloading types_simplejson-3.20.0.20260518-py3-none-any.whl (10 kB)\nCollecting types-tabulate\n  Downloading types_tabulate-0.10.0.20260508-py3-none-any.whl (8.1 kB)\nInstalling collected packages: types-tabulate, types-simplejson, types-PyYAML\nSuccessfully installed types-PyYAML-6.0.12.20260518 types-simplejson-3.20.0.20260518 types-tabulate-0.10.0.20260508\nopenstack_image_manager/main.py:480: error: Item \"openstack.image.v1.image.Image\" of \"openstack.image.v1.image.Image | openstack.image.v2.image.Image\" has no attribute \"data\"  [union-attr]\nopenstack_image_manager/main.py:483: error: Argument 1 to \"delete_image\" of \"Proxy\" has incompatible type \"openstack.image.v1.image.Image | openstack.image.v2.image.Image\"; expected \"str | openstack.image.v1.image.Image\"  [arg-type]\nopenstack_image_manager/main.py:483: error: Argument 1 to \"delete_image\" of \"Proxy\" has incompatible type \"openstack.image.v1.image.Image | openstack.image.v2.image.Image\"; expected \"str | openstack.image.v2.image.Image\"  [arg-type]\nopenstack_image_manager/main.py:487: error: Argument 1 to \"wait_for_image\" of \"ImageManager\" has incompatible type \"openstack.image.v1.image.Image | openstack.image.v2.image.Image\"; expected \"openstack.image.v2.image.Image\"  [arg-type]\nopenstack_image_manager/main.py:498: error: Item \"openstack.image.v1._proxy.Proxy\" of \"openstack.image.v1._proxy.Proxy | openstack.image.v2._proxy.Proxy\" has no attribute \"import_image\"  [union-attr]\nopenstack_image_manager/main.py:498: error: Argument 1 to \"import_image\" of \"Proxy\" has incompatible type \"openstack.image.v1.image.Image | openstack.image.v2.image.Image\"; expected \"str | openstack.image.v2.image.Image\"  [arg-type]\nopenstack_image_manager/main.py:500: error: Argument 1 to \"wait_for_image\" of \"ImageManager\" has incompatible type \"openstack.image.v1.image.Image | openstack.image.v2.image.Image\"; expected \"openstack.image.v2.image.Image\"  [arg-type]\nopenstack_image_manager/main.py:508: error: Argument 1 to \"delete_image\" of \"Proxy\" has incompatible type \"openstack.image.v1.image.Image | openstack.image.v2.image.Image\"; expected \"str | openstack.image.v1.image.Image\"  [arg-type]\nopenstack_image_manager/main.py:508: error: Argument 1 to \"delete_image\" of \"Proxy\" has incompatible type \"openstack.image.v1.image.Image | openstack.image.v2.image.Image\"; expected \"str | openstack.image.v2.image.Image\"  [arg-type]\nopenstack_image_manager/main.py:563: error: Argument 1 to \"get_image\" of \"Proxy\" has incompatible type \"openstack.image.v2.image.Image\"; expected \"str | openstack.image.v1.image.Image\"  [arg-type]\nopenstack_image_manager/main.py:583: error: Incompatible return value type (got \"openstack.image.v1.image.Image | openstack.image.v2.image.Image\", expected \"openstack.image.v2.image.Image | None\")  [return-value]\nopenstack_image_manager/main.py:874: error: Item \"openstack.image.v1._proxy.Proxy\" of \"openstack.image.v1._proxy.Proxy | openstack.image.v2._proxy.Proxy\" has no attribute \"add_tag\"  [union-attr]\nopenstack_image_manager/main.py:879: error: Item \"openstack.image.v1._proxy.Proxy\" of \"openstack.image.v1._proxy.Proxy | openstack.image.v2._proxy.Proxy\" has no attribute \"remove_tag\"  [union-attr]\nopenstack_image_manager/main.py:919: error: Item \"openstack.image.v1._proxy.Proxy\" of \"openstack.image.v1._proxy.Proxy | openstack.image.v2._proxy.Proxy\" has no attribute \"deactivate_image\"  [union-attr]\nopenstack_image_manager/main.py:923: error: Item \"openstack.image.v1._proxy.Proxy\" of \"openstack.image.v1._proxy.Proxy | openstack.image.v2._proxy.Proxy\" has no attribute \"reactivate_image\"  [union-attr]\nopenstack_image_manager/main.py:1147: error: Item \"openstack.image.v1._proxy.Proxy\" of \"openstack.image.v1._proxy.Proxy | openstack.image.v2._proxy.Proxy\" has no attribute \"deactivate_image\"  [union-attr]\nopenstack_image_manager/main.py:1176: error: Item \"openstack.image.v1._proxy.Proxy\" of \"openstack.image.v1._proxy.Proxy | openstack.image.v2._proxy.Proxy\" has no attribute \"deactivate_image\"  [union-attr]\nInstalling missing stub packages:\n/tmp/venv/bin/python3 -m pip install types-PyYAML types-simplejson types-tabulate\n\n\nFound 17 errors in 1 file (checked 12 source files)",
                            "stdout_lines": [
                                "Collecting types-PyYAML",
                                "  Downloading types_pyyaml-6.0.12.20260518-py3-none-any.whl (20 kB)",
                                "Collecting types-simplejson",
                                "  Downloading types_simplejson-3.20.0.20260518-py3-none-any.whl (10 kB)",
                                "Collecting types-tabulate",
                                "  Downloading types_tabulate-0.10.0.20260508-py3-none-any.whl (8.1 kB)",
                                "Installing collected packages: types-tabulate, types-simplejson, types-PyYAML",
                                "Successfully installed types-PyYAML-6.0.12.20260518 types-simplejson-3.20.0.20260518 types-tabulate-0.10.0.20260508",
                                "openstack_image_manager/main.py:480: error: Item \"openstack.image.v1.image.Image\" of \"openstack.image.v1.image.Image | openstack.image.v2.image.Image\" has no attribute \"data\"  [union-attr]",
                                "openstack_image_manager/main.py:483: error: Argument 1 to \"delete_image\" of \"Proxy\" has incompatible type \"openstack.image.v1.image.Image | openstack.image.v2.image.Image\"; expected \"str | openstack.image.v1.image.Image\"  [arg-type]",
                                "openstack_image_manager/main.py:483: error: Argument 1 to \"delete_image\" of \"Proxy\" has incompatible type \"openstack.image.v1.image.Image | openstack.image.v2.image.Image\"; expected \"str | openstack.image.v2.image.Image\"  [arg-type]",
                                "openstack_image_manager/main.py:487: error: Argument 1 to \"wait_for_image\" of \"ImageManager\" has incompatible type \"openstack.image.v1.image.Image | openstack.image.v2.image.Image\"; expected \"openstack.image.v2.image.Image\"  [arg-type]",
                                "openstack_image_manager/main.py:498: error: Item \"openstack.image.v1._proxy.Proxy\" of \"openstack.image.v1._proxy.Proxy | openstack.image.v2._proxy.Proxy\" has no attribute \"import_image\"  [union-attr]",
                                "openstack_image_manager/main.py:498: error: Argument 1 to \"import_image\" of \"Proxy\" has incompatible type \"openstack.image.v1.image.Image | openstack.image.v2.image.Image\"; expected \"str | openstack.image.v2.image.Image\"  [arg-type]",
                                "openstack_image_manager/main.py:500: error: Argument 1 to \"wait_for_image\" of \"ImageManager\" has incompatible type \"openstack.image.v1.image.Image | openstack.image.v2.image.Image\"; expected \"openstack.image.v2.image.Image\"  [arg-type]",
                                "openstack_image_manager/main.py:508: error: Argument 1 to \"delete_image\" of \"Proxy\" has incompatible type \"openstack.image.v1.image.Image | openstack.image.v2.image.Image\"; expected \"str | openstack.image.v1.image.Image\"  [arg-type]",
                                "openstack_image_manager/main.py:508: error: Argument 1 to \"delete_image\" of \"Proxy\" has incompatible type \"openstack.image.v1.image.Image | openstack.image.v2.image.Image\"; expected \"str | openstack.image.v2.image.Image\"  [arg-type]",
                                "openstack_image_manager/main.py:563: error: Argument 1 to \"get_image\" of \"Proxy\" has incompatible type \"openstack.image.v2.image.Image\"; expected \"str | openstack.image.v1.image.Image\"  [arg-type]",
                                "openstack_image_manager/main.py:583: error: Incompatible return value type (got \"openstack.image.v1.image.Image | openstack.image.v2.image.Image\", expected \"openstack.image.v2.image.Image | None\")  [return-value]",
                                "openstack_image_manager/main.py:874: error: Item \"openstack.image.v1._proxy.Proxy\" of \"openstack.image.v1._proxy.Proxy | openstack.image.v2._proxy.Proxy\" has no attribute \"add_tag\"  [union-attr]",
                                "openstack_image_manager/main.py:879: error: Item \"openstack.image.v1._proxy.Proxy\" of \"openstack.image.v1._proxy.Proxy | openstack.image.v2._proxy.Proxy\" has no attribute \"remove_tag\"  [union-attr]",
                                "openstack_image_manager/main.py:919: error: Item \"openstack.image.v1._proxy.Proxy\" of \"openstack.image.v1._proxy.Proxy | openstack.image.v2._proxy.Proxy\" has no attribute \"deactivate_image\"  [union-attr]",
                                "openstack_image_manager/main.py:923: error: Item \"openstack.image.v1._proxy.Proxy\" of \"openstack.image.v1._proxy.Proxy | openstack.image.v2._proxy.Proxy\" has no attribute \"reactivate_image\"  [union-attr]",
                                "openstack_image_manager/main.py:1147: error: Item \"openstack.image.v1._proxy.Proxy\" of \"openstack.image.v1._proxy.Proxy | openstack.image.v2._proxy.Proxy\" has no attribute \"deactivate_image\"  [union-attr]",
                                "openstack_image_manager/main.py:1176: error: Item \"openstack.image.v1._proxy.Proxy\" of \"openstack.image.v1._proxy.Proxy | openstack.image.v2._proxy.Proxy\" has no attribute \"deactivate_image\"  [union-attr]",
                                "Installing missing stub packages:",
                                "/tmp/venv/bin/python3 -m pip install types-PyYAML types-simplejson types-tabulate",
                                "",
                                "",
                                "Found 17 errors in 1 file (checked 12 source files)"
                            ],
                            "zuul_log_id": "0242ac1f-6606-d2c4-a06b-00000000000a-1-debianbookworm"
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-d2c4-a06b-000000000005",
                        "name": "mypy",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/untrusted/project_0/github.com/osism/zuul-jobs/roles/mypy"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:55:25.588171Z",
                            "start": "2026-06-19T16:55:13.563344Z"
                        },
                        "id": "0242ac1f-6606-d2c4-a06b-00000000000a",
                        "name": "Run mypy"
                    }
                }
            ]
        }
    ],
    "stats": {
        "debian-bookworm": {
            "changed": 7,
            "failures": 1,
            "ignored": 0,
            "ok": 10,
            "rescued": 0,
            "skipped": 12,
            "unreachable": 0
        }
    },
    "trusted": false
},
{
    "branch": "main",
    "index": "0",
    "phase": "post",
    "playbook": "github.com/osism/zuul-config/playbooks/base/post-fetch.yaml",
    "plays": [
        {
            "play": {
                "duration": {
                    "end": "2026-06-19T16:56:10.744218Z",
                    "start": "2026-06-19T16:55:26.600741Z"
                },
                "id": "0242ac1f-6606-de8c-aa52-000000000002",
                "name": "Base post-fetch"
            },
            "tasks": [
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "ansible.builtin.file",
                            "changed": false,
                            "diff": {
                                "after": {
                                    "path": "/home/zuul/zuul-output/logs"
                                },
                                "before": {
                                    "path": "/home/zuul/zuul-output/logs"
                                }
                            },
                            "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": "0755",
                                    "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
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-de8c-aa52-000000000007",
                        "name": "diagnose-network",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_0/github.com/osism/zuul-config/roles/diagnose-network"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:55:27.040278Z",
                            "start": "2026-06-19T16:55:26.618526Z"
                        },
                        "id": "0242ac1f-6606-de8c-aa52-000000000009",
                        "name": "Ensure log directory exists"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "ansible.builtin.shell",
                            "ansible_job_id": "j252149587668.1639",
                            "changed": false,
                            "cmd": "set +e\nset -o pipefail\nphase=post\nout=/home/zuul/zuul-output/logs/net-debug.$phase.txt\ntargets=\"tarballs.opendev.org galaxy.ansible.com\"\niface=$(ip -6 route show default 2>/dev/null        | awk '{for(i=1;i<=NF;i++) if($i==\"dev\"){print $(i+1); exit}}')\n: \"${iface:=eth0}\"\ngw=$(ip -6 route show default 2>/dev/null     | awk '{for(i=1;i<=NF;i++) if($i==\"via\"){print $(i+1); exit}}')\n{\n  echo \"== date ==\";    date -Is\n  echo \"== iface / gw ==\"; echo \"iface=$iface gw=$gw\"\n  echo \"== ip -6 addr (lifetimes = SLAAC evidence) ==\"; ip -6 addr show\n  echo \"== ip -6 route show ==\"; ip -6 route show\n  echo \"== ip -6 route show default (expires/proto ra = RA evidence) ==\"\n  ip -6 route show default\n  echo \"== ip -4 route show default ==\"; ip -4 route show default\n  echo \"== accept_ra / forwarding (procfs; RA-suppression evidence) ==\"\n  for k in all default \"$iface\"; do\n    for s in forwarding accept_ra; do\n      v=$(cat \"/proc/sys/net/ipv6/conf/$k/$s\" 2>/dev/null)\n      echo \"net.ipv6.conf.$k.$s = ${v:-<unavailable>}\"\n    done\n  done\n  echo \"== resolvectl status ==\"\n  if command -v resolvectl >/dev/null 2>&1; then resolvectl status 2>&1\n  else echo \"resolvectl not installed\"; fi\n  echo \"== /etc/resolv.conf (resolver stub) ==\"\n  cat /etc/resolv.conf 2>/dev/null || echo \"(absent)\"\n  echo \"== /run/systemd/resolve/resolv.conf (upstreams) ==\"\n  cat /run/systemd/resolve/resolv.conf 2>/dev/null    || echo \"(no systemd-resolved upstream file)\"\n  for d in $targets; do\n    echo \"== target: $d ==\"\n    echo \"-- getent ahosts (families glibc returns) --\"\n    getent ahosts \"$d\" 2>&1\n    if command -v resolvectl >/dev/null 2>&1; then\n      echo \"-- resolvectl query --\"; resolvectl query --cache=no \"$d\" 2>&1\n    fi\n    v6=$(getent ahosts \"$d\" 2>/dev/null | awk '$1~/:/{print $1; exit}')\n    v4=$(getent ahosts \"$d\" 2>/dev/null         | awk '$1~/^[0-9]+(\\.[0-9]+){3}$/{print $1; exit}')\n    if [ -n \"$v6\" ]; then\n      echo \"-- ip -6 route get $v6 --\"; ip -6 route get \"$v6\" 2>&1\n    fi\n    if [ -n \"$v4\" ]; then\n      echo \"-- ip -4 route get $v4 --\"; ip -4 route get \"$v4\" 2>&1\n    fi\n    # Several attempts per family: a single sample misclassifies a\n    # ~50%-loss path as healthy or dead by coin flip, defeating the\n    # pre/post bracket. Bounded and in-line -- not a background sampler.\n    for fam in 6 4; do\n      echo \"-- curl -$fam (3 attempts) --\"\n      ok=0\n      for n in 1 2 3; do\n        curl -$fam -sS -m 10 -o /dev/null          -w \"  #$n http=%{http_code} ip=%{remote_ip} t=%{time_total}s\\n\"          \"https://$d/\" 2>&1 && ok=1 || echo \"  #$n curl -$fam FAILED\"\n      done\n      # Trace only the family that failed, to its resolved address:\n      # localises WHERE the failing path dies instead of tracing the\n      # healthy family. v4 via traceroute, v6 via traceroute6.\n      if [ \"$ok\" = 0 ]; then\n        addr=$v6; [ \"$fam\" = 4 ] && addr=$v4\n        tr=traceroute6; [ \"$fam\" = 4 ] && tr=traceroute\n        if [ -n \"$addr\" ] && command -v \"$tr\" >/dev/null 2>&1; then\n          echo \"  !! curl -$fam failed 3x; $tr to $addr\"\n          timeout 30 \"$tr\" -q1 -w2 \"$addr\" 2>&1\n        fi\n      fi\n    done\n  done\n  echo \"== ping -6 gateway ==\"\n  if [ -n \"$gw\" ]; then\n    ping -6 -c1 -W2 \"${gw}%${iface}\" 2>&1\n  else echo \"no v6 gw\"; fi\n} > \"$out\" 2>&1\n",
                            "delta": "0:00:25.144500",
                            "end": "2026-06-19 16:55:53.213647",
                            "failed_when_result": false,
                            "finished": 1,
                            "invocation": {
                                "module_args": {
                                    "_raw_params": "set +e\nset -o pipefail\nphase=post\nout=/home/zuul/zuul-output/logs/net-debug.$phase.txt\ntargets=\"tarballs.opendev.org galaxy.ansible.com\"\niface=$(ip -6 route show default 2>/dev/null        | awk '{for(i=1;i<=NF;i++) if($i==\"dev\"){print $(i+1); exit}}')\n: \"${iface:=eth0}\"\ngw=$(ip -6 route show default 2>/dev/null     | awk '{for(i=1;i<=NF;i++) if($i==\"via\"){print $(i+1); exit}}')\n{\n  echo \"== date ==\";    date -Is\n  echo \"== iface / gw ==\"; echo \"iface=$iface gw=$gw\"\n  echo \"== ip -6 addr (lifetimes = SLAAC evidence) ==\"; ip -6 addr show\n  echo \"== ip -6 route show ==\"; ip -6 route show\n  echo \"== ip -6 route show default (expires/proto ra = RA evidence) ==\"\n  ip -6 route show default\n  echo \"== ip -4 route show default ==\"; ip -4 route show default\n  echo \"== accept_ra / forwarding (procfs; RA-suppression evidence) ==\"\n  for k in all default \"$iface\"; do\n    for s in forwarding accept_ra; do\n      v=$(cat \"/proc/sys/net/ipv6/conf/$k/$s\" 2>/dev/null)\n      echo \"net.ipv6.conf.$k.$s = ${v:-<unavailable>}\"\n    done\n  done\n  echo \"== resolvectl status ==\"\n  if command -v resolvectl >/dev/null 2>&1; then resolvectl status 2>&1\n  else echo \"resolvectl not installed\"; fi\n  echo \"== /etc/resolv.conf (resolver stub) ==\"\n  cat /etc/resolv.conf 2>/dev/null || echo \"(absent)\"\n  echo \"== /run/systemd/resolve/resolv.conf (upstreams) ==\"\n  cat /run/systemd/resolve/resolv.conf 2>/dev/null    || echo \"(no systemd-resolved upstream file)\"\n  for d in $targets; do\n    echo \"== target: $d ==\"\n    echo \"-- getent ahosts (families glibc returns) --\"\n    getent ahosts \"$d\" 2>&1\n    if command -v resolvectl >/dev/null 2>&1; then\n      echo \"-- resolvectl query --\"; resolvectl query --cache=no \"$d\" 2>&1\n    fi\n    v6=$(getent ahosts \"$d\" 2>/dev/null | awk '$1~/:/{print $1; exit}')\n    v4=$(getent ahosts \"$d\" 2>/dev/null         | awk '$1~/^[0-9]+(\\.[0-9]+){3}$/{print $1; exit}')\n    if [ -n \"$v6\" ]; then\n      echo \"-- ip -6 route get $v6 --\"; ip -6 route get \"$v6\" 2>&1\n    fi\n    if [ -n \"$v4\" ]; then\n      echo \"-- ip -4 route get $v4 --\"; ip -4 route get \"$v4\" 2>&1\n    fi\n    # Several attempts per family: a single sample misclassifies a\n    # ~50%-loss path as healthy or dead by coin flip, defeating the\n    # pre/post bracket. Bounded and in-line -- not a background sampler.\n    for fam in 6 4; do\n      echo \"-- curl -$fam (3 attempts) --\"\n      ok=0\n      for n in 1 2 3; do\n        curl -$fam -sS -m 10 -o /dev/null          -w \"  #$n http=%{http_code} ip=%{remote_ip} t=%{time_total}s\\n\"          \"https://$d/\" 2>&1 && ok=1 || echo \"  #$n curl -$fam FAILED\"\n      done\n      # Trace only the family that failed, to its resolved address:\n      # localises WHERE the failing path dies instead of tracing the\n      # healthy family. v4 via traceroute, v6 via traceroute6.\n      if [ \"$ok\" = 0 ]; then\n        addr=$v6; [ \"$fam\" = 4 ] && addr=$v4\n        tr=traceroute6; [ \"$fam\" = 4 ] && tr=traceroute\n        if [ -n \"$addr\" ] && command -v \"$tr\" >/dev/null 2>&1; then\n          echo \"  !! curl -$fam failed 3x; $tr to $addr\"\n          timeout 30 \"$tr\" -q1 -w2 \"$addr\" 2>&1\n        fi\n      fi\n    done\n  done\n  echo \"== ping -6 gateway ==\"\n  if [ -n \"$gw\" ]; then\n    ping -6 -c1 -W2 \"${gw}%${iface}\" 2>&1\n  else echo \"no v6 gw\"; fi\n} > \"$out\" 2>&1\n",
                                    "_uses_shell": true,
                                    "argv": null,
                                    "chdir": null,
                                    "creates": null,
                                    "executable": "/bin/bash",
                                    "expand_argument_vars": true,
                                    "removes": null,
                                    "stdin": null,
                                    "stdin_add_newline": true,
                                    "strip_empty_ends": true,
                                    "zuul_ansible_split_streams": false,
                                    "zuul_log_id": "0242ac1f-6606-de8c-aa52-00000000000a-0-debianbookworm",
                                    "zuul_output_max_bytes": 1073741824
                                }
                            },
                            "msg": "non-zero return code",
                            "rc": 1,
                            "results_file": "/home/zuul/.ansible_async/j252149587668.1639",
                            "start": "2026-06-19 16:55:28.069147",
                            "started": 1,
                            "stderr": "",
                            "stderr_lines": [],
                            "stdout": "",
                            "stdout_lines": [],
                            "zuul_log_id": "0242ac1f-6606-de8c-aa52-00000000000a-0-debianbookworm"
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-de8c-aa52-000000000007",
                        "name": "diagnose-network",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_0/github.com/osism/zuul-config/roles/diagnose-network"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:55:54.691686Z",
                            "start": "2026-06-19T16:55:27.048507Z"
                        },
                        "id": "0242ac1f-6606-de8c-aa52-00000000000a",
                        "name": "Snapshot dual-stack network state (post)"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "ansible.builtin.shell",
                            "ansible_job_id": "j947988301481.1760",
                            "changed": false,
                            "cmd": "set +e\nset -o pipefail\nphase=post\nout=/home/zuul/zuul-output/logs/net-debug.$phase.txt\n{\n  echo \"== docker / buildkit IPv6 config ==\"\n  if ! command -v docker >/dev/null 2>&1; then\n    echo \"docker not available; skipped\"\n  else\n    echo \"-- docker info (IPv6 lines) --\"\n    if info=$(timeout 30 docker info 2>&1); then\n      printf '%s\\n' \"$info\" | grep -iE 'ipv6|ip6tables'        || echo \"(no IPv6 lines)\"\n    else\n      echo \"docker info FAILED/timed out (daemon down or no permission):\"\n      printf '%s\\n' \"$info\" | head -5\n    fi\n    echo \"-- /etc/docker/daemon.json --\"\n    cat /etc/docker/daemon.json 2>/dev/null || echo \"(absent)\"\n    echo \"-- docker network inspect bridge (EnableIPv6 + IPAM) --\"\n    timeout 30 docker network inspect bridge 2>&1      | grep -iE '\"Name\"|EnableIPv6|Subnet|Gateway'      || echo \"(inspect failed)\"\n    echo \"-- docker buildx ls --\"\n    timeout 30 docker buildx ls 2>&1 || echo \"(buildx unavailable)\"\n  fi\n} >> \"$out\" 2>&1\n",
                            "delta": "0:00:00.009907",
                            "end": "2026-06-19 16:55:55.403372",
                            "failed_when_result": false,
                            "finished": 1,
                            "invocation": {
                                "module_args": {
                                    "_raw_params": "set +e\nset -o pipefail\nphase=post\nout=/home/zuul/zuul-output/logs/net-debug.$phase.txt\n{\n  echo \"== docker / buildkit IPv6 config ==\"\n  if ! command -v docker >/dev/null 2>&1; then\n    echo \"docker not available; skipped\"\n  else\n    echo \"-- docker info (IPv6 lines) --\"\n    if info=$(timeout 30 docker info 2>&1); then\n      printf '%s\\n' \"$info\" | grep -iE 'ipv6|ip6tables'        || echo \"(no IPv6 lines)\"\n    else\n      echo \"docker info FAILED/timed out (daemon down or no permission):\"\n      printf '%s\\n' \"$info\" | head -5\n    fi\n    echo \"-- /etc/docker/daemon.json --\"\n    cat /etc/docker/daemon.json 2>/dev/null || echo \"(absent)\"\n    echo \"-- docker network inspect bridge (EnableIPv6 + IPAM) --\"\n    timeout 30 docker network inspect bridge 2>&1      | grep -iE '\"Name\"|EnableIPv6|Subnet|Gateway'      || echo \"(inspect failed)\"\n    echo \"-- docker buildx ls --\"\n    timeout 30 docker buildx ls 2>&1 || echo \"(buildx unavailable)\"\n  fi\n} >> \"$out\" 2>&1\n",
                                    "_uses_shell": true,
                                    "argv": null,
                                    "chdir": null,
                                    "creates": null,
                                    "executable": "/bin/bash",
                                    "expand_argument_vars": true,
                                    "removes": null,
                                    "stdin": null,
                                    "stdin_add_newline": true,
                                    "strip_empty_ends": true,
                                    "zuul_ansible_split_streams": false,
                                    "zuul_log_id": "0242ac1f-6606-de8c-aa52-00000000000b-0-debianbookworm",
                                    "zuul_output_max_bytes": 1073741824
                                }
                            },
                            "msg": "",
                            "rc": 0,
                            "results_file": "/home/zuul/.ansible_async/j947988301481.1760",
                            "start": "2026-06-19 16:55:55.393465",
                            "started": 1,
                            "stderr": "",
                            "stderr_lines": [],
                            "stdout": "",
                            "stdout_lines": [],
                            "zuul_log_id": "0242ac1f-6606-de8c-aa52-00000000000b-0-debianbookworm"
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-de8c-aa52-000000000007",
                        "name": "diagnose-network",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_0/github.com/osism/zuul-config/roles/diagnose-network"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:56:00.770773Z",
                            "start": "2026-06-19T16:55:54.707726Z"
                        },
                        "id": "0242ac1f-6606-de8c-aa52-00000000000b",
                        "name": "Snapshot Docker/BuildKit IPv6 config (teardown)"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "ansible.builtin.shell",
                            "ansible_job_id": "j65830069543.1795",
                            "changed": false,
                            "cmd": "set +e\nset -o pipefail\nphase=post\nout=/home/zuul/zuul-output/logs/net-debug.$phase.txt\ntargets=\"tarballs.opendev.org galaxy.ansible.com\"\n{\n  echo \"== container netns exec probe (default bridge) ==\"\n  if ! command -v docker >/dev/null 2>&1; then\n    echo \"docker not available; skipped\"\n  else\n    # Prefer a full base image likely to carry ip/curl/getent,\n    # skipping dangling (<none>) tags; fall back to any local image\n    # ID (a valid run reference). Never pull. (docker image ls\n    # columns: REPOSITORY TAG IMAGE_ID ...)\n    img=$(timeout 30 docker image ls 2>/dev/null | awk      '$1~/^(ubuntu|debian)$/ && $2!=\"<none>\"{print $1\":\"$2; exit}')\n    if [ -z \"$img\" ]; then\n      img=$(timeout 30 docker image ls -q 2>/dev/null | head -1)\n    fi\n    if [ -z \"$img\" ]; then\n      echo \"no local image; skipped (will not pull over a broken network)\"\n    else\n      echo \"using local image $img\"\n      # Bound the whole probe: on the degraded node this role exists\n      # to diagnose, a wedged daemon can make `docker run` hang\n      # indefinitely and stall teardown. timeout keeps it best-effort.\n      # A killed client may orphan the container, but the node is torn\n      # down right after, so that is acceptable here.\n      timeout 60 docker run --rm \"$img\" sh -c '\n        echo \"tools: ip=$(command -v ip || echo no)\" \\\n             \"curl=$(command -v curl || echo no)\" \\\n             \"getent=$(command -v getent || echo no)\"\n        echo \"-- ip -6 addr / route --\"\n        (ip -6 addr show 2>/dev/null; ip -6 route show 2>/dev/null) \\\n          || cat /proc/net/ipv6_route 2>/dev/null || echo \"no ip tool\"\n        echo \"-- /etc/resolv.conf --\"; cat /etc/resolv.conf 2>/dev/null\n        for d in '\"$targets\"'; do\n          echo \"target $d:\"\n          getent ahosts \"$d\" 2>&1 | head -4 || echo \"  getent unavailable\"\n          (curl -6 -sS -m 8 -o /dev/null \\\n             -w \"  v6 %{http_code} %{remote_ip} t=%{time_total}\\n\" \\\n             \"https://$d/\" 2>&1 || echo \"  v6 FAIL/unavailable\")\n          (curl -4 -sS -m 8 -o /dev/null \\\n             -w \"  v4 %{http_code} %{remote_ip} t=%{time_total}\\n\" \\\n             \"https://$d/\" 2>&1 || echo \"  v4 FAIL/unavailable\")\n        done\n      ' 2>&1\n    fi\n  fi\n} >> \"$out\" 2>&1\n",
                            "delta": "0:00:00.009076",
                            "end": "2026-06-19 16:56:01.440516",
                            "failed_when_result": false,
                            "finished": 1,
                            "invocation": {
                                "module_args": {
                                    "_raw_params": "set +e\nset -o pipefail\nphase=post\nout=/home/zuul/zuul-output/logs/net-debug.$phase.txt\ntargets=\"tarballs.opendev.org galaxy.ansible.com\"\n{\n  echo \"== container netns exec probe (default bridge) ==\"\n  if ! command -v docker >/dev/null 2>&1; then\n    echo \"docker not available; skipped\"\n  else\n    # Prefer a full base image likely to carry ip/curl/getent,\n    # skipping dangling (<none>) tags; fall back to any local image\n    # ID (a valid run reference). Never pull. (docker image ls\n    # columns: REPOSITORY TAG IMAGE_ID ...)\n    img=$(timeout 30 docker image ls 2>/dev/null | awk      '$1~/^(ubuntu|debian)$/ && $2!=\"<none>\"{print $1\":\"$2; exit}')\n    if [ -z \"$img\" ]; then\n      img=$(timeout 30 docker image ls -q 2>/dev/null | head -1)\n    fi\n    if [ -z \"$img\" ]; then\n      echo \"no local image; skipped (will not pull over a broken network)\"\n    else\n      echo \"using local image $img\"\n      # Bound the whole probe: on the degraded node this role exists\n      # to diagnose, a wedged daemon can make `docker run` hang\n      # indefinitely and stall teardown. timeout keeps it best-effort.\n      # A killed client may orphan the container, but the node is torn\n      # down right after, so that is acceptable here.\n      timeout 60 docker run --rm \"$img\" sh -c '\n        echo \"tools: ip=$(command -v ip || echo no)\" \\\n             \"curl=$(command -v curl || echo no)\" \\\n             \"getent=$(command -v getent || echo no)\"\n        echo \"-- ip -6 addr / route --\"\n        (ip -6 addr show 2>/dev/null; ip -6 route show 2>/dev/null) \\\n          || cat /proc/net/ipv6_route 2>/dev/null || echo \"no ip tool\"\n        echo \"-- /etc/resolv.conf --\"; cat /etc/resolv.conf 2>/dev/null\n        for d in '\"$targets\"'; do\n          echo \"target $d:\"\n          getent ahosts \"$d\" 2>&1 | head -4 || echo \"  getent unavailable\"\n          (curl -6 -sS -m 8 -o /dev/null \\\n             -w \"  v6 %{http_code} %{remote_ip} t=%{time_total}\\n\" \\\n             \"https://$d/\" 2>&1 || echo \"  v6 FAIL/unavailable\")\n          (curl -4 -sS -m 8 -o /dev/null \\\n             -w \"  v4 %{http_code} %{remote_ip} t=%{time_total}\\n\" \\\n             \"https://$d/\" 2>&1 || echo \"  v4 FAIL/unavailable\")\n        done\n      ' 2>&1\n    fi\n  fi\n} >> \"$out\" 2>&1\n",
                                    "_uses_shell": true,
                                    "argv": null,
                                    "chdir": null,
                                    "creates": null,
                                    "executable": "/bin/bash",
                                    "expand_argument_vars": true,
                                    "removes": null,
                                    "stdin": null,
                                    "stdin_add_newline": true,
                                    "strip_empty_ends": true,
                                    "zuul_ansible_split_streams": false,
                                    "zuul_log_id": "0242ac1f-6606-de8c-aa52-00000000000c-0-debianbookworm",
                                    "zuul_output_max_bytes": 1073741824
                                }
                            },
                            "msg": "",
                            "rc": 0,
                            "results_file": "/home/zuul/.ansible_async/j65830069543.1795",
                            "start": "2026-06-19 16:56:01.431440",
                            "started": 1,
                            "stderr": "",
                            "stderr_lines": [],
                            "stdout": "",
                            "stdout_lines": [],
                            "zuul_log_id": "0242ac1f-6606-de8c-aa52-00000000000c-0-debianbookworm"
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-de8c-aa52-000000000007",
                        "name": "diagnose-network",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_0/github.com/osism/zuul-config/roles/diagnose-network"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:56:06.787868Z",
                            "start": "2026-06-19T16:56:00.779170Z"
                        },
                        "id": "0242ac1f-6606-de8c-aa52-00000000000c",
                        "name": "Probe container network namespace (teardown)"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "set_fact",
                            "changed": false,
                            "false_condition": "groups['all'] | length > 1",
                            "skip_reason": "Conditional result was False",
                            "skipped": true
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-de8c-aa52-00000000000e",
                        "name": "fetch-output",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_1/github.com/osism/openinfra-zuul-jobs/roles/fetch-output"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:56:06.855411Z",
                            "start": "2026-06-19T16:56:06.798971Z"
                        },
                        "id": "0242ac1f-6606-de8c-aa52-000000000010",
                        "name": "Set log path for multiple nodes"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "set_fact",
                            "ansible_facts": {
                                "log_path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/work/logs"
                            },
                            "changed": false
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-de8c-aa52-00000000000e",
                        "name": "fetch-output",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_1/github.com/osism/openinfra-zuul-jobs/roles/fetch-output"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:56:06.944004Z",
                            "start": "2026-06-19T16:56:06.874195Z"
                        },
                        "id": "0242ac1f-6606-de8c-aa52-000000000011",
                        "name": "Set log path for single node"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "file",
                            "changed": true,
                            "msg": "All items completed",
                            "results": [
                                {
                                    "ansible_loop_var": "zj_output_dir",
                                    "changed": false,
                                    "diff": {
                                        "after": {
                                            "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/work/logs"
                                        },
                                        "before": {
                                            "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/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/bd6142c67d41408594c85721f4b5574c/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/bd6142c67d41408594c85721f4b5574c/work/logs",
                                    "size": 4096,
                                    "state": "directory",
                                    "uid": 0,
                                    "zj_output_dir": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/work/logs"
                                },
                                {
                                    "ansible_loop_var": "zj_output_dir",
                                    "changed": true,
                                    "diff": {
                                        "after": {
                                            "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/work/artifacts",
                                            "state": "directory"
                                        },
                                        "before": {
                                            "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/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/bd6142c67d41408594c85721f4b5574c/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/bd6142c67d41408594c85721f4b5574c/work/artifacts",
                                    "size": 4096,
                                    "state": "directory",
                                    "uid": 0,
                                    "zj_output_dir": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/work/artifacts"
                                },
                                {
                                    "ansible_loop_var": "zj_output_dir",
                                    "changed": true,
                                    "diff": {
                                        "after": {
                                            "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/work/docs",
                                            "state": "directory"
                                        },
                                        "before": {
                                            "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/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/bd6142c67d41408594c85721f4b5574c/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/bd6142c67d41408594c85721f4b5574c/work/docs",
                                    "size": 4096,
                                    "state": "directory",
                                    "uid": 0,
                                    "zj_output_dir": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/work/docs"
                                }
                            ]
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-de8c-aa52-00000000000e",
                        "name": "fetch-output",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_1/github.com/osism/openinfra-zuul-jobs/roles/fetch-output"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:56:07.953613Z",
                            "start": "2026-06-19T16:56:06.949510Z"
                        },
                        "id": "0242ac1f-6606-de8c-aa52-000000000012",
                        "name": "Ensure local output dirs"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "synchronize",
                            "changed": true,
                            "msg": "All items completed",
                            "results": [
                                {
                                    "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@2a13:1a81:8000:3124:f816:3eff:fe6d:fdbc]:/home/zuul/zuul-output/logs/' /var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/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/bd6142c67d41408594c85721f4b5574c/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@2a13:1a81:8000:3124:f816:3eff:fe6d:fdbc]:/home/zuul/zuul-output/logs/",
                                            "ssh_connection_multiplexing": false,
                                            "times": null,
                                            "use_ssh_args": false,
                                            "verify_host": true
                                        }
                                    },
                                    "msg": ".d..t...... ./\n>f+++++++++ net-debug.post.txt\n>f+++++++++ net-debug.pre.txt\n>f+++++++++ sudo-debug.txt\n>f+++++++++ sudo-strace.log\n>f+++++++++ sudo-strace.log.time\n",
                                    "rc": 0,
                                    "stdout_lines": [
                                        ".d..t...... ./",
                                        ">f+++++++++ net-debug.post.txt",
                                        ">f+++++++++ net-debug.pre.txt",
                                        ">f+++++++++ sudo-debug.txt",
                                        ">f+++++++++ sudo-strace.log",
                                        ">f+++++++++ sudo-strace.log.time"
                                    ],
                                    "zj_output": {
                                        "dest": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/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@2a13:1a81:8000:3124:f816:3eff:fe6d:fdbc]:/home/zuul/zuul-output/artifacts/' /var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/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/bd6142c67d41408594c85721f4b5574c/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@2a13:1a81:8000:3124:f816:3eff:fe6d:fdbc]:/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/bd6142c67d41408594c85721f4b5574c/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@2a13:1a81:8000:3124:f816:3eff:fe6d:fdbc]:/home/zuul/zuul-output/docs/' /var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/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/bd6142c67d41408594c85721f4b5574c/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@2a13:1a81:8000:3124:f816:3eff:fe6d:fdbc]:/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/bd6142c67d41408594c85721f4b5574c/work/docs",
                                        "src": "docs"
                                    }
                                }
                            ]
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-de8c-aa52-00000000000e",
                        "name": "fetch-output",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_1/github.com/osism/openinfra-zuul-jobs/roles/fetch-output"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:56:10.046472Z",
                            "start": "2026-06-19T16:56:07.963459Z"
                        },
                        "id": "0242ac1f-6606-de8c-aa52-000000000014",
                        "name": "Collect logs, artifacts and docs"
                    }
                },
                {
                    "hosts": {
                        "debian-bookworm": {
                            "action": "shell",
                            "changed": true,
                            "msg": "All items completed",
                            "results": [
                                {
                                    "ansible_loop_var": "zj_item",
                                    "changed": true,
                                    "cmd": "if [ -n \"$(find /var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/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/bd6142c67d41408594c85721f4b5574c/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/bd6142c67d41408594c85721f4b5574c/work/artifacts/* /var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/work/logs/artifacts\nfi\n",
                                    "delta": "0:00:00.008837",
                                    "end": "2026-06-19 16:56:10.412985",
                                    "failed": false,
                                    "invocation": {
                                        "module_args": {
                                            "_raw_params": "if [ -n \"$(find /var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/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/bd6142c67d41408594c85721f4b5574c/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/bd6142c67d41408594c85721f4b5574c/work/artifacts/* /var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/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_output_max_bytes": 1073741824
                                        }
                                    },
                                    "msg": "",
                                    "rc": 0,
                                    "start": "2026-06-19 16:56:10.404148",
                                    "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/bd6142c67d41408594c85721f4b5574c/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/bd6142c67d41408594c85721f4b5574c/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/bd6142c67d41408594c85721f4b5574c/work/docs/* /var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/work/logs/docs\nfi\n",
                                    "delta": "0:00:00.016330",
                                    "end": "2026-06-19 16:56:10.698200",
                                    "failed": false,
                                    "invocation": {
                                        "module_args": {
                                            "_raw_params": "if [ -n \"$(find /var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/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/bd6142c67d41408594c85721f4b5574c/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/bd6142c67d41408594c85721f4b5574c/work/docs/* /var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/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_output_max_bytes": 1073741824
                                        }
                                    },
                                    "msg": "",
                                    "rc": 0,
                                    "start": "2026-06-19 16:56:10.681870",
                                    "stderr": "",
                                    "stderr_lines": [],
                                    "stdout": "",
                                    "stdout_lines": [],
                                    "zj_item": "docs",
                                    "zuul_log_id": "in-loop-ignore"
                                }
                            ]
                        }
                    },
                    "role": {
                        "id": "0242ac1f-6606-de8c-aa52-000000000017",
                        "name": "merge-output-to-logs",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_1/github.com/osism/openinfra-zuul-jobs/roles/merge-output-to-logs"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:56:10.744218Z",
                            "start": "2026-06-19T16:56:10.057357Z"
                        },
                        "id": "0242ac1f-6606-de8c-aa52-000000000019",
                        "name": "Move artifacts and docs to logs dir"
                    }
                }
            ]
        }
    ],
    "stats": {
        "debian-bookworm": {
            "changed": 3,
            "failures": 0,
            "ignored": 0,
            "ok": 8,
            "rescued": 0,
            "skipped": 1,
            "unreachable": 0
        }
    },
    "trusted": true
},
{
    "branch": "main",
    "index": "1",
    "phase": "post",
    "playbook": "github.com/osism/zuul-config/playbooks/base/post.yaml",
    "plays": [
        {
            "play": {
                "duration": {
                    "end": "2026-06-19T16:56:12.472901Z",
                    "start": "2026-06-19T16:56:11.839692Z"
                },
                "id": "0242ac1f-6606-b9b9-27f7-000000000002",
                "name": "Base post"
            },
            "tasks": [
                {
                    "hosts": {
                        "debian-bookworm": {
                            "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 AAAAB3NzaC1yc2EAAAADAQABAAABgQCtnTD9QpX8KVUgeb6xiupD+OwC3aLjzyqY+t7XsjmVIihuBVrL/kr1mQN6TUca3CmxEtNtOUfG0M2XXiswV3oZ8zCVR5sP9dCYaEm3VsOKZshK6IRLfa+rKURsfCDAm1M2wbpByLaJ+qW/dc6iGmoqKeUFAcTtcTNUilcF+QDLPn65yD/t140NutYHiNWx/pLoSyIpXZF0h78SA/rvEUg28Xqo8kvWlnVqsGm8NUgZOinPwPLRl7qG8Y+H1ea57c4KMCu9KWuQ/DXJwuyNZbCvN2ofyrgmfB2+KXWeZVkaL1Epfy+hUv0ZoLpKSFHPRh7ghQ2pyvZ5/dqBeaRdQgiE6WFiC3tFPFqzwKx0ye+h+jCDCUG+g8QXj1p42J+89aAd3HL17DMrU0VI0p8XSCgmuUAELJGoyJTlme0Tdw+m+L4h7cFR/E43gJBk+sICfVoMtksg6S35/cwJApiFCMOnNQqZ7yzqNAdACePq17buNTudIbo8jBibacLm9MQyEHM= 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 AAAAB3NzaC1yc2EAAAADAQABAAABgQCtnTD9QpX8KVUgeb6xiupD+OwC3aLjzyqY+t7XsjmVIihuBVrL/kr1mQN6TUca3CmxEtNtOUfG0M2XXiswV3oZ8zCVR5sP9dCYaEm3VsOKZshK6IRLfa+rKURsfCDAm1M2wbpByLaJ+qW/dc6iGmoqKeUFAcTtcTNUilcF+QDLPn65yD/t140NutYHiNWx/pLoSyIpXZF0h78SA/rvEUg28Xqo8kvWlnVqsGm8NUgZOinPwPLRl7qG8Y+H1ea57c4KMCu9KWuQ/DXJwuyNZbCvN2ofyrgmfB2+KXWeZVkaL1Epfy+hUv0ZoLpKSFHPRh7ghQ2pyvZ5/dqBeaRdQgiE6WFiC3tFPFqzwKx0ye+h+jCDCUG+g8QXj1p42J+89aAd3HL17DMrU0VI0p8XSCgmuUAELJGoyJTlme0Tdw+m+L4h7cFR/E43gJBk+sICfVoMtksg6S35/cwJApiFCMOnNQqZ7yzqNAdACePq17buNTudIbo8jBibacLm9MQyEHM= 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": "0242ac1f-6606-b9b9-27f7-000000000005",
                        "name": "remove-build-sshkey",
                        "path": "/var/lib/zuul/builds/bd6142c67d41408594c85721f4b5574c/trusted/project_1/github.com/osism/openinfra-zuul-jobs/roles/remove-build-sshkey"
                    },
                    "task": {
                        "duration": {
                            "end": "2026-06-19T16:56:12.472901Z",
                            "start": "2026-06-19T16:56:11.854998Z"
                        },
                        "id": "0242ac1f-6606-b9b9-27f7-000000000007",
                        "name": "Remove the build SSH key from all nodes"
                    }
                }
            ]
        }
    ],
    "stats": {
        "debian-bookworm": {
            "changed": 1,
            "failures": 0,
            "ignored": 0,
            "ok": 1,
            "rescued": 0,
            "skipped": 0,
            "unreachable": 0
        }
    },
    "trusted": true
}
]
