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.229
      ansible_port: 22
      ansible_python_interpreter: auto
      ansible_user: zuul
      atmosphere_deploy_tags: kubernetes,csi,cert-manager,cluster-issuer,ingress-nginx,rabbitmq-cluster-operator,percona-xtradb-cluster-operator,percona-xtradb-cluster,valkey,memcached,keycloak,kube-prometheus-stack,keystone,horizon
      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
      cluster_issuer_type: self-signed
      csi_driver: local-path-provisioner
      ingress_nginx_helm_values:
        controller:
          config:
            worker-processes: 2
      keystone_helm_values:
        pod:
          replicas:
            api: 1
      kube_vip_address: 172.17.0.100
      kube_vip_interface: '{{ ansible_facts[''default_ipv4''].interface }}'
      kubernetes_hostname: '{{ ansible_facts[''default_ipv4''].address }}'
      molecule_scenario: keycloak
      nodepool:
        az: nova
        cloud: public
        external_id: 585e4ad8-f595-496a-b569-7c72b1df9c53
        host_id: c9670958829e9c96e47d452d2c9c4ce9edaac336d3dbc4a3c4ec531c
        interface_ip: 199.204.45.229
        label: ubuntu-jammy
        node_properties: {}
        private_ipv4: 199.204.45.229
        private_ipv6: null
        provider: yul1
        public_ipv4: 199.204.45.229
        public_ipv6: 2604:e100:1:0:f816:3eff:fee1:3fa5
        region: ca-ymq-1
        slot: null
      percona_xtradb_cluster_spec:
        allowUnsafeConfigurations: true
        haproxy:
          size: 1
        pxc:
          size: 1
      zuul_node:
        az: nova
        cloud: public
        external_id: 585e4ad8-f595-496a-b569-7c72b1df9c53
        host_id: c9670958829e9c96e47d452d2c9c4ce9edaac336d3dbc4a3c4ec531c
        interface_ip: 199.204.45.229
        label: ubuntu-jammy
        node_properties: {}
        private_ipv4: 199.204.45.229
        private_ipv6: null
        provider: yul1
        public_ipv4: 199.204.45.229
        public_ipv6: 2604:e100:1:0:f816:3eff:fee1:3fa5
        region: ca-ymq-1
        slot: null
        uuid: null
  vars:
    atmosphere_deploy_tags: kubernetes,csi,cert-manager,cluster-issuer,ingress-nginx,rabbitmq-cluster-operator,percona-xtradb-cluster-operator,percona-xtradb-cluster,valkey,memcached,keycloak,kube-prometheus-stack,keystone,horizon
    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
    cluster_issuer_type: self-signed
    csi_driver: local-path-provisioner
    ingress_nginx_helm_values:
      controller:
        config:
          worker-processes: 2
    keystone_helm_values:
      pod:
        replicas:
          api: 1
    kube_vip_address: 172.17.0.100
    kube_vip_interface: '{{ ansible_facts[''default_ipv4''].interface }}'
    kubernetes_hostname: '{{ ansible_facts[''default_ipv4''].address }}'
    molecule_scenario: keycloak
    percona_xtradb_cluster_spec:
      allowUnsafeConfigurations: true
      haproxy:
        size: 1
      pxc:
        size: 1
    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#34>'
      - '<Job atmosphere-molecule-keycloak explicit: None implied: {MatchAny:{ImpliedBranchMatcher:main}}
        source: vexxhost/atmosphere/.zuul.yaml@main#298>'
      - '<Job atmosphere-molecule-keycloak explicit: None implied: None source: vexxhost/atmosphere/.zuul.yaml@main#324>'
      ansible_version: '9'
      attempts: 1
      branch: main
      build: 4fa0575f26c946f2a7278408f745e781
      build_refs:
      - branch: main
        change: '3877'
        change_message: "refactor(roles): dedupe *_pre tasks via shared tasks/_pre.yml\n\nStacked
          on top of #3818 (parallel deploy orchestrator). Targets `main`; once #3818
          lands, the diff here will collapse to just the dedup commits.\n\n## Problem\n\nPR
          #3818 introduced four `*_pre` roles (`keystone_pre`, `neutron_pre`, `octavia_pre`,
          `magnum_pre`) that run concurrently with their main role under the parallel
          deploy orchestrator. Each `*_pre` role contained a verbatim copy of a subset
          of tasks from the main role; the main role re-declared the same tasks gated
          by `when: not (_pre_role_active | default(false))`. Two copies had to be
          kept in sync by hand and were already showing drift (`Unfortuantely` typo
          in `octavia/tasks/main.yml` not present in `octavia_pre`).\n\n## Approach\n\nFor
          each service `<svc>` with a pre-role:\n\n1. Move the duplicated task bodies
          into `roles/<svc>/tasks/_pre.yml` inside the **main** role.\n2. The main
          role's `tasks/main.yml` replaces the gated blocks with a single import:\n
          \  ```yaml\n   - name: Run parallelizable pre-tasks (sequential mode only)\n
          \    ansible.builtin.import_tasks: _pre.yml\n     when: not (_pre_role_active
          | default(false))\n   ```\n3. `roles/<svc>_pre/tasks/main.yml` becomes a
          thin shim:\n   ```yaml\n   - name: Run parallelizable <svc> tasks\n     ansible.builtin.include_role:\n
          \      name: vexxhost.atmosphere.<svc>\n       tasks_from: _pre.yml\n   ```\n\nNo
          orchestrator Go changes \u2014 the `PreRoleName` mechanism in `internal/deploy/component.go`
          is unchanged.\n\n## Commits\n\n| Commit | Service | Tasks deduped |\n|---|---|---:|\n|
          `refactor(magnum)` | magnum / magnum_pre | 1 |\n| `refactor(neutron)` |
          neutron / neutron_pre | 5 (drops a redundant `openstack_helm_endpoints`
          include already covered by `meta/main.yml`) |\n| `refactor(octavia)` | octavia
          / octavia_pre | 3 (also fixes the `Unfortuantely` typo drift) |\n| `refactor(keystone)`
          | keystone / keystone_pre | 5 |\n| `doc(reno)` | release note | \u2014 |\n\nNet:
          ~270 lines of duplicated YAML collapse into one source of truth + 4 thin
          shims.\n\n## Validation\n\n- All YAML parses cleanly.\n- Behaviour is unchanged
          in both sequential (`playbooks/site.yml`) and parallel (`./bin/atmosphere
          deploy`) modes \u2014 verified by inspection of the orchestrator gate in
          `internal/deploy/deployer.go` which sets `_pre_role_active: true` only when
          running the main role of a component that has a `PreRoleName`.\n- Zuul molecule
          scenarios `aio-ovn`, `aio-openvswitch`, `keycloak` and `csi-*` exercise
          both code paths end-to-end.\n\nCloses the dedup follow-up agreed for #3818.\n\nCo-authored-by:
          Copilot <223556219+Copilot@users.noreply.github.com>\n"
        change_url: https://github.com/vexxhost/atmosphere/pull/3877
        commit_id: 83eb006f2fbad67b601cf0995c2d8b86d50d39a3
        patchset: 83eb006f2fbad67b601cf0995c2d8b86d50d39a3
        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: ecd50d99a03f4cebbc84901010a178b0
      buildset_refs:
      - branch: main
        change: '3877'
        change_message: "refactor(roles): dedupe *_pre tasks via shared tasks/_pre.yml\n\nStacked
          on top of #3818 (parallel deploy orchestrator). Targets `main`; once #3818
          lands, the diff here will collapse to just the dedup commits.\n\n## Problem\n\nPR
          #3818 introduced four `*_pre` roles (`keystone_pre`, `neutron_pre`, `octavia_pre`,
          `magnum_pre`) that run concurrently with their main role under the parallel
          deploy orchestrator. Each `*_pre` role contained a verbatim copy of a subset
          of tasks from the main role; the main role re-declared the same tasks gated
          by `when: not (_pre_role_active | default(false))`. Two copies had to be
          kept in sync by hand and were already showing drift (`Unfortuantely` typo
          in `octavia/tasks/main.yml` not present in `octavia_pre`).\n\n## Approach\n\nFor
          each service `<svc>` with a pre-role:\n\n1. Move the duplicated task bodies
          into `roles/<svc>/tasks/_pre.yml` inside the **main** role.\n2. The main
          role's `tasks/main.yml` replaces the gated blocks with a single import:\n
          \  ```yaml\n   - name: Run parallelizable pre-tasks (sequential mode only)\n
          \    ansible.builtin.import_tasks: _pre.yml\n     when: not (_pre_role_active
          | default(false))\n   ```\n3. `roles/<svc>_pre/tasks/main.yml` becomes a
          thin shim:\n   ```yaml\n   - name: Run parallelizable <svc> tasks\n     ansible.builtin.include_role:\n
          \      name: vexxhost.atmosphere.<svc>\n       tasks_from: _pre.yml\n   ```\n\nNo
          orchestrator Go changes \u2014 the `PreRoleName` mechanism in `internal/deploy/component.go`
          is unchanged.\n\n## Commits\n\n| Commit | Service | Tasks deduped |\n|---|---|---:|\n|
          `refactor(magnum)` | magnum / magnum_pre | 1 |\n| `refactor(neutron)` |
          neutron / neutron_pre | 5 (drops a redundant `openstack_helm_endpoints`
          include already covered by `meta/main.yml`) |\n| `refactor(octavia)` | octavia
          / octavia_pre | 3 (also fixes the `Unfortuantely` typo drift) |\n| `refactor(keystone)`
          | keystone / keystone_pre | 5 |\n| `doc(reno)` | release note | \u2014 |\n\nNet:
          ~270 lines of duplicated YAML collapse into one source of truth + 4 thin
          shims.\n\n## Validation\n\n- All YAML parses cleanly.\n- Behaviour is unchanged
          in both sequential (`playbooks/site.yml`) and parallel (`./bin/atmosphere
          deploy`) modes \u2014 verified by inspection of the orchestrator gate in
          `internal/deploy/deployer.go` which sets `_pre_role_active: true` only when
          running the main role of a component that has a `PreRoleName`.\n- Zuul molecule
          scenarios `aio-ovn`, `aio-openvswitch`, `keycloak` and `csi-*` exercise
          both code paths end-to-end.\n\nCloses the dedup follow-up agreed for #3818.\n\nCo-authored-by:
          Copilot <223556219+Copilot@users.noreply.github.com>\n"
        change_url: https://github.com/vexxhost/atmosphere/pull/3877
        commit_id: 83eb006f2fbad67b601cf0995c2d8b86d50d39a3
        patchset: 83eb006f2fbad67b601cf0995c2d8b86d50d39a3
        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: '3877'
      change_message: "refactor(roles): dedupe *_pre tasks via shared tasks/_pre.yml\n\nStacked
        on top of #3818 (parallel deploy orchestrator). Targets `main`; once #3818
        lands, the diff here will collapse to just the dedup commits.\n\n## Problem\n\nPR
        #3818 introduced four `*_pre` roles (`keystone_pre`, `neutron_pre`, `octavia_pre`,
        `magnum_pre`) that run concurrently with their main role under the parallel
        deploy orchestrator. Each `*_pre` role contained a verbatim copy of a subset
        of tasks from the main role; the main role re-declared the same tasks gated
        by `when: not (_pre_role_active | default(false))`. Two copies had to be kept
        in sync by hand and were already showing drift (`Unfortuantely` typo in `octavia/tasks/main.yml`
        not present in `octavia_pre`).\n\n## Approach\n\nFor each service `<svc>`
        with a pre-role:\n\n1. Move the duplicated task bodies into `roles/<svc>/tasks/_pre.yml`
        inside the **main** role.\n2. The main role's `tasks/main.yml` replaces the
        gated blocks with a single import:\n   ```yaml\n   - name: Run parallelizable
        pre-tasks (sequential mode only)\n     ansible.builtin.import_tasks: _pre.yml\n
        \    when: not (_pre_role_active | default(false))\n   ```\n3. `roles/<svc>_pre/tasks/main.yml`
        becomes a thin shim:\n   ```yaml\n   - name: Run parallelizable <svc> tasks\n
        \    ansible.builtin.include_role:\n       name: vexxhost.atmosphere.<svc>\n
        \      tasks_from: _pre.yml\n   ```\n\nNo orchestrator Go changes \u2014 the
        `PreRoleName` mechanism in `internal/deploy/component.go` is unchanged.\n\n##
        Commits\n\n| Commit | Service | Tasks deduped |\n|---|---|---:|\n| `refactor(magnum)`
        | magnum / magnum_pre | 1 |\n| `refactor(neutron)` | neutron / neutron_pre
        | 5 (drops a redundant `openstack_helm_endpoints` include already covered
        by `meta/main.yml`) |\n| `refactor(octavia)` | octavia / octavia_pre | 3 (also
        fixes the `Unfortuantely` typo drift) |\n| `refactor(keystone)` | keystone
        / keystone_pre | 5 |\n| `doc(reno)` | release note | \u2014 |\n\nNet: ~270
        lines of duplicated YAML collapse into one source of truth + 4 thin shims.\n\n##
        Validation\n\n- All YAML parses cleanly.\n- Behaviour is unchanged in both
        sequential (`playbooks/site.yml`) and parallel (`./bin/atmosphere deploy`)
        modes \u2014 verified by inspection of the orchestrator gate in `internal/deploy/deployer.go`
        which sets `_pre_role_active: true` only when running the main role of a component
        that has a `PreRoleName`.\n- Zuul molecule scenarios `aio-ovn`, `aio-openvswitch`,
        `keycloak` and `csi-*` exercise both code paths end-to-end.\n\nCloses the
        dedup follow-up agreed for #3818.\n\nCo-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>\n"
      change_url: https://github.com/vexxhost/atmosphere/pull/3877
      child_jobs: []
      commit_id: 83eb006f2fbad67b601cf0995c2d8b86d50d39a3
      event_id: bf7b3be0-42be-11f1-9d45-17d2d2c890dc
      executor:
        hostname: 0a8996d2b663
        inventory_file: /var/lib/zuul/builds/4fa0575f26c946f2a7278408f745e781/ansible/inventory.yaml
        log_root: /var/lib/zuul/builds/4fa0575f26c946f2a7278408f745e781/work/logs
        result_data_file: /var/lib/zuul/builds/4fa0575f26c946f2a7278408f745e781/work/results.json
        src_root: /var/lib/zuul/builds/4fa0575f26c946f2a7278408f745e781/work/src
        work_root: /var/lib/zuul/builds/4fa0575f26c946f2a7278408f745e781/work
      include_vars: []
      items:
      - branch: main
        change: '3877'
        change_message: "refactor(roles): dedupe *_pre tasks via shared tasks/_pre.yml\n\nStacked
          on top of #3818 (parallel deploy orchestrator). Targets `main`; once #3818
          lands, the diff here will collapse to just the dedup commits.\n\n## Problem\n\nPR
          #3818 introduced four `*_pre` roles (`keystone_pre`, `neutron_pre`, `octavia_pre`,
          `magnum_pre`) that run concurrently with their main role under the parallel
          deploy orchestrator. Each `*_pre` role contained a verbatim copy of a subset
          of tasks from the main role; the main role re-declared the same tasks gated
          by `when: not (_pre_role_active | default(false))`. Two copies had to be
          kept in sync by hand and were already showing drift (`Unfortuantely` typo
          in `octavia/tasks/main.yml` not present in `octavia_pre`).\n\n## Approach\n\nFor
          each service `<svc>` with a pre-role:\n\n1. Move the duplicated task bodies
          into `roles/<svc>/tasks/_pre.yml` inside the **main** role.\n2. The main
          role's `tasks/main.yml` replaces the gated blocks with a single import:\n
          \  ```yaml\n   - name: Run parallelizable pre-tasks (sequential mode only)\n
          \    ansible.builtin.import_tasks: _pre.yml\n     when: not (_pre_role_active
          | default(false))\n   ```\n3. `roles/<svc>_pre/tasks/main.yml` becomes a
          thin shim:\n   ```yaml\n   - name: Run parallelizable <svc> tasks\n     ansible.builtin.include_role:\n
          \      name: vexxhost.atmosphere.<svc>\n       tasks_from: _pre.yml\n   ```\n\nNo
          orchestrator Go changes \u2014 the `PreRoleName` mechanism in `internal/deploy/component.go`
          is unchanged.\n\n## Commits\n\n| Commit | Service | Tasks deduped |\n|---|---|---:|\n|
          `refactor(magnum)` | magnum / magnum_pre | 1 |\n| `refactor(neutron)` |
          neutron / neutron_pre | 5 (drops a redundant `openstack_helm_endpoints`
          include already covered by `meta/main.yml`) |\n| `refactor(octavia)` | octavia
          / octavia_pre | 3 (also fixes the `Unfortuantely` typo drift) |\n| `refactor(keystone)`
          | keystone / keystone_pre | 5 |\n| `doc(reno)` | release note | \u2014 |\n\nNet:
          ~270 lines of duplicated YAML collapse into one source of truth + 4 thin
          shims.\n\n## Validation\n\n- All YAML parses cleanly.\n- Behaviour is unchanged
          in both sequential (`playbooks/site.yml`) and parallel (`./bin/atmosphere
          deploy`) modes \u2014 verified by inspection of the orchestrator gate in
          `internal/deploy/deployer.go` which sets `_pre_role_active: true` only when
          running the main role of a component that has a `PreRoleName`.\n- Zuul molecule
          scenarios `aio-ovn`, `aio-openvswitch`, `keycloak` and `csi-*` exercise
          both code paths end-to-end.\n\nCloses the dedup follow-up agreed for #3818.\n\nCo-authored-by:
          Copilot <223556219+Copilot@users.noreply.github.com>\n"
        change_url: https://github.com/vexxhost/atmosphere/pull/3877
        commit_id: 83eb006f2fbad67b601cf0995c2d8b86d50d39a3
        patchset: 83eb006f2fbad67b601cf0995c2d8b86d50d39a3
        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-keycloak
      jobtags: []
      max_attempts: 3
      message: cmVmYWN0b3Iocm9sZXMpOiBkZWR1cGUgKl9wcmUgdGFza3MgdmlhIHNoYXJlZCB0YXNrcy9fcHJlLnltbAoKU3RhY2tlZCBvbiB0b3Agb2YgIzM4MTggKHBhcmFsbGVsIGRlcGxveSBvcmNoZXN0cmF0b3IpLiBUYXJnZXRzIGBtYWluYDsgb25jZSAjMzgxOCBsYW5kcywgdGhlIGRpZmYgaGVyZSB3aWxsIGNvbGxhcHNlIHRvIGp1c3QgdGhlIGRlZHVwIGNvbW1pdHMuCgojIyBQcm9ibGVtCgpQUiAjMzgxOCBpbnRyb2R1Y2VkIGZvdXIgYCpfcHJlYCByb2xlcyAoYGtleXN0b25lX3ByZWAsIGBuZXV0cm9uX3ByZWAsIGBvY3RhdmlhX3ByZWAsIGBtYWdudW1fcHJlYCkgdGhhdCBydW4gY29uY3VycmVudGx5IHdpdGggdGhlaXIgbWFpbiByb2xlIHVuZGVyIHRoZSBwYXJhbGxlbCBkZXBsb3kgb3JjaGVzdHJhdG9yLiBFYWNoIGAqX3ByZWAgcm9sZSBjb250YWluZWQgYSB2ZXJiYXRpbSBjb3B5IG9mIGEgc3Vic2V0IG9mIHRhc2tzIGZyb20gdGhlIG1haW4gcm9sZTsgdGhlIG1haW4gcm9sZSByZS1kZWNsYXJlZCB0aGUgc2FtZSB0YXNrcyBnYXRlZCBieSBgd2hlbjogbm90IChfcHJlX3JvbGVfYWN0aXZlIHwgZGVmYXVsdChmYWxzZSkpYC4gVHdvIGNvcGllcyBoYWQgdG8gYmUga2VwdCBpbiBzeW5jIGJ5IGhhbmQgYW5kIHdlcmUgYWxyZWFkeSBzaG93aW5nIGRyaWZ0IChgVW5mb3J0dWFudGVseWAgdHlwbyBpbiBgb2N0YXZpYS90YXNrcy9tYWluLnltbGAgbm90IHByZXNlbnQgaW4gYG9jdGF2aWFfcHJlYCkuCgojIyBBcHByb2FjaAoKRm9yIGVhY2ggc2VydmljZSBgPHN2Yz5gIHdpdGggYSBwcmUtcm9sZToKCjEuIE1vdmUgdGhlIGR1cGxpY2F0ZWQgdGFzayBib2RpZXMgaW50byBgcm9sZXMvPHN2Yz4vdGFza3MvX3ByZS55bWxgIGluc2lkZSB0aGUgKiptYWluKiogcm9sZS4KMi4gVGhlIG1haW4gcm9sZSdzIGB0YXNrcy9tYWluLnltbGAgcmVwbGFjZXMgdGhlIGdhdGVkIGJsb2NrcyB3aXRoIGEgc2luZ2xlIGltcG9ydDoKICAgYGBgeWFtbAogICAtIG5hbWU6IFJ1biBwYXJhbGxlbGl6YWJsZSBwcmUtdGFza3MgKHNlcXVlbnRpYWwgbW9kZSBvbmx5KQogICAgIGFuc2libGUuYnVpbHRpbi5pbXBvcnRfdGFza3M6IF9wcmUueW1sCiAgICAgd2hlbjogbm90IChfcHJlX3JvbGVfYWN0aXZlIHwgZGVmYXVsdChmYWxzZSkpCiAgIGBgYAozLiBgcm9sZXMvPHN2Yz5fcHJlL3Rhc2tzL21haW4ueW1sYCBiZWNvbWVzIGEgdGhpbiBzaGltOgogICBgYGB5YW1sCiAgIC0gbmFtZTogUnVuIHBhcmFsbGVsaXphYmxlIDxzdmM+IHRhc2tzCiAgICAgYW5zaWJsZS5idWlsdGluLmluY2x1ZGVfcm9sZToKICAgICAgIG5hbWU6IHZleHhob3N0LmF0bW9zcGhlcmUuPHN2Yz4KICAgICAgIHRhc2tzX2Zyb206IF9wcmUueW1sCiAgIGBgYAoKTm8gb3JjaGVzdHJhdG9yIEdvIGNoYW5nZXMg4oCUIHRoZSBgUHJlUm9sZU5hbWVgIG1lY2hhbmlzbSBpbiBgaW50ZXJuYWwvZGVwbG95L2NvbXBvbmVudC5nb2AgaXMgdW5jaGFuZ2VkLgoKIyMgQ29tbWl0cwoKfCBDb21taXQgfCBTZXJ2aWNlIHwgVGFza3MgZGVkdXBlZCB8CnwtLS18LS0tfC0tLTp8CnwgYHJlZmFjdG9yKG1hZ251bSlgIHwgbWFnbnVtIC8gbWFnbnVtX3ByZSB8IDEgfAp8IGByZWZhY3RvcihuZXV0cm9uKWAgfCBuZXV0cm9uIC8gbmV1dHJvbl9wcmUgfCA1IChkcm9wcyBhIHJlZHVuZGFudCBgb3BlbnN0YWNrX2hlbG1fZW5kcG9pbnRzYCBpbmNsdWRlIGFscmVhZHkgY292ZXJlZCBieSBgbWV0YS9tYWluLnltbGApIHwKfCBgcmVmYWN0b3Iob2N0YXZpYSlgIHwgb2N0YXZpYSAvIG9jdGF2aWFfcHJlIHwgMyAoYWxzbyBmaXhlcyB0aGUgYFVuZm9ydHVhbnRlbHlgIHR5cG8gZHJpZnQpIHwKfCBgcmVmYWN0b3Ioa2V5c3RvbmUpYCB8IGtleXN0b25lIC8ga2V5c3RvbmVfcHJlIHwgNSB8CnwgYGRvYyhyZW5vKWAgfCByZWxlYXNlIG5vdGUgfCDigJQgfAoKTmV0OiB+MjcwIGxpbmVzIG9mIGR1cGxpY2F0ZWQgWUFNTCBjb2xsYXBzZSBpbnRvIG9uZSBzb3VyY2Ugb2YgdHJ1dGggKyA0IHRoaW4gc2hpbXMuCgojIyBWYWxpZGF0aW9uCgotIEFsbCBZQU1MIHBhcnNlcyBjbGVhbmx5LgotIEJlaGF2aW91ciBpcyB1bmNoYW5nZWQgaW4gYm90aCBzZXF1ZW50aWFsIChgcGxheWJvb2tzL3NpdGUueW1sYCkgYW5kIHBhcmFsbGVsIChgLi9iaW4vYXRtb3NwaGVyZSBkZXBsb3lgKSBtb2RlcyDigJQgdmVyaWZpZWQgYnkgaW5zcGVjdGlvbiBvZiB0aGUgb3JjaGVzdHJhdG9yIGdhdGUgaW4gYGludGVybmFsL2RlcGxveS9kZXBsb3llci5nb2Agd2hpY2ggc2V0cyBgX3ByZV9yb2xlX2FjdGl2ZTogdHJ1ZWAgb25seSB3aGVuIHJ1bm5pbmcgdGhlIG1haW4gcm9sZSBvZiBhIGNvbXBvbmVudCB0aGF0IGhhcyBhIGBQcmVSb2xlTmFtZWAuCi0gWnV1bCBtb2xlY3VsZSBzY2VuYXJpb3MgYGFpby1vdm5gLCBgYWlvLW9wZW52c3dpdGNoYCwgYGtleWNsb2FrYCBhbmQgYGNzaS0qYCBleGVyY2lzZSBib3RoIGNvZGUgcGF0aHMgZW5kLXRvLWVuZC4KCkNsb3NlcyB0aGUgZGVkdXAgZm9sbG93LXVwIGFncmVlZCBmb3IgIzM4MTguCgpDby1hdXRob3JlZC1ieTogQ29waWxvdCA8MjIzNTU2MjE5K0NvcGlsb3RAdXNlcnMubm9yZXBseS5naXRodWIuY29tPgo=
      patchset: 83eb006f2fbad67b601cf0995c2d8b86d50d39a3
      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: 83eb006f2fbad67b601cf0995c2d8b86d50d39a3
          untrusted/project_4/opendev.org/openstack/openstack-helm:
            canonical_name: opendev.org/openstack/openstack-helm
            checkout: master
            commit: 4d5267170d82791cf249843da757249e4124aa85
        playbooks:
        - path: untrusted/project_3/github.com/vexxhost/atmosphere/molecule/keycloak/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: 83eb006f2fbad67b601cf0995c2d8b86d50d39a3
          name: vexxhost/atmosphere
          required: false
          short_name: atmosphere
          src_dir: src/github.com/vexxhost/atmosphere
      ref: refs/pull/3877/head
      resources: {}
      tenant: oss
      timeout: 1800
      topic: null
      voting: true
