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.19.213.222
      ansible_port: 22
      ansible_python_interpreter: auto
      ansible_user: zuul
      atmosphere_deploy_tags: kubernetes,csi
      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
      ceph_public_network: '{{ ansible_facts[''default_ipv4''][''network''] + ''/''
        + (ansible_facts[''default_ipv4''][''prefix''] | string) }}'
      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_scenario: csi
      nodepool:
        az: nova
        cloud: public
        external_id: e76d87da-da11-4b27-b58f-46f1db346180
        host_id: 413ad91e6120ae81306de27e59dcefd40ab96f06b8665fea7030ef8f
        interface_ip: 199.19.213.222
        label: ubuntu-jammy
        node_properties: {}
        private_ipv4: 199.19.213.222
        private_ipv6: null
        provider: yul1
        public_ipv4: 199.19.213.222
        public_ipv6: 2604:e100:1:0:f816:3eff:fe83:4fa6
        region: ca-ymq-1
        slot: null
      zuul_node:
        az: nova
        cloud: public
        external_id: e76d87da-da11-4b27-b58f-46f1db346180
        host_id: 413ad91e6120ae81306de27e59dcefd40ab96f06b8665fea7030ef8f
        interface_ip: 199.19.213.222
        label: ubuntu-jammy
        node_properties: {}
        private_ipv4: 199.19.213.222
        private_ipv6: null
        provider: yul1
        public_ipv4: 199.19.213.222
        public_ipv6: 2604:e100:1:0:f816:3eff:fe83:4fa6
        region: ca-ymq-1
        slot: null
        uuid: null
  vars:
    atmosphere_deploy_tags: kubernetes,csi
    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
    ceph_public_network: '{{ ansible_facts[''default_ipv4''][''network''] + ''/''
      + (ansible_facts[''default_ipv4''][''prefix''] | string) }}'
    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_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#61>'
      - '<Job atmosphere-molecule-csi-local-path-provisioner explicit: None implied:
        {MatchAny:{ImpliedBranchMatcher:main}} source: vexxhost/atmosphere/.zuul.yaml@main#68>'
      - '<Job atmosphere-molecule-csi-local-path-provisioner explicit: None implied:
        None source: vexxhost/atmosphere/.zuul.yaml@main#314>'
      ansible_version: '9'
      attempts: 1
      branch: main
      build: 753e7106071c41ebb058e85489a84018
      build_refs:
      - branch: main
        change: '3844'
        change_message: "feat(deploy): break three config-only DAG edges for parallelism\n\n##
          Summary\n\nAudit of install-time behaviour vs. declared dependencies in
          the parallel deployment orchestrator found three edges where the declared
          dependency is a **configuration-only reference** (endpoint URL stored in
          a Helm values template) rather than a real install-time API call. Removing
          them lets the orchestrator schedule components earlier.\n\n### Edges removed\n\n|
          Component | Old deps | New deps | Why the removed edge is safe |\n|---|---|---|---|\n|
          `neutron` | keystone, **nova**, ovn, coredns | keystone, ovn, coredns |
          `roles/neutron/tasks/main.yml` only makes Neutron API calls (`openstack.cloud.network`,
          subnets) and does not touch Nova at install time. |\n| `magnum` | **barbican**,
          **heat** | keystone | `roles/magnum/vars/main.yml` references `barbican_client`
          / `heat_client` in `magnum.conf`. These strings are only dereferenced when
          a user later creates a cluster. |\n| `rook-ceph-cluster` | rook-ceph, ceph,
          **barbican** | rook-ceph, ceph, **keystone** | The role creates an identity
          user and catalog entry for the RGW. The previous Barbican dependency was
          mis-declared \u2014 the real dependency is Keystone. |\n\n### Readiness
          check added\n\nAlong with the Keystone dependency, `roles/rook_ceph_cluster/tasks/main.yml`
          now waits for the `keystone-api` Deployment to be `Available` before the
          subsequent `openstack.cloud.*` calls, preventing a race with Keystone's
          rollout. This mirrors the cert-manager secret wait added for Octavia in
          #3834.\n\nThe other two removals (`neutron -> nova`, `magnum -> barbican/heat`)
          don't need new gates: audit of the affected `tasks/` files confirms they
          make no install-time API calls against the removed dependencies.\n\n## Measured
          impact\n\nOn `atmosphere-molecule-aio-ovn` the current critical path is:\n\n```\n...
          -> keystone -> Wave6 -> nova -> neutron -> (octavia || manila) = ~12 min
          tail\n```\n\nAfter these changes the expected critical path is:\n\n```\n...
          -> keystone -> Wave6 -> (nova || neutron) -> (octavia || manila) = ~8.5
          min tail\n```\n\n**Expected saving: ~3 min 20 s on the critical path** (roughly
          9% of the measured 34m 40s non-prepull deploy time in #3841).\n\n## Validation\n\n-
          `go test ./pkg/dag/ ./internal/deploy/` passes.\n- `go build ./cmd/atmosphere`
          succeeds.\n- Release note passes `vale` with zero errors / warnings / suggestions.\n-
          DCO signed.\n\n## Stacking\n\nThis PR is based on #3818 (`feat/parallel-deploy-orchestrator`)
          so it is self-contained once #3818 lands on main. #3841 will be rebuilt
          as #3834 + #3835 + this PR on top of `main`.\n\nSigned-off-by: Rico Lin
          <rlin@vexxhost.com>\nCo-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>"
        change_url: https://github.com/vexxhost/atmosphere/pull/3844
        commit_id: c112285bf56a1fb035a17e619036804879673465
        patchset: c112285bf56a1fb035a17e619036804879673465
        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: ba8dbc0c1f8c4716a1ff518844d96dd6
      buildset_refs:
      - branch: main
        change: '3844'
        change_message: "feat(deploy): break three config-only DAG edges for parallelism\n\n##
          Summary\n\nAudit of install-time behaviour vs. declared dependencies in
          the parallel deployment orchestrator found three edges where the declared
          dependency is a **configuration-only reference** (endpoint URL stored in
          a Helm values template) rather than a real install-time API call. Removing
          them lets the orchestrator schedule components earlier.\n\n### Edges removed\n\n|
          Component | Old deps | New deps | Why the removed edge is safe |\n|---|---|---|---|\n|
          `neutron` | keystone, **nova**, ovn, coredns | keystone, ovn, coredns |
          `roles/neutron/tasks/main.yml` only makes Neutron API calls (`openstack.cloud.network`,
          subnets) and does not touch Nova at install time. |\n| `magnum` | **barbican**,
          **heat** | keystone | `roles/magnum/vars/main.yml` references `barbican_client`
          / `heat_client` in `magnum.conf`. These strings are only dereferenced when
          a user later creates a cluster. |\n| `rook-ceph-cluster` | rook-ceph, ceph,
          **barbican** | rook-ceph, ceph, **keystone** | The role creates an identity
          user and catalog entry for the RGW. The previous Barbican dependency was
          mis-declared \u2014 the real dependency is Keystone. |\n\n### Readiness
          check added\n\nAlong with the Keystone dependency, `roles/rook_ceph_cluster/tasks/main.yml`
          now waits for the `keystone-api` Deployment to be `Available` before the
          subsequent `openstack.cloud.*` calls, preventing a race with Keystone's
          rollout. This mirrors the cert-manager secret wait added for Octavia in
          #3834.\n\nThe other two removals (`neutron -> nova`, `magnum -> barbican/heat`)
          don't need new gates: audit of the affected `tasks/` files confirms they
          make no install-time API calls against the removed dependencies.\n\n## Measured
          impact\n\nOn `atmosphere-molecule-aio-ovn` the current critical path is:\n\n```\n...
          -> keystone -> Wave6 -> nova -> neutron -> (octavia || manila) = ~12 min
          tail\n```\n\nAfter these changes the expected critical path is:\n\n```\n...
          -> keystone -> Wave6 -> (nova || neutron) -> (octavia || manila) = ~8.5
          min tail\n```\n\n**Expected saving: ~3 min 20 s on the critical path** (roughly
          9% of the measured 34m 40s non-prepull deploy time in #3841).\n\n## Validation\n\n-
          `go test ./pkg/dag/ ./internal/deploy/` passes.\n- `go build ./cmd/atmosphere`
          succeeds.\n- Release note passes `vale` with zero errors / warnings / suggestions.\n-
          DCO signed.\n\n## Stacking\n\nThis PR is based on #3818 (`feat/parallel-deploy-orchestrator`)
          so it is self-contained once #3818 lands on main. #3841 will be rebuilt
          as #3834 + #3835 + this PR on top of `main`.\n\nSigned-off-by: Rico Lin
          <rlin@vexxhost.com>\nCo-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>"
        change_url: https://github.com/vexxhost/atmosphere/pull/3844
        commit_id: c112285bf56a1fb035a17e619036804879673465
        patchset: c112285bf56a1fb035a17e619036804879673465
        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: '3844'
      change_message: "feat(deploy): break three config-only DAG edges for parallelism\n\n##
        Summary\n\nAudit of install-time behaviour vs. declared dependencies in the
        parallel deployment orchestrator found three edges where the declared dependency
        is a **configuration-only reference** (endpoint URL stored in a Helm values
        template) rather than a real install-time API call. Removing them lets the
        orchestrator schedule components earlier.\n\n### Edges removed\n\n| Component
        | Old deps | New deps | Why the removed edge is safe |\n|---|---|---|---|\n|
        `neutron` | keystone, **nova**, ovn, coredns | keystone, ovn, coredns | `roles/neutron/tasks/main.yml`
        only makes Neutron API calls (`openstack.cloud.network`, subnets) and does
        not touch Nova at install time. |\n| `magnum` | **barbican**, **heat** | keystone
        | `roles/magnum/vars/main.yml` references `barbican_client` / `heat_client`
        in `magnum.conf`. These strings are only dereferenced when a user later creates
        a cluster. |\n| `rook-ceph-cluster` | rook-ceph, ceph, **barbican** | rook-ceph,
        ceph, **keystone** | The role creates an identity user and catalog entry for
        the RGW. The previous Barbican dependency was mis-declared \u2014 the real
        dependency is Keystone. |\n\n### Readiness check added\n\nAlong with the Keystone
        dependency, `roles/rook_ceph_cluster/tasks/main.yml` now waits for the `keystone-api`
        Deployment to be `Available` before the subsequent `openstack.cloud.*` calls,
        preventing a race with Keystone's rollout. This mirrors the cert-manager secret
        wait added for Octavia in #3834.\n\nThe other two removals (`neutron -> nova`,
        `magnum -> barbican/heat`) don't need new gates: audit of the affected `tasks/`
        files confirms they make no install-time API calls against the removed dependencies.\n\n##
        Measured impact\n\nOn `atmosphere-molecule-aio-ovn` the current critical path
        is:\n\n```\n... -> keystone -> Wave6 -> nova -> neutron -> (octavia || manila)
        = ~12 min tail\n```\n\nAfter these changes the expected critical path is:\n\n```\n...
        -> keystone -> Wave6 -> (nova || neutron) -> (octavia || manila) = ~8.5 min
        tail\n```\n\n**Expected saving: ~3 min 20 s on the critical path** (roughly
        9% of the measured 34m 40s non-prepull deploy time in #3841).\n\n## Validation\n\n-
        `go test ./pkg/dag/ ./internal/deploy/` passes.\n- `go build ./cmd/atmosphere`
        succeeds.\n- Release note passes `vale` with zero errors / warnings / suggestions.\n-
        DCO signed.\n\n## Stacking\n\nThis PR is based on #3818 (`feat/parallel-deploy-orchestrator`)
        so it is self-contained once #3818 lands on main. #3841 will be rebuilt as
        #3834 + #3835 + this PR on top of `main`.\n\nSigned-off-by: Rico Lin <rlin@vexxhost.com>\nCo-authored-by:
        Copilot <223556219+Copilot@users.noreply.github.com>"
      change_url: https://github.com/vexxhost/atmosphere/pull/3844
      child_jobs: []
      commit_id: c112285bf56a1fb035a17e619036804879673465
      event_id: be8e8f70-3f30-11f1-8300-dde549b7518a
      executor:
        hostname: 0a8996d2b663
        inventory_file: /var/lib/zuul/builds/753e7106071c41ebb058e85489a84018/ansible/inventory.yaml
        log_root: /var/lib/zuul/builds/753e7106071c41ebb058e85489a84018/work/logs
        result_data_file: /var/lib/zuul/builds/753e7106071c41ebb058e85489a84018/work/results.json
        src_root: /var/lib/zuul/builds/753e7106071c41ebb058e85489a84018/work/src
        work_root: /var/lib/zuul/builds/753e7106071c41ebb058e85489a84018/work
      include_vars: []
      items:
      - branch: main
        change: '3844'
        change_message: "feat(deploy): break three config-only DAG edges for parallelism\n\n##
          Summary\n\nAudit of install-time behaviour vs. declared dependencies in
          the parallel deployment orchestrator found three edges where the declared
          dependency is a **configuration-only reference** (endpoint URL stored in
          a Helm values template) rather than a real install-time API call. Removing
          them lets the orchestrator schedule components earlier.\n\n### Edges removed\n\n|
          Component | Old deps | New deps | Why the removed edge is safe |\n|---|---|---|---|\n|
          `neutron` | keystone, **nova**, ovn, coredns | keystone, ovn, coredns |
          `roles/neutron/tasks/main.yml` only makes Neutron API calls (`openstack.cloud.network`,
          subnets) and does not touch Nova at install time. |\n| `magnum` | **barbican**,
          **heat** | keystone | `roles/magnum/vars/main.yml` references `barbican_client`
          / `heat_client` in `magnum.conf`. These strings are only dereferenced when
          a user later creates a cluster. |\n| `rook-ceph-cluster` | rook-ceph, ceph,
          **barbican** | rook-ceph, ceph, **keystone** | The role creates an identity
          user and catalog entry for the RGW. The previous Barbican dependency was
          mis-declared \u2014 the real dependency is Keystone. |\n\n### Readiness
          check added\n\nAlong with the Keystone dependency, `roles/rook_ceph_cluster/tasks/main.yml`
          now waits for the `keystone-api` Deployment to be `Available` before the
          subsequent `openstack.cloud.*` calls, preventing a race with Keystone's
          rollout. This mirrors the cert-manager secret wait added for Octavia in
          #3834.\n\nThe other two removals (`neutron -> nova`, `magnum -> barbican/heat`)
          don't need new gates: audit of the affected `tasks/` files confirms they
          make no install-time API calls against the removed dependencies.\n\n## Measured
          impact\n\nOn `atmosphere-molecule-aio-ovn` the current critical path is:\n\n```\n...
          -> keystone -> Wave6 -> nova -> neutron -> (octavia || manila) = ~12 min
          tail\n```\n\nAfter these changes the expected critical path is:\n\n```\n...
          -> keystone -> Wave6 -> (nova || neutron) -> (octavia || manila) = ~8.5
          min tail\n```\n\n**Expected saving: ~3 min 20 s on the critical path** (roughly
          9% of the measured 34m 40s non-prepull deploy time in #3841).\n\n## Validation\n\n-
          `go test ./pkg/dag/ ./internal/deploy/` passes.\n- `go build ./cmd/atmosphere`
          succeeds.\n- Release note passes `vale` with zero errors / warnings / suggestions.\n-
          DCO signed.\n\n## Stacking\n\nThis PR is based on #3818 (`feat/parallel-deploy-orchestrator`)
          so it is self-contained once #3818 lands on main. #3841 will be rebuilt
          as #3834 + #3835 + this PR on top of `main`.\n\nSigned-off-by: Rico Lin
          <rlin@vexxhost.com>\nCo-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>"
        change_url: https://github.com/vexxhost/atmosphere/pull/3844
        commit_id: c112285bf56a1fb035a17e619036804879673465
        patchset: c112285bf56a1fb035a17e619036804879673465
        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: ZmVhdChkZXBsb3kpOiBicmVhayB0aHJlZSBjb25maWctb25seSBEQUcgZWRnZXMgZm9yIHBhcmFsbGVsaXNtCgojIyBTdW1tYXJ5CgpBdWRpdCBvZiBpbnN0YWxsLXRpbWUgYmVoYXZpb3VyIHZzLiBkZWNsYXJlZCBkZXBlbmRlbmNpZXMgaW4gdGhlIHBhcmFsbGVsIGRlcGxveW1lbnQgb3JjaGVzdHJhdG9yIGZvdW5kIHRocmVlIGVkZ2VzIHdoZXJlIHRoZSBkZWNsYXJlZCBkZXBlbmRlbmN5IGlzIGEgKipjb25maWd1cmF0aW9uLW9ubHkgcmVmZXJlbmNlKiogKGVuZHBvaW50IFVSTCBzdG9yZWQgaW4gYSBIZWxtIHZhbHVlcyB0ZW1wbGF0ZSkgcmF0aGVyIHRoYW4gYSByZWFsIGluc3RhbGwtdGltZSBBUEkgY2FsbC4gUmVtb3ZpbmcgdGhlbSBsZXRzIHRoZSBvcmNoZXN0cmF0b3Igc2NoZWR1bGUgY29tcG9uZW50cyBlYXJsaWVyLgoKIyMjIEVkZ2VzIHJlbW92ZWQKCnwgQ29tcG9uZW50IHwgT2xkIGRlcHMgfCBOZXcgZGVwcyB8IFdoeSB0aGUgcmVtb3ZlZCBlZGdlIGlzIHNhZmUgfAp8LS0tfC0tLXwtLS18LS0tfAp8IGBuZXV0cm9uYCB8IGtleXN0b25lLCAqKm5vdmEqKiwgb3ZuLCBjb3JlZG5zIHwga2V5c3RvbmUsIG92biwgY29yZWRucyB8IGByb2xlcy9uZXV0cm9uL3Rhc2tzL21haW4ueW1sYCBvbmx5IG1ha2VzIE5ldXRyb24gQVBJIGNhbGxzIChgb3BlbnN0YWNrLmNsb3VkLm5ldHdvcmtgLCBzdWJuZXRzKSBhbmQgZG9lcyBub3QgdG91Y2ggTm92YSBhdCBpbnN0YWxsIHRpbWUuIHwKfCBgbWFnbnVtYCB8ICoqYmFyYmljYW4qKiwgKipoZWF0KiogfCBrZXlzdG9uZSB8IGByb2xlcy9tYWdudW0vdmFycy9tYWluLnltbGAgcmVmZXJlbmNlcyBgYmFyYmljYW5fY2xpZW50YCAvIGBoZWF0X2NsaWVudGAgaW4gYG1hZ251bS5jb25mYC4gVGhlc2Ugc3RyaW5ncyBhcmUgb25seSBkZXJlZmVyZW5jZWQgd2hlbiBhIHVzZXIgbGF0ZXIgY3JlYXRlcyBhIGNsdXN0ZXIuIHwKfCBgcm9vay1jZXBoLWNsdXN0ZXJgIHwgcm9vay1jZXBoLCBjZXBoLCAqKmJhcmJpY2FuKiogfCByb29rLWNlcGgsIGNlcGgsICoqa2V5c3RvbmUqKiB8IFRoZSByb2xlIGNyZWF0ZXMgYW4gaWRlbnRpdHkgdXNlciBhbmQgY2F0YWxvZyBlbnRyeSBmb3IgdGhlIFJHVy4gVGhlIHByZXZpb3VzIEJhcmJpY2FuIGRlcGVuZGVuY3kgd2FzIG1pcy1kZWNsYXJlZCDigJQgdGhlIHJlYWwgZGVwZW5kZW5jeSBpcyBLZXlzdG9uZS4gfAoKIyMjIFJlYWRpbmVzcyBjaGVjayBhZGRlZAoKQWxvbmcgd2l0aCB0aGUgS2V5c3RvbmUgZGVwZW5kZW5jeSwgYHJvbGVzL3Jvb2tfY2VwaF9jbHVzdGVyL3Rhc2tzL21haW4ueW1sYCBub3cgd2FpdHMgZm9yIHRoZSBga2V5c3RvbmUtYXBpYCBEZXBsb3ltZW50IHRvIGJlIGBBdmFpbGFibGVgIGJlZm9yZSB0aGUgc3Vic2VxdWVudCBgb3BlbnN0YWNrLmNsb3VkLipgIGNhbGxzLCBwcmV2ZW50aW5nIGEgcmFjZSB3aXRoIEtleXN0b25lJ3Mgcm9sbG91dC4gVGhpcyBtaXJyb3JzIHRoZSBjZXJ0LW1hbmFnZXIgc2VjcmV0IHdhaXQgYWRkZWQgZm9yIE9jdGF2aWEgaW4gIzM4MzQuCgpUaGUgb3RoZXIgdHdvIHJlbW92YWxzIChgbmV1dHJvbiAtPiBub3ZhYCwgYG1hZ251bSAtPiBiYXJiaWNhbi9oZWF0YCkgZG9uJ3QgbmVlZCBuZXcgZ2F0ZXM6IGF1ZGl0IG9mIHRoZSBhZmZlY3RlZCBgdGFza3MvYCBmaWxlcyBjb25maXJtcyB0aGV5IG1ha2Ugbm8gaW5zdGFsbC10aW1lIEFQSSBjYWxscyBhZ2FpbnN0IHRoZSByZW1vdmVkIGRlcGVuZGVuY2llcy4KCiMjIE1lYXN1cmVkIGltcGFjdAoKT24gYGF0bW9zcGhlcmUtbW9sZWN1bGUtYWlvLW92bmAgdGhlIGN1cnJlbnQgY3JpdGljYWwgcGF0aCBpczoKCmBgYAouLi4gLT4ga2V5c3RvbmUgLT4gV2F2ZTYgLT4gbm92YSAtPiBuZXV0cm9uIC0+IChvY3RhdmlhIHx8IG1hbmlsYSkgPSB+MTIgbWluIHRhaWwKYGBgCgpBZnRlciB0aGVzZSBjaGFuZ2VzIHRoZSBleHBlY3RlZCBjcml0aWNhbCBwYXRoIGlzOgoKYGBgCi4uLiAtPiBrZXlzdG9uZSAtPiBXYXZlNiAtPiAobm92YSB8fCBuZXV0cm9uKSAtPiAob2N0YXZpYSB8fCBtYW5pbGEpID0gfjguNSBtaW4gdGFpbApgYGAKCioqRXhwZWN0ZWQgc2F2aW5nOiB+MyBtaW4gMjAgcyBvbiB0aGUgY3JpdGljYWwgcGF0aCoqIChyb3VnaGx5IDklIG9mIHRoZSBtZWFzdXJlZCAzNG0gNDBzIG5vbi1wcmVwdWxsIGRlcGxveSB0aW1lIGluICMzODQxKS4KCiMjIFZhbGlkYXRpb24KCi0gYGdvIHRlc3QgLi9wa2cvZGFnLyAuL2ludGVybmFsL2RlcGxveS9gIHBhc3Nlcy4KLSBgZ28gYnVpbGQgLi9jbWQvYXRtb3NwaGVyZWAgc3VjY2VlZHMuCi0gUmVsZWFzZSBub3RlIHBhc3NlcyBgdmFsZWAgd2l0aCB6ZXJvIGVycm9ycyAvIHdhcm5pbmdzIC8gc3VnZ2VzdGlvbnMuCi0gRENPIHNpZ25lZC4KCiMjIFN0YWNraW5nCgpUaGlzIFBSIGlzIGJhc2VkIG9uICMzODE4IChgZmVhdC9wYXJhbGxlbC1kZXBsb3ktb3JjaGVzdHJhdG9yYCkgc28gaXQgaXMgc2VsZi1jb250YWluZWQgb25jZSAjMzgxOCBsYW5kcyBvbiBtYWluLiAjMzg0MSB3aWxsIGJlIHJlYnVpbHQgYXMgIzM4MzQgKyAjMzgzNSArIHRoaXMgUFIgb24gdG9wIG9mIGBtYWluYC4KClNpZ25lZC1vZmYtYnk6IFJpY28gTGluIDxybGluQHZleHhob3N0LmNvbT4KQ28tYXV0aG9yZWQtYnk6IENvcGlsb3QgPDIyMzU1NjIxOStDb3BpbG90QHVzZXJzLm5vcmVwbHkuZ2l0aHViLmNvbT4=
      patchset: c112285bf56a1fb035a17e619036804879673465
      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: 9f5c1d680d573485f0ccdb18d2184d4f1d446419
          trusted/project_2/github.com/vexxhost/zuul-jobs:
            canonical_name: github.com/vexxhost/zuul-jobs
            checkout: main
            commit: a6e68243e02ef030ce5e75f8b67630880c475f33
          untrusted/project_0/github.com/vexxhost/zuul-jobs:
            canonical_name: github.com/vexxhost/zuul-jobs
            checkout: main
            commit: a6e68243e02ef030ce5e75f8b67630880c475f33
          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: 9f5c1d680d573485f0ccdb18d2184d4f1d446419
          untrusted/project_3/github.com/vexxhost/atmosphere:
            canonical_name: github.com/vexxhost/atmosphere
            checkout: main
            commit: c112285bf56a1fb035a17e619036804879673465
          untrusted/project_4/opendev.org/openstack/openstack-helm:
            canonical_name: opendev.org/openstack/openstack-helm
            checkout: master
            commit: 105a735c5814af2b2ae40e0572c0aad0118061e8
        playbooks:
        - path: untrusted/project_3/github.com/vexxhost/atmosphere/molecule/csi/converge.yml
          roles:
          - checkout: main
            checkout_description: playbook branch
            link_name: ansible/playbook_0/role_0/atmosphere
            link_target: untrusted/project_3/github.com/vexxhost/atmosphere
            role_path: ansible/playbook_0/role_0/atmosphere/roles
          - checkout: master
            checkout_description: project default branch
            link_name: ansible/playbook_0/role_1/openstack-helm
            link_target: untrusted/project_4/opendev.org/openstack/openstack-helm
            role_path: ansible/playbook_0/role_1/openstack-helm/roles
          - checkout: master
            checkout_description: project default branch
            link_name: ansible/playbook_0/role_3/zuul-jobs
            link_target: untrusted/project_2/opendev.org/zuul/zuul-jobs
            role_path: ansible/playbook_0/role_3/zuul-jobs/roles
          - checkout: main
            checkout_description: zuul branch
            link_name: ansible/playbook_0/role_4/zuul-jobs
            link_target: untrusted/project_0/github.com/vexxhost/zuul-jobs
            role_path: ansible/playbook_0/role_4/zuul-jobs/roles
        - path: untrusted/project_3/github.com/vexxhost/atmosphere/test-playbooks/molecule/run.yml
          roles:
          - checkout: main
            checkout_description: playbook branch
            link_name: ansible/playbook_1/role_0/atmosphere
            link_target: untrusted/project_3/github.com/vexxhost/atmosphere
            role_path: ansible/playbook_1/role_0/atmosphere/roles
          - checkout: master
            checkout_description: project default branch
            link_name: ansible/playbook_1/role_1/openstack-helm
            link_target: untrusted/project_4/opendev.org/openstack/openstack-helm
            role_path: ansible/playbook_1/role_1/openstack-helm/roles
          - checkout: master
            checkout_description: project default branch
            link_name: ansible/playbook_1/role_3/zuul-jobs
            link_target: untrusted/project_2/opendev.org/zuul/zuul-jobs
            role_path: ansible/playbook_1/role_3/zuul-jobs/roles
          - checkout: main
            checkout_description: zuul branch
            link_name: ansible/playbook_1/role_4/zuul-jobs
            link_target: untrusted/project_0/github.com/vexxhost/zuul-jobs
            role_path: ansible/playbook_1/role_4/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/vexxhost/atmosphere:
          canonical_hostname: github.com
          canonical_name: github.com/vexxhost/atmosphere
          checkout: main
          checkout_description: zuul branch
          commit: c112285bf56a1fb035a17e619036804879673465
          name: vexxhost/atmosphere
          required: false
          short_name: atmosphere
          src_dir: src/github.com/vexxhost/atmosphere
      ref: refs/pull/3844/head
      resources: {}
      tenant: oss
      timeout: 1800
      topic: null
      voting: true
