all:
  children:
    cephs:
      hosts:
        instance: null
    computes:
      hosts:
        instance: null
    controllers:
      hosts:
        instance: null
    zuul_unreachable:
      hosts: {}
  hosts:
    instance:
      ansible_connection: ssh
      ansible_host: 199.204.45.19
      ansible_port: 22
      ansible_python_interpreter: auto
      ansible_user: zuul
      atmosphere_image_prefix: harbor.atmosphere.dev/
      ceph_conf_overrides:
      - option: mon allow pool size one
        section: global
        value: true
      - option: osd crush chooseleaf type
        section: global
        value: 0
      - option: auth allow insecure global id reclaim
        section: mon
        value: false
      ceph_csi_rbd_helm_values:
        provisioner:
          replicaCount: 1
      ceph_fsid: 4837cbf8-4f90-4300-b3f6-726c9b9f89b4
      ceph_osd_devices:
      - /dev/ceph-{{ inventory_hostname_short }}-osd0/data
      - /dev/ceph-{{ inventory_hostname_short }}-osd1/data
      - /dev/ceph-{{ inventory_hostname_short }}-osd2/data
      cilium_helm_values:
        operator:
          replicas: 1
      csi_driver: local-path-provisioner
      kube_vip_address: 172.17.0.100
      kube_vip_interface: '{{ ansible_facts[''default_ipv4''].interface }}'
      kubernetes_hostname: '{{ ansible_facts[''default_ipv4''].address }}'
      molecule_install_collection_siblings: true
      molecule_scenario: csi
      nodepool:
        az: nova
        cloud: public
        external_id: db2250ad-7eac-4bf0-961a-c639a0fdb81c
        host_id: b3056f425dc12eb7c2b177d04ce92ce8e9d8895ce2af8682a7cd0f26
        interface_ip: 199.204.45.19
        label: ubuntu-jammy
        node_properties: {}
        private_ipv4: 199.204.45.19
        private_ipv6: null
        provider: yul1
        public_ipv4: 199.204.45.19
        public_ipv6: 2604:e100:1:0:f816:3eff:fef6:bf87
        region: ca-ymq-1
        slot: null
      zuul_node:
        az: nova
        cloud: public
        external_id: db2250ad-7eac-4bf0-961a-c639a0fdb81c
        host_id: b3056f425dc12eb7c2b177d04ce92ce8e9d8895ce2af8682a7cd0f26
        interface_ip: 199.204.45.19
        label: ubuntu-jammy
        node_properties: {}
        private_ipv4: 199.204.45.19
        private_ipv6: null
        provider: yul1
        public_ipv4: 199.204.45.19
        public_ipv6: 2604:e100:1:0:f816:3eff:fef6:bf87
        region: ca-ymq-1
        slot: null
        uuid: null
  vars:
    atmosphere_image_prefix: harbor.atmosphere.dev/
    ceph_conf_overrides:
    - option: mon allow pool size one
      section: global
      value: true
    - option: osd crush chooseleaf type
      section: global
      value: 0
    - option: auth allow insecure global id reclaim
      section: mon
      value: false
    ceph_csi_rbd_helm_values:
      provisioner:
        replicaCount: 1
    ceph_fsid: 4837cbf8-4f90-4300-b3f6-726c9b9f89b4
    ceph_osd_devices:
    - /dev/ceph-{{ inventory_hostname_short }}-osd0/data
    - /dev/ceph-{{ inventory_hostname_short }}-osd1/data
    - /dev/ceph-{{ inventory_hostname_short }}-osd2/data
    cilium_helm_values:
      operator:
        replicas: 1
    csi_driver: local-path-provisioner
    kube_vip_address: 172.17.0.100
    kube_vip_interface: '{{ ansible_facts[''default_ipv4''].interface }}'
    kubernetes_hostname: '{{ ansible_facts[''default_ipv4''].address }}'
    molecule_install_collection_siblings: true
    molecule_scenario: csi
    zuul:
      _inheritance_path:
      - '<Job base explicit: None implied: {MatchAny:{ImpliedBranchMatcher:main}}
        source: vexxhost/zuul-config/zuul.d/jobs.yaml@main#1>'
      - '<Job molecule explicit: None implied: {MatchAny:{ImpliedBranchMatcher:main}}
        source: vexxhost/zuul-jobs/zuul.d/ansible-jobs.yaml@main#1>'
      - '<Job atmosphere-molecule explicit: None implied: {MatchAny:{ImpliedBranchMatcher:main}}
        source: vexxhost/atmosphere/.zuul.yaml@main#24>'
      - '<Job atmosphere-molecule-csi explicit: None implied: {MatchAny:{ImpliedBranchMatcher:main}}
        source: vexxhost/atmosphere/.zuul.yaml@main#73>'
      - '<Job atmosphere-molecule-csi-local-path-provisioner explicit: None implied:
        {MatchAny:{ImpliedBranchMatcher:main}} source: vexxhost/atmosphere/.zuul.yaml@main#80>'
      - '<Job atmosphere-molecule-csi-local-path-provisioner explicit: None implied:
        None source: vexxhost/atmosphere/.zuul.yaml@main#308>'
      ansible_version: '9'
      attempts: 1
      branch: main
      build: 4ecb2a65a4894e1880679bd40822362a
      build_refs:
      - branch: main
        change: '3862'
        change_message: "fix(glance_image): fix combine crash, make ETag optional,
          and upload before rename\n\nFixes a crash in the `glance_image` role where
          `combine()` received the Ansible omit placeholder string instead of a dict,
          and improves the role's safety and compatibility.\n\n## Changes Made\n\n-
          **`roles/glance/tasks/main.yml`**: Changed `glance_image_properties: default(omit)`
          to `default({})` so `combine()` always receives a dict, fixing the `failed
          to combine variables` crash.\n- **`roles/glance_image/tasks/main.yml`**:
          Reordered the upload sequence \u2014 the new image is uploaded first, and
          the old image is only renamed to `<name>-<short-etag>` and tagged `atmosphere:image:obsolete`
          after the upload succeeds. This ensures the service image name is never
          left without an active image if an upload fails.\n- **`roles/glance_image/tasks/main.yml`**:
          Made ETag optional. The role no longer fails when the source URL does not
          return an `ETag` header. When an ETag is present it is used for change detection
          and stored as `atmosphere:image:etag` on the uploaded image. When absent,
          the role falls back to URL-only change detection and omits the property.\n-
          **`roles/glance_image/README.md`**: Updated to document the optional-ETag
          fallback behaviour, the upload-before-rename sequence, and that the HEAD
          request runs on every run to check for changes.\n- **`roles/glance_image/tasks/main.yml`**:
          Renamed the obsolete image tag from `atmosphere:obsolete` to `atmosphere:image:obsolete`
          for consistent namespace."
        change_url: https://github.com/vexxhost/atmosphere/pull/3862
        commit_id: ab2b33ec9479b3aedbfb7604a47a5eae0f3f8ee4
        patchset: ab2b33ec9479b3aedbfb7604a47a5eae0f3f8ee4
        project:
          canonical_hostname: github.com
          canonical_name: github.com/vexxhost/atmosphere
          name: vexxhost/atmosphere
          short_name: atmosphere
          src_dir: src/github.com/vexxhost/atmosphere
        src_dir: src/github.com/vexxhost/atmosphere
        topic: null
      buildset: f4a62d8f74734f3280c0ce370e2eb8f7
      buildset_refs:
      - branch: main
        change: '3862'
        change_message: "fix(glance_image): fix combine crash, make ETag optional,
          and upload before rename\n\nFixes a crash in the `glance_image` role where
          `combine()` received the Ansible omit placeholder string instead of a dict,
          and improves the role's safety and compatibility.\n\n## Changes Made\n\n-
          **`roles/glance/tasks/main.yml`**: Changed `glance_image_properties: default(omit)`
          to `default({})` so `combine()` always receives a dict, fixing the `failed
          to combine variables` crash.\n- **`roles/glance_image/tasks/main.yml`**:
          Reordered the upload sequence \u2014 the new image is uploaded first, and
          the old image is only renamed to `<name>-<short-etag>` and tagged `atmosphere:image:obsolete`
          after the upload succeeds. This ensures the service image name is never
          left without an active image if an upload fails.\n- **`roles/glance_image/tasks/main.yml`**:
          Made ETag optional. The role no longer fails when the source URL does not
          return an `ETag` header. When an ETag is present it is used for change detection
          and stored as `atmosphere:image:etag` on the uploaded image. When absent,
          the role falls back to URL-only change detection and omits the property.\n-
          **`roles/glance_image/README.md`**: Updated to document the optional-ETag
          fallback behaviour, the upload-before-rename sequence, and that the HEAD
          request runs on every run to check for changes.\n- **`roles/glance_image/tasks/main.yml`**:
          Renamed the obsolete image tag from `atmosphere:obsolete` to `atmosphere:image:obsolete`
          for consistent namespace."
        change_url: https://github.com/vexxhost/atmosphere/pull/3862
        commit_id: ab2b33ec9479b3aedbfb7604a47a5eae0f3f8ee4
        patchset: ab2b33ec9479b3aedbfb7604a47a5eae0f3f8ee4
        project:
          canonical_hostname: github.com
          canonical_name: github.com/vexxhost/atmosphere
          name: vexxhost/atmosphere
          short_name: atmosphere
          src_dir: src/github.com/vexxhost/atmosphere
        src_dir: src/github.com/vexxhost/atmosphere
        topic: null
      change: '3862'
      change_message: "fix(glance_image): fix combine crash, make ETag optional, and
        upload before rename\n\nFixes a crash in the `glance_image` role where `combine()`
        received the Ansible omit placeholder string instead of a dict, and improves
        the role's safety and compatibility.\n\n## Changes Made\n\n- **`roles/glance/tasks/main.yml`**:
        Changed `glance_image_properties: default(omit)` to `default({})` so `combine()`
        always receives a dict, fixing the `failed to combine variables` crash.\n-
        **`roles/glance_image/tasks/main.yml`**: Reordered the upload sequence \u2014
        the new image is uploaded first, and the old image is only renamed to `<name>-<short-etag>`
        and tagged `atmosphere:image:obsolete` after the upload succeeds. This ensures
        the service image name is never left without an active image if an upload
        fails.\n- **`roles/glance_image/tasks/main.yml`**: Made ETag optional. The
        role no longer fails when the source URL does not return an `ETag` header.
        When an ETag is present it is used for change detection and stored as `atmosphere:image:etag`
        on the uploaded image. When absent, the role falls back to URL-only change
        detection and omits the property.\n- **`roles/glance_image/README.md`**: Updated
        to document the optional-ETag fallback behaviour, the upload-before-rename
        sequence, and that the HEAD request runs on every run to check for changes.\n-
        **`roles/glance_image/tasks/main.yml`**: Renamed the obsolete image tag from
        `atmosphere:obsolete` to `atmosphere:image:obsolete` for consistent namespace."
      change_url: https://github.com/vexxhost/atmosphere/pull/3862
      child_jobs: []
      commit_id: ab2b33ec9479b3aedbfb7604a47a5eae0f3f8ee4
      event_id: 5c4868a0-5442-11f1-82a9-1e4c784ee850
      executor:
        hostname: 2d72f0692154
        inventory_file: /var/lib/zuul/builds/4ecb2a65a4894e1880679bd40822362a/ansible/inventory.yaml
        log_root: /var/lib/zuul/builds/4ecb2a65a4894e1880679bd40822362a/work/logs
        result_data_file: /var/lib/zuul/builds/4ecb2a65a4894e1880679bd40822362a/work/results.json
        src_root: /var/lib/zuul/builds/4ecb2a65a4894e1880679bd40822362a/work/src
        work_root: /var/lib/zuul/builds/4ecb2a65a4894e1880679bd40822362a/work
      include_vars: []
      items:
      - branch: main
        change: '3862'
        change_message: "fix(glance_image): fix combine crash, make ETag optional,
          and upload before rename\n\nFixes a crash in the `glance_image` role where
          `combine()` received the Ansible omit placeholder string instead of a dict,
          and improves the role's safety and compatibility.\n\n## Changes Made\n\n-
          **`roles/glance/tasks/main.yml`**: Changed `glance_image_properties: default(omit)`
          to `default({})` so `combine()` always receives a dict, fixing the `failed
          to combine variables` crash.\n- **`roles/glance_image/tasks/main.yml`**:
          Reordered the upload sequence \u2014 the new image is uploaded first, and
          the old image is only renamed to `<name>-<short-etag>` and tagged `atmosphere:image:obsolete`
          after the upload succeeds. This ensures the service image name is never
          left without an active image if an upload fails.\n- **`roles/glance_image/tasks/main.yml`**:
          Made ETag optional. The role no longer fails when the source URL does not
          return an `ETag` header. When an ETag is present it is used for change detection
          and stored as `atmosphere:image:etag` on the uploaded image. When absent,
          the role falls back to URL-only change detection and omits the property.\n-
          **`roles/glance_image/README.md`**: Updated to document the optional-ETag
          fallback behaviour, the upload-before-rename sequence, and that the HEAD
          request runs on every run to check for changes.\n- **`roles/glance_image/tasks/main.yml`**:
          Renamed the obsolete image tag from `atmosphere:obsolete` to `atmosphere:image:obsolete`
          for consistent namespace."
        change_url: https://github.com/vexxhost/atmosphere/pull/3862
        commit_id: ab2b33ec9479b3aedbfb7604a47a5eae0f3f8ee4
        patchset: ab2b33ec9479b3aedbfb7604a47a5eae0f3f8ee4
        project:
          canonical_hostname: github.com
          canonical_name: github.com/vexxhost/atmosphere
          name: vexxhost/atmosphere
          short_name: atmosphere
          src_dir: src/github.com/vexxhost/atmosphere
        topic: null
      job: atmosphere-molecule-csi-local-path-provisioner
      jobtags: []
      max_attempts: 3
      message: Zml4KGdsYW5jZV9pbWFnZSk6IGZpeCBjb21iaW5lIGNyYXNoLCBtYWtlIEVUYWcgb3B0aW9uYWwsIGFuZCB1cGxvYWQgYmVmb3JlIHJlbmFtZQoKRml4ZXMgYSBjcmFzaCBpbiB0aGUgYGdsYW5jZV9pbWFnZWAgcm9sZSB3aGVyZSBgY29tYmluZSgpYCByZWNlaXZlZCB0aGUgQW5zaWJsZSBvbWl0IHBsYWNlaG9sZGVyIHN0cmluZyBpbnN0ZWFkIG9mIGEgZGljdCwgYW5kIGltcHJvdmVzIHRoZSByb2xlJ3Mgc2FmZXR5IGFuZCBjb21wYXRpYmlsaXR5LgoKIyMgQ2hhbmdlcyBNYWRlCgotICoqYHJvbGVzL2dsYW5jZS90YXNrcy9tYWluLnltbGAqKjogQ2hhbmdlZCBgZ2xhbmNlX2ltYWdlX3Byb3BlcnRpZXM6IGRlZmF1bHQob21pdClgIHRvIGBkZWZhdWx0KHt9KWAgc28gYGNvbWJpbmUoKWAgYWx3YXlzIHJlY2VpdmVzIGEgZGljdCwgZml4aW5nIHRoZSBgZmFpbGVkIHRvIGNvbWJpbmUgdmFyaWFibGVzYCBjcmFzaC4KLSAqKmByb2xlcy9nbGFuY2VfaW1hZ2UvdGFza3MvbWFpbi55bWxgKio6IFJlb3JkZXJlZCB0aGUgdXBsb2FkIHNlcXVlbmNlIOKAlCB0aGUgbmV3IGltYWdlIGlzIHVwbG9hZGVkIGZpcnN0LCBhbmQgdGhlIG9sZCBpbWFnZSBpcyBvbmx5IHJlbmFtZWQgdG8gYDxuYW1lPi08c2hvcnQtZXRhZz5gIGFuZCB0YWdnZWQgYGF0bW9zcGhlcmU6aW1hZ2U6b2Jzb2xldGVgIGFmdGVyIHRoZSB1cGxvYWQgc3VjY2VlZHMuIFRoaXMgZW5zdXJlcyB0aGUgc2VydmljZSBpbWFnZSBuYW1lIGlzIG5ldmVyIGxlZnQgd2l0aG91dCBhbiBhY3RpdmUgaW1hZ2UgaWYgYW4gdXBsb2FkIGZhaWxzLgotICoqYHJvbGVzL2dsYW5jZV9pbWFnZS90YXNrcy9tYWluLnltbGAqKjogTWFkZSBFVGFnIG9wdGlvbmFsLiBUaGUgcm9sZSBubyBsb25nZXIgZmFpbHMgd2hlbiB0aGUgc291cmNlIFVSTCBkb2VzIG5vdCByZXR1cm4gYW4gYEVUYWdgIGhlYWRlci4gV2hlbiBhbiBFVGFnIGlzIHByZXNlbnQgaXQgaXMgdXNlZCBmb3IgY2hhbmdlIGRldGVjdGlvbiBhbmQgc3RvcmVkIGFzIGBhdG1vc3BoZXJlOmltYWdlOmV0YWdgIG9uIHRoZSB1cGxvYWRlZCBpbWFnZS4gV2hlbiBhYnNlbnQsIHRoZSByb2xlIGZhbGxzIGJhY2sgdG8gVVJMLW9ubHkgY2hhbmdlIGRldGVjdGlvbiBhbmQgb21pdHMgdGhlIHByb3BlcnR5LgotICoqYHJvbGVzL2dsYW5jZV9pbWFnZS9SRUFETUUubWRgKio6IFVwZGF0ZWQgdG8gZG9jdW1lbnQgdGhlIG9wdGlvbmFsLUVUYWcgZmFsbGJhY2sgYmVoYXZpb3VyLCB0aGUgdXBsb2FkLWJlZm9yZS1yZW5hbWUgc2VxdWVuY2UsIGFuZCB0aGF0IHRoZSBIRUFEIHJlcXVlc3QgcnVucyBvbiBldmVyeSBydW4gdG8gY2hlY2sgZm9yIGNoYW5nZXMuCi0gKipgcm9sZXMvZ2xhbmNlX2ltYWdlL3Rhc2tzL21haW4ueW1sYCoqOiBSZW5hbWVkIHRoZSBvYnNvbGV0ZSBpbWFnZSB0YWcgZnJvbSBgYXRtb3NwaGVyZTpvYnNvbGV0ZWAgdG8gYGF0bW9zcGhlcmU6aW1hZ2U6b2Jzb2xldGVgIGZvciBjb25zaXN0ZW50IG5hbWVzcGFjZS4=
      patchset: ab2b33ec9479b3aedbfb7604a47a5eae0f3f8ee4
      pipeline: check
      playbook_context:
        playbook_projects:
          trusted/project_0/github.com/vexxhost/zuul-config:
            canonical_name: github.com/vexxhost/zuul-config
            checkout: main
            commit: 298983cd1253e6833abdb49d87d912527e0e6597
          trusted/project_1/opendev.org/zuul/zuul-jobs:
            canonical_name: opendev.org/zuul/zuul-jobs
            checkout: master
            commit: 79fe3eb1d01f8ac5739b0b7bc4759c407b6e248d
          trusted/project_2/github.com/vexxhost/zuul-jobs:
            canonical_name: github.com/vexxhost/zuul-jobs
            checkout: main
            commit: 348c7ff425450b0356e1d84589143dce260be74a
          untrusted/project_0/github.com/vexxhost/zuul-jobs:
            canonical_name: github.com/vexxhost/zuul-jobs
            checkout: main
            commit: 348c7ff425450b0356e1d84589143dce260be74a
          untrusted/project_1/github.com/vexxhost/zuul-config:
            canonical_name: github.com/vexxhost/zuul-config
            checkout: main
            commit: 298983cd1253e6833abdb49d87d912527e0e6597
          untrusted/project_2/opendev.org/zuul/zuul-jobs:
            canonical_name: opendev.org/zuul/zuul-jobs
            checkout: master
            commit: 79fe3eb1d01f8ac5739b0b7bc4759c407b6e248d
          untrusted/project_3/github.com/vexxhost/atmosphere:
            canonical_name: github.com/vexxhost/atmosphere
            checkout: main
            commit: ab2b33ec9479b3aedbfb7604a47a5eae0f3f8ee4
          untrusted/project_4/opendev.org/openstack/openstack-helm:
            canonical_name: opendev.org/openstack/openstack-helm
            checkout: master
            commit: ebd6507b8b84365fe43c389f9571959da7b0826c
        playbooks:
        - path: untrusted/project_0/github.com/vexxhost/zuul-jobs/playbooks/molecule/run.yaml
          roles:
          - checkout: master
            checkout_description: project default branch
            link_name: ansible/playbook_0/role_1/zuul-jobs
            link_target: untrusted/project_2/opendev.org/zuul/zuul-jobs
            role_path: ansible/playbook_0/role_1/zuul-jobs/roles
          - checkout: main
            checkout_description: playbook branch
            link_name: ansible/playbook_0/role_2/zuul-jobs
            link_target: untrusted/project_0/github.com/vexxhost/zuul-jobs
            role_path: ansible/playbook_0/role_2/zuul-jobs/roles
        post_playbooks:
        - path: untrusted/project_3/github.com/vexxhost/atmosphere/test-playbooks/molecule/post.yml
          roles:
          - checkout: main
            checkout_description: playbook branch
            link_name: ansible/post_playbook_0/role_0/atmosphere
            link_target: untrusted/project_3/github.com/vexxhost/atmosphere
            role_path: ansible/post_playbook_0/role_0/atmosphere/roles
          - checkout: master
            checkout_description: project default branch
            link_name: ansible/post_playbook_0/role_1/openstack-helm
            link_target: untrusted/project_4/opendev.org/openstack/openstack-helm
            role_path: ansible/post_playbook_0/role_1/openstack-helm/roles
          - checkout: master
            checkout_description: project default branch
            link_name: ansible/post_playbook_0/role_3/zuul-jobs
            link_target: untrusted/project_2/opendev.org/zuul/zuul-jobs
            role_path: ansible/post_playbook_0/role_3/zuul-jobs/roles
          - checkout: main
            checkout_description: zuul branch
            link_name: ansible/post_playbook_0/role_4/zuul-jobs
            link_target: untrusted/project_0/github.com/vexxhost/zuul-jobs
            role_path: ansible/post_playbook_0/role_4/zuul-jobs/roles
        - path: trusted/project_0/github.com/vexxhost/zuul-config/playbooks/base/post.yaml
          roles:
          - checkout: master
            checkout_description: project default branch
            link_name: ansible/post_playbook_1/role_1/zuul-jobs
            link_target: trusted/project_1/opendev.org/zuul/zuul-jobs
            role_path: ansible/post_playbook_1/role_1/zuul-jobs/roles
          - checkout: main
            checkout_description: zuul branch
            link_name: ansible/post_playbook_1/role_2/zuul-jobs
            link_target: trusted/project_2/github.com/vexxhost/zuul-jobs
            role_path: ansible/post_playbook_1/role_2/zuul-jobs/roles
        - path: trusted/project_0/github.com/vexxhost/zuul-config/playbooks/base/post-logs.yaml
          roles:
          - checkout: master
            checkout_description: project default branch
            link_name: ansible/post_playbook_2/role_1/zuul-jobs
            link_target: trusted/project_1/opendev.org/zuul/zuul-jobs
            role_path: ansible/post_playbook_2/role_1/zuul-jobs/roles
          - checkout: main
            checkout_description: zuul branch
            link_name: ansible/post_playbook_2/role_2/zuul-jobs
            link_target: trusted/project_2/github.com/vexxhost/zuul-jobs
            role_path: ansible/post_playbook_2/role_2/zuul-jobs/roles
        pre_playbooks:
        - path: trusted/project_0/github.com/vexxhost/zuul-config/playbooks/base/pre.yaml
          roles:
          - checkout: master
            checkout_description: project default branch
            link_name: ansible/pre_playbook_0/role_1/zuul-jobs
            link_target: trusted/project_1/opendev.org/zuul/zuul-jobs
            role_path: ansible/pre_playbook_0/role_1/zuul-jobs/roles
          - checkout: main
            checkout_description: zuul branch
            link_name: ansible/pre_playbook_0/role_2/zuul-jobs
            link_target: trusted/project_2/github.com/vexxhost/zuul-jobs
            role_path: ansible/pre_playbook_0/role_2/zuul-jobs/roles
        - path: untrusted/project_0/github.com/vexxhost/zuul-jobs/playbooks/molecule/pre.yaml
          roles:
          - checkout: master
            checkout_description: project default branch
            link_name: ansible/pre_playbook_1/role_1/zuul-jobs
            link_target: untrusted/project_2/opendev.org/zuul/zuul-jobs
            role_path: ansible/pre_playbook_1/role_1/zuul-jobs/roles
          - checkout: main
            checkout_description: playbook branch
            link_name: ansible/pre_playbook_1/role_2/zuul-jobs
            link_target: untrusted/project_0/github.com/vexxhost/zuul-jobs
            role_path: ansible/pre_playbook_1/role_2/zuul-jobs/roles
        - path: untrusted/project_3/github.com/vexxhost/atmosphere/test-playbooks/molecule/pre.yml
          roles:
          - checkout: main
            checkout_description: playbook branch
            link_name: ansible/pre_playbook_2/role_0/atmosphere
            link_target: untrusted/project_3/github.com/vexxhost/atmosphere
            role_path: ansible/pre_playbook_2/role_0/atmosphere/roles
          - checkout: master
            checkout_description: project default branch
            link_name: ansible/pre_playbook_2/role_1/openstack-helm
            link_target: untrusted/project_4/opendev.org/openstack/openstack-helm
            role_path: ansible/pre_playbook_2/role_1/openstack-helm/roles
          - checkout: master
            checkout_description: project default branch
            link_name: ansible/pre_playbook_2/role_3/zuul-jobs
            link_target: untrusted/project_2/opendev.org/zuul/zuul-jobs
            role_path: ansible/pre_playbook_2/role_3/zuul-jobs/roles
          - checkout: main
            checkout_description: zuul branch
            link_name: ansible/pre_playbook_2/role_4/zuul-jobs
            link_target: untrusted/project_0/github.com/vexxhost/zuul-jobs
            role_path: ansible/pre_playbook_2/role_4/zuul-jobs/roles
      post_review: false
      post_timeout: null
      pre_timeout: null
      project:
        canonical_hostname: github.com
        canonical_name: github.com/vexxhost/atmosphere
        name: vexxhost/atmosphere
        short_name: atmosphere
        src_dir: src/github.com/vexxhost/atmosphere
      projects:
        github.com/ansible-collections/ansible.netcommon:
          canonical_hostname: github.com
          canonical_name: github.com/ansible-collections/ansible.netcommon
          checkout: main
          checkout_description: zuul branch
          commit: 74b98f449ab9c553bd7821a7524e54412cd05751
          name: ansible-collections/ansible.netcommon
          required: true
          short_name: ansible.netcommon
          src_dir: src/github.com/ansible-collections/ansible.netcommon
        github.com/ansible-collections/ansible.posix:
          canonical_hostname: github.com
          canonical_name: github.com/ansible-collections/ansible.posix
          checkout: main
          checkout_description: zuul branch
          commit: 3059c5138cb18ab1cc1a305bf6f91322177d36dc
          name: ansible-collections/ansible.posix
          required: true
          short_name: ansible.posix
          src_dir: src/github.com/ansible-collections/ansible.posix
        github.com/ansible-collections/ansible.utils:
          canonical_hostname: github.com
          canonical_name: github.com/ansible-collections/ansible.utils
          checkout: main
          checkout_description: zuul branch
          commit: 777fdd8b4df2aebf2227d5b3d89eb8f97fcc281c
          name: ansible-collections/ansible.utils
          required: true
          short_name: ansible.utils
          src_dir: src/github.com/ansible-collections/ansible.utils
        github.com/ansible-collections/community.crypto:
          canonical_hostname: github.com
          canonical_name: github.com/ansible-collections/community.crypto
          checkout: main
          checkout_description: zuul branch
          commit: be72041cee7c6766efa4d22ee9e7ffbc2cb14676
          name: ansible-collections/community.crypto
          required: true
          short_name: community.crypto
          src_dir: src/github.com/ansible-collections/community.crypto
        github.com/ansible-collections/community.general:
          canonical_hostname: github.com
          canonical_name: github.com/ansible-collections/community.general
          checkout: main
          checkout_description: zuul branch
          commit: e6ca0df592c4db26ef4af31ea08986fa8a056fd6
          name: ansible-collections/community.general
          required: true
          short_name: community.general
          src_dir: src/github.com/ansible-collections/community.general
        github.com/ansible-collections/community.mysql:
          canonical_hostname: github.com
          canonical_name: github.com/ansible-collections/community.mysql
          checkout: main
          checkout_description: zuul branch
          commit: fa81214de95662ba161ddaeb99680a16a7d337d4
          name: ansible-collections/community.mysql
          required: true
          short_name: community.mysql
          src_dir: src/github.com/ansible-collections/community.mysql
        github.com/ansible-collections/kubernetes.core:
          canonical_hostname: github.com
          canonical_name: github.com/ansible-collections/kubernetes.core
          checkout: main
          checkout_description: zuul branch
          commit: 53c6c0ee80065de07286213058ee1747939b4add
          name: ansible-collections/kubernetes.core
          required: true
          short_name: kubernetes.core
          src_dir: src/github.com/ansible-collections/kubernetes.core
        github.com/vexxhost/ansible-collection-ceph:
          canonical_hostname: github.com
          canonical_name: github.com/vexxhost/ansible-collection-ceph
          checkout: main
          checkout_description: zuul branch
          commit: 73f630a25d5c22f029e85298d9d47f3d94a014a6
          name: vexxhost/ansible-collection-ceph
          required: true
          short_name: ansible-collection-ceph
          src_dir: src/github.com/vexxhost/ansible-collection-ceph
        github.com/vexxhost/ansible-collection-containers:
          canonical_hostname: github.com
          canonical_name: github.com/vexxhost/ansible-collection-containers
          checkout: main
          checkout_description: zuul branch
          commit: 81e3fb55671a8a2c167c263761c5c139bc8421bc
          name: vexxhost/ansible-collection-containers
          required: true
          short_name: ansible-collection-containers
          src_dir: src/github.com/vexxhost/ansible-collection-containers
        github.com/vexxhost/ansible-collection-kubernetes:
          canonical_hostname: github.com
          canonical_name: github.com/vexxhost/ansible-collection-kubernetes
          checkout: main
          checkout_description: zuul branch
          commit: 9e778e36eee2b628f7d316634d7bc6f722c101b9
          name: vexxhost/ansible-collection-kubernetes
          required: true
          short_name: ansible-collection-kubernetes
          src_dir: src/github.com/vexxhost/ansible-collection-kubernetes
        github.com/vexxhost/atmosphere:
          canonical_hostname: github.com
          canonical_name: github.com/vexxhost/atmosphere
          checkout: main
          checkout_description: zuul branch
          commit: ab2b33ec9479b3aedbfb7604a47a5eae0f3f8ee4
          name: vexxhost/atmosphere
          required: false
          short_name: atmosphere
          src_dir: src/github.com/vexxhost/atmosphere
        github.com/vexxhost/atmosphere.common:
          canonical_hostname: github.com
          canonical_name: github.com/vexxhost/atmosphere.common
          checkout: main
          checkout_description: zuul branch
          commit: b64e01cde1aaea79198f3ca2385e27c224b2c7a3
          name: vexxhost/atmosphere.common
          required: true
          short_name: atmosphere.common
          src_dir: src/github.com/vexxhost/atmosphere.common
        opendev.org/openstack/ansible-collections-openstack:
          canonical_hostname: opendev.org
          canonical_name: opendev.org/openstack/ansible-collections-openstack
          checkout: master
          checkout_description: project default branch
          commit: 338534eab2f1111a652739e873a5c6deb32bbce2
          name: openstack/ansible-collections-openstack
          required: true
          short_name: ansible-collections-openstack
          src_dir: src/opendev.org/openstack/ansible-collections-openstack
      ref: refs/pull/3862/head
      resources: {}
      tenant: oss
      timeout: 1800
      topic: null
      voting: true
