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_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: 9278b40a-cca2-4877-89f6-55579ecffe9f
        host_id: 7b8a4cf3090e32af994f4889a62f1003a5f74592d8295d185d35c3b9
        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:fed4:eb93
        region: ca-ymq-1
        slot: null
      zuul_node:
        az: nova
        cloud: public
        external_id: 9278b40a-cca2-4877-89f6-55579ecffe9f
        host_id: 7b8a4cf3090e32af994f4889a62f1003a5f74592d8295d185d35c3b9
        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:fed4:eb93
        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: 2c49d34fb86e4e6290ebbd1697d8e64a
      build_refs:
      - branch: main
        change: '3834'
        change_message: "feat(deploy): add intra-component parallelism with pre-roles
          and optimize DAG dependencies\n\n## Summary\n\nBuilds on top of the parallel
          deploy orchestrator (#3818) to add **intra-component parallelism** via pre-roles
          and **optimize the DAG dependency graph**, further reducing critical-path
          deployment time.\n\n## Features\n\n### Intra-component parallelism with
          pre-roles\n\nIntroduces a `PreRoleName` field on `Component`, enabling independent
          tasks (e.g. image uploads, cert creation) to run **in parallel** with the
          main Helm deploy within a single component slot.\n\nThe deployer launches
          the pre-role and main role as concurrent `ansible-playbook` processes via
          `errgroup`. A `_pre_role_active: true` variable signals the main role to
          skip tasks already handled by the pre-role.\n\nApplied to two critical-path
          components:\n\n| Component | Pre-role tasks | Estimated savings |\n|-----------|---------------|-------------------|\n|
          **magnum** | Glance image uploads (~150s) | ~120\u2013150s (overlaps with
          Helm install) |\n| **octavia** | cert-manager Certificates + admin quota
          setup | ~15s |\n\n### DAG dependency optimization\n\nRemoves `octavia` from
          `magnum`'s dependency list. Magnum's Helm install only needs the octavia
          endpoint URL (a deterministic string from `openstack_helm_endpoints`), not
          a running octavia service. This lets magnum start after `barbican` + `heat`
          complete instead of waiting for `octavia`, saving ~4.5 min on the critical
          path.\n\n### Pre-role fixes\n\n- Add `openstack_helm_endpoints` role dependency
          to `octavia_pre` and `magnum_pre` (`meta/main.yml`)\n- Add `README.md` to
          pre-role directories (required by CI)\n- Add octavia TLS defaults (`octavia_tls_*`)
          to `octavia_pre/defaults/main.yml`\n- Add magnum image vars (`_magnum_images`)
          and format defaults to `magnum_pre`\n\n## Changed files\n\n| File | Change
          |\n|------|--------|\n| `internal/deploy/component.go` | Add `PreRoleName`
          field, remove magnum\u2192octavia dep |\n| `internal/deploy/deployer.go`
          | Parallel pre-role + main role execution via errgroup |\n| `internal/deploy/deployer_test.go`
          | Tests for pre-role playbook rendering |\n| `roles/magnum_pre/` | **New**
          \u2014 pre-role for image uploads |\n| `roles/magnum/tasks/main.yml` | Skip
          image uploads when `_pre_role_active` |\n| `roles/octavia_pre/` | **New**
          \u2014 pre-role for certs + quotas |\n| `roles/octavia/tasks/main.yml` |
          Skip cert/quota tasks when `_pre_role_active` |"
        change_url: https://github.com/vexxhost/atmosphere/pull/3834
        commit_id: 0bb3af2a7a2ea4173484240281445de249102a94
        patchset: 0bb3af2a7a2ea4173484240281445de249102a94
        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: 8e8d0034bcb64b46abba7147e8751f04
      buildset_refs:
      - branch: main
        change: '3834'
        change_message: "feat(deploy): add intra-component parallelism with pre-roles
          and optimize DAG dependencies\n\n## Summary\n\nBuilds on top of the parallel
          deploy orchestrator (#3818) to add **intra-component parallelism** via pre-roles
          and **optimize the DAG dependency graph**, further reducing critical-path
          deployment time.\n\n## Features\n\n### Intra-component parallelism with
          pre-roles\n\nIntroduces a `PreRoleName` field on `Component`, enabling independent
          tasks (e.g. image uploads, cert creation) to run **in parallel** with the
          main Helm deploy within a single component slot.\n\nThe deployer launches
          the pre-role and main role as concurrent `ansible-playbook` processes via
          `errgroup`. A `_pre_role_active: true` variable signals the main role to
          skip tasks already handled by the pre-role.\n\nApplied to two critical-path
          components:\n\n| Component | Pre-role tasks | Estimated savings |\n|-----------|---------------|-------------------|\n|
          **magnum** | Glance image uploads (~150s) | ~120\u2013150s (overlaps with
          Helm install) |\n| **octavia** | cert-manager Certificates + admin quota
          setup | ~15s |\n\n### DAG dependency optimization\n\nRemoves `octavia` from
          `magnum`'s dependency list. Magnum's Helm install only needs the octavia
          endpoint URL (a deterministic string from `openstack_helm_endpoints`), not
          a running octavia service. This lets magnum start after `barbican` + `heat`
          complete instead of waiting for `octavia`, saving ~4.5 min on the critical
          path.\n\n### Pre-role fixes\n\n- Add `openstack_helm_endpoints` role dependency
          to `octavia_pre` and `magnum_pre` (`meta/main.yml`)\n- Add `README.md` to
          pre-role directories (required by CI)\n- Add octavia TLS defaults (`octavia_tls_*`)
          to `octavia_pre/defaults/main.yml`\n- Add magnum image vars (`_magnum_images`)
          and format defaults to `magnum_pre`\n\n## Changed files\n\n| File | Change
          |\n|------|--------|\n| `internal/deploy/component.go` | Add `PreRoleName`
          field, remove magnum\u2192octavia dep |\n| `internal/deploy/deployer.go`
          | Parallel pre-role + main role execution via errgroup |\n| `internal/deploy/deployer_test.go`
          | Tests for pre-role playbook rendering |\n| `roles/magnum_pre/` | **New**
          \u2014 pre-role for image uploads |\n| `roles/magnum/tasks/main.yml` | Skip
          image uploads when `_pre_role_active` |\n| `roles/octavia_pre/` | **New**
          \u2014 pre-role for certs + quotas |\n| `roles/octavia/tasks/main.yml` |
          Skip cert/quota tasks when `_pre_role_active` |"
        change_url: https://github.com/vexxhost/atmosphere/pull/3834
        commit_id: 0bb3af2a7a2ea4173484240281445de249102a94
        patchset: 0bb3af2a7a2ea4173484240281445de249102a94
        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: '3834'
      change_message: "feat(deploy): add intra-component parallelism with pre-roles
        and optimize DAG dependencies\n\n## Summary\n\nBuilds on top of the parallel
        deploy orchestrator (#3818) to add **intra-component parallelism** via pre-roles
        and **optimize the DAG dependency graph**, further reducing critical-path
        deployment time.\n\n## Features\n\n### Intra-component parallelism with pre-roles\n\nIntroduces
        a `PreRoleName` field on `Component`, enabling independent tasks (e.g. image
        uploads, cert creation) to run **in parallel** with the main Helm deploy within
        a single component slot.\n\nThe deployer launches the pre-role and main role
        as concurrent `ansible-playbook` processes via `errgroup`. A `_pre_role_active:
        true` variable signals the main role to skip tasks already handled by the
        pre-role.\n\nApplied to two critical-path components:\n\n| Component | Pre-role
        tasks | Estimated savings |\n|-----------|---------------|-------------------|\n|
        **magnum** | Glance image uploads (~150s) | ~120\u2013150s (overlaps with
        Helm install) |\n| **octavia** | cert-manager Certificates + admin quota setup
        | ~15s |\n\n### DAG dependency optimization\n\nRemoves `octavia` from `magnum`'s
        dependency list. Magnum's Helm install only needs the octavia endpoint URL
        (a deterministic string from `openstack_helm_endpoints`), not a running octavia
        service. This lets magnum start after `barbican` + `heat` complete instead
        of waiting for `octavia`, saving ~4.5 min on the critical path.\n\n### Pre-role
        fixes\n\n- Add `openstack_helm_endpoints` role dependency to `octavia_pre`
        and `magnum_pre` (`meta/main.yml`)\n- Add `README.md` to pre-role directories
        (required by CI)\n- Add octavia TLS defaults (`octavia_tls_*`) to `octavia_pre/defaults/main.yml`\n-
        Add magnum image vars (`_magnum_images`) and format defaults to `magnum_pre`\n\n##
        Changed files\n\n| File | Change |\n|------|--------|\n| `internal/deploy/component.go`
        | Add `PreRoleName` field, remove magnum\u2192octavia dep |\n| `internal/deploy/deployer.go`
        | Parallel pre-role + main role execution via errgroup |\n| `internal/deploy/deployer_test.go`
        | Tests for pre-role playbook rendering |\n| `roles/magnum_pre/` | **New**
        \u2014 pre-role for image uploads |\n| `roles/magnum/tasks/main.yml` | Skip
        image uploads when `_pre_role_active` |\n| `roles/octavia_pre/` | **New**
        \u2014 pre-role for certs + quotas |\n| `roles/octavia/tasks/main.yml` | Skip
        cert/quota tasks when `_pre_role_active` |"
      change_url: https://github.com/vexxhost/atmosphere/pull/3834
      child_jobs: []
      commit_id: 0bb3af2a7a2ea4173484240281445de249102a94
      event_id: f7b13810-3a4f-11f1-99e9-d6428bfbb2d6
      executor:
        hostname: 0a8996d2b663
        inventory_file: /var/lib/zuul/builds/2c49d34fb86e4e6290ebbd1697d8e64a/ansible/inventory.yaml
        log_root: /var/lib/zuul/builds/2c49d34fb86e4e6290ebbd1697d8e64a/work/logs
        result_data_file: /var/lib/zuul/builds/2c49d34fb86e4e6290ebbd1697d8e64a/work/results.json
        src_root: /var/lib/zuul/builds/2c49d34fb86e4e6290ebbd1697d8e64a/work/src
        work_root: /var/lib/zuul/builds/2c49d34fb86e4e6290ebbd1697d8e64a/work
      include_vars: []
      items:
      - branch: main
        change: '3834'
        change_message: "feat(deploy): add intra-component parallelism with pre-roles
          and optimize DAG dependencies\n\n## Summary\n\nBuilds on top of the parallel
          deploy orchestrator (#3818) to add **intra-component parallelism** via pre-roles
          and **optimize the DAG dependency graph**, further reducing critical-path
          deployment time.\n\n## Features\n\n### Intra-component parallelism with
          pre-roles\n\nIntroduces a `PreRoleName` field on `Component`, enabling independent
          tasks (e.g. image uploads, cert creation) to run **in parallel** with the
          main Helm deploy within a single component slot.\n\nThe deployer launches
          the pre-role and main role as concurrent `ansible-playbook` processes via
          `errgroup`. A `_pre_role_active: true` variable signals the main role to
          skip tasks already handled by the pre-role.\n\nApplied to two critical-path
          components:\n\n| Component | Pre-role tasks | Estimated savings |\n|-----------|---------------|-------------------|\n|
          **magnum** | Glance image uploads (~150s) | ~120\u2013150s (overlaps with
          Helm install) |\n| **octavia** | cert-manager Certificates + admin quota
          setup | ~15s |\n\n### DAG dependency optimization\n\nRemoves `octavia` from
          `magnum`'s dependency list. Magnum's Helm install only needs the octavia
          endpoint URL (a deterministic string from `openstack_helm_endpoints`), not
          a running octavia service. This lets magnum start after `barbican` + `heat`
          complete instead of waiting for `octavia`, saving ~4.5 min on the critical
          path.\n\n### Pre-role fixes\n\n- Add `openstack_helm_endpoints` role dependency
          to `octavia_pre` and `magnum_pre` (`meta/main.yml`)\n- Add `README.md` to
          pre-role directories (required by CI)\n- Add octavia TLS defaults (`octavia_tls_*`)
          to `octavia_pre/defaults/main.yml`\n- Add magnum image vars (`_magnum_images`)
          and format defaults to `magnum_pre`\n\n## Changed files\n\n| File | Change
          |\n|------|--------|\n| `internal/deploy/component.go` | Add `PreRoleName`
          field, remove magnum\u2192octavia dep |\n| `internal/deploy/deployer.go`
          | Parallel pre-role + main role execution via errgroup |\n| `internal/deploy/deployer_test.go`
          | Tests for pre-role playbook rendering |\n| `roles/magnum_pre/` | **New**
          \u2014 pre-role for image uploads |\n| `roles/magnum/tasks/main.yml` | Skip
          image uploads when `_pre_role_active` |\n| `roles/octavia_pre/` | **New**
          \u2014 pre-role for certs + quotas |\n| `roles/octavia/tasks/main.yml` |
          Skip cert/quota tasks when `_pre_role_active` |"
        change_url: https://github.com/vexxhost/atmosphere/pull/3834
        commit_id: 0bb3af2a7a2ea4173484240281445de249102a94
        patchset: 0bb3af2a7a2ea4173484240281445de249102a94
        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: ZmVhdChkZXBsb3kpOiBhZGQgaW50cmEtY29tcG9uZW50IHBhcmFsbGVsaXNtIHdpdGggcHJlLXJvbGVzIGFuZCBvcHRpbWl6ZSBEQUcgZGVwZW5kZW5jaWVzCgojIyBTdW1tYXJ5CgpCdWlsZHMgb24gdG9wIG9mIHRoZSBwYXJhbGxlbCBkZXBsb3kgb3JjaGVzdHJhdG9yICgjMzgxOCkgdG8gYWRkICoqaW50cmEtY29tcG9uZW50IHBhcmFsbGVsaXNtKiogdmlhIHByZS1yb2xlcyBhbmQgKipvcHRpbWl6ZSB0aGUgREFHIGRlcGVuZGVuY3kgZ3JhcGgqKiwgZnVydGhlciByZWR1Y2luZyBjcml0aWNhbC1wYXRoIGRlcGxveW1lbnQgdGltZS4KCiMjIEZlYXR1cmVzCgojIyMgSW50cmEtY29tcG9uZW50IHBhcmFsbGVsaXNtIHdpdGggcHJlLXJvbGVzCgpJbnRyb2R1Y2VzIGEgYFByZVJvbGVOYW1lYCBmaWVsZCBvbiBgQ29tcG9uZW50YCwgZW5hYmxpbmcgaW5kZXBlbmRlbnQgdGFza3MgKGUuZy4gaW1hZ2UgdXBsb2FkcywgY2VydCBjcmVhdGlvbikgdG8gcnVuICoqaW4gcGFyYWxsZWwqKiB3aXRoIHRoZSBtYWluIEhlbG0gZGVwbG95IHdpdGhpbiBhIHNpbmdsZSBjb21wb25lbnQgc2xvdC4KClRoZSBkZXBsb3llciBsYXVuY2hlcyB0aGUgcHJlLXJvbGUgYW5kIG1haW4gcm9sZSBhcyBjb25jdXJyZW50IGBhbnNpYmxlLXBsYXlib29rYCBwcm9jZXNzZXMgdmlhIGBlcnJncm91cGAuIEEgYF9wcmVfcm9sZV9hY3RpdmU6IHRydWVgIHZhcmlhYmxlIHNpZ25hbHMgdGhlIG1haW4gcm9sZSB0byBza2lwIHRhc2tzIGFscmVhZHkgaGFuZGxlZCBieSB0aGUgcHJlLXJvbGUuCgpBcHBsaWVkIHRvIHR3byBjcml0aWNhbC1wYXRoIGNvbXBvbmVudHM6Cgp8IENvbXBvbmVudCB8IFByZS1yb2xlIHRhc2tzIHwgRXN0aW1hdGVkIHNhdmluZ3MgfAp8LS0tLS0tLS0tLS18LS0tLS0tLS0tLS0tLS0tfC0tLS0tLS0tLS0tLS0tLS0tLS18CnwgKiptYWdudW0qKiB8IEdsYW5jZSBpbWFnZSB1cGxvYWRzICh+MTUwcykgfCB+MTIw4oCTMTUwcyAob3ZlcmxhcHMgd2l0aCBIZWxtIGluc3RhbGwpIHwKfCAqKm9jdGF2aWEqKiB8IGNlcnQtbWFuYWdlciBDZXJ0aWZpY2F0ZXMgKyBhZG1pbiBxdW90YSBzZXR1cCB8IH4xNXMgfAoKIyMjIERBRyBkZXBlbmRlbmN5IG9wdGltaXphdGlvbgoKUmVtb3ZlcyBgb2N0YXZpYWAgZnJvbSBgbWFnbnVtYCdzIGRlcGVuZGVuY3kgbGlzdC4gTWFnbnVtJ3MgSGVsbSBpbnN0YWxsIG9ubHkgbmVlZHMgdGhlIG9jdGF2aWEgZW5kcG9pbnQgVVJMIChhIGRldGVybWluaXN0aWMgc3RyaW5nIGZyb20gYG9wZW5zdGFja19oZWxtX2VuZHBvaW50c2ApLCBub3QgYSBydW5uaW5nIG9jdGF2aWEgc2VydmljZS4gVGhpcyBsZXRzIG1hZ251bSBzdGFydCBhZnRlciBgYmFyYmljYW5gICsgYGhlYXRgIGNvbXBsZXRlIGluc3RlYWQgb2Ygd2FpdGluZyBmb3IgYG9jdGF2aWFgLCBzYXZpbmcgfjQuNSBtaW4gb24gdGhlIGNyaXRpY2FsIHBhdGguCgojIyMgUHJlLXJvbGUgZml4ZXMKCi0gQWRkIGBvcGVuc3RhY2tfaGVsbV9lbmRwb2ludHNgIHJvbGUgZGVwZW5kZW5jeSB0byBgb2N0YXZpYV9wcmVgIGFuZCBgbWFnbnVtX3ByZWAgKGBtZXRhL21haW4ueW1sYCkKLSBBZGQgYFJFQURNRS5tZGAgdG8gcHJlLXJvbGUgZGlyZWN0b3JpZXMgKHJlcXVpcmVkIGJ5IENJKQotIEFkZCBvY3RhdmlhIFRMUyBkZWZhdWx0cyAoYG9jdGF2aWFfdGxzXypgKSB0byBgb2N0YXZpYV9wcmUvZGVmYXVsdHMvbWFpbi55bWxgCi0gQWRkIG1hZ251bSBpbWFnZSB2YXJzIChgX21hZ251bV9pbWFnZXNgKSBhbmQgZm9ybWF0IGRlZmF1bHRzIHRvIGBtYWdudW1fcHJlYAoKIyMgQ2hhbmdlZCBmaWxlcwoKfCBGaWxlIHwgQ2hhbmdlIHwKfC0tLS0tLXwtLS0tLS0tLXwKfCBgaW50ZXJuYWwvZGVwbG95L2NvbXBvbmVudC5nb2AgfCBBZGQgYFByZVJvbGVOYW1lYCBmaWVsZCwgcmVtb3ZlIG1hZ251beKGkm9jdGF2aWEgZGVwIHwKfCBgaW50ZXJuYWwvZGVwbG95L2RlcGxveWVyLmdvYCB8IFBhcmFsbGVsIHByZS1yb2xlICsgbWFpbiByb2xlIGV4ZWN1dGlvbiB2aWEgZXJyZ3JvdXAgfAp8IGBpbnRlcm5hbC9kZXBsb3kvZGVwbG95ZXJfdGVzdC5nb2AgfCBUZXN0cyBmb3IgcHJlLXJvbGUgcGxheWJvb2sgcmVuZGVyaW5nIHwKfCBgcm9sZXMvbWFnbnVtX3ByZS9gIHwgKipOZXcqKiDigJQgcHJlLXJvbGUgZm9yIGltYWdlIHVwbG9hZHMgfAp8IGByb2xlcy9tYWdudW0vdGFza3MvbWFpbi55bWxgIHwgU2tpcCBpbWFnZSB1cGxvYWRzIHdoZW4gYF9wcmVfcm9sZV9hY3RpdmVgIHwKfCBgcm9sZXMvb2N0YXZpYV9wcmUvYCB8ICoqTmV3Kiog4oCUIHByZS1yb2xlIGZvciBjZXJ0cyArIHF1b3RhcyB8CnwgYHJvbGVzL29jdGF2aWEvdGFza3MvbWFpbi55bWxgIHwgU2tpcCBjZXJ0L3F1b3RhIHRhc2tzIHdoZW4gYF9wcmVfcm9sZV9hY3RpdmVgIHw=
      patchset: 0bb3af2a7a2ea4173484240281445de249102a94
      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: fc4af6d44718d2e648cf6396f3e96bb46a55117a
          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: fc4af6d44718d2e648cf6396f3e96bb46a55117a
          untrusted/project_3/github.com/vexxhost/atmosphere:
            canonical_name: github.com/vexxhost/atmosphere
            checkout: main
            commit: 0bb3af2a7a2ea4173484240281445de249102a94
          untrusted/project_4/opendev.org/openstack/openstack-helm:
            canonical_name: opendev.org/openstack/openstack-helm
            checkout: master
            commit: c665eedfa3ae1b76a7e8438fffcb62aefaa30a46
        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: 0bb3af2a7a2ea4173484240281445de249102a94
          name: vexxhost/atmosphere
          required: false
          short_name: atmosphere
          src_dir: src/github.com/vexxhost/atmosphere
      ref: refs/pull/3834/head
      resources: {}
      tenant: oss
      timeout: 1800
      topic: null
      voting: true
