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.144
      ansible_port: 22
      ansible_python_interpreter: auto
      ansible_user: zuul
      atmosphere_image_prefix: harbor.atmosphere.dev/
      atmosphere_network_backend: openvswitch
      barbican_helm_values:
        pod:
          replicas:
            api: 1
      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) }}'
      ceph_version: 18.2.7
      cilium_helm_values:
        operator:
          replicas: 1
      cinder_helm_values:
        conf:
          ceph:
            pools:
              backup:
                replication: 1
              cinder.volumes:
                replication: 1
          cinder:
            DEFAULT:
              osapi_volume_workers: 2
        pod:
          replicas:
            api: 1
            scheduler: 1
      cluster_issuer_type: self-signed
      coredns_helm_values:
        replicaCount: 1
      csi_driver: local-path-provisioner
      glance_helm_values:
        conf:
          glance:
            DEFAULT:
              workers: 2
            glance_store:
              rbd_store_replication: 1
        pod:
          replicas:
            api: 1
      glance_images:
      - container_format: bare
        disk_format: raw
        is_public: true
        min_disk: 1
        name: cirros
        url: http://download.cirros-cloud.net/0.6.2/cirros-0.6.2-x86_64-disk.img
      heat_helm_values:
        conf:
          heat:
            DEFAULT:
              num_engine_workers: 2
            heat_api:
              workers: 2
            heat_api_cfn:
              workers: 2
            heat_api_cloudwatch:
              workers: 2
        pod:
          replicas:
            api: 1
            cfn: 1
            cloudwatch: 1
            engine: 1
      horizon_helm_values:
        pod:
          replicas:
            server: 1
      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 }}'
      kubernetes_keepalived_interface: br-mgmt
      magnum_helm_values:
        conf:
          magnum:
            api:
              workers: 2
            conductor:
              workers: 2
        pod:
          replicas:
            api: 1
            conductor: 1
      magnum_image_disk_format: qcow2
      magnum_images: '[ {{ _magnum_images[-1] }} ]'
      manila_helm_values:
        conf:
          manila:
            DEFAULT:
              osapi_share_workers: 2
        pod:
          replicas:
            api: 1
            scheduler: 1
      molecule_scenario: aio
      neutron_helm_values:
        conf:
          neutron:
            DEFAULT:
              api_workers: 2
              metadata_workers: 2
              rpc_workers: 2
        pod:
          replicas:
            rpc_server: 1
            server: 1
      nodepool:
        az: nova
        cloud: public
        external_id: 0835b9d6-fd2e-458a-9617-8ba3951b227b
        host_id: fe6a549c934f5f67345b1bd07db2b4711c0ee4717d98054273574436
        interface_ip: 199.204.45.144
        label: ubuntu-jammy-16
        node_properties: {}
        private_ipv4: 199.204.45.144
        private_ipv6: null
        provider: yul1
        public_ipv4: 199.204.45.144
        public_ipv6: 2604:e100:1:0:f816:3eff:fe4e:43
        region: ca-ymq-1
        slot: null
      nova_helm_values:
        conf:
          nova:
            DEFAULT:
              metadata_workers: 2
              osapi_compute_workers: 2
            conductor:
              workers: 2
            scheduler:
              workers: 2
        pod:
          replicas:
            api_metadata: 1
            conductor: 1
            novncproxy: 1
            osapi: 1
            scheduler: 1
            spiceproxy: 1
      octavia_helm_values:
        conf:
          octavia:
            controller_worker:
              workers: 2
          octavia_api_uwsgi:
            uwsgi:
              processes: 2
        pod:
          replicas:
            api: 1
            housekeeping: 1
            worker: 1
      ovn_helm_values:
        conf:
          auto_bridge_add:
            br-ex: null
        pod:
          replicas:
            ovn_northd: 1
            ovn_ovsdb_nb: 1
            ovn_ovsdb_sb: 1
      percona_xtradb_cluster_spec:
        allowUnsafeConfigurations: true
        haproxy:
          size: 1
        pxc:
          size: 1
      placement_helm_values:
        conf:
          placement_api_uwsgi:
            uwsgi:
              processes: 2
        pod:
          replicas:
            api: 1
      rook_ceph_cluster_radosgw_spec:
        dataPool:
          failureDomain: osd
        gateway:
          instances: 1
        metadataPool:
          failureDomain: osd
      staffeln_helm_values:
        pod:
          replicas:
            api: 1
            conductor: 1
      valkey_helm_values:
        replica:
          replicaCount: 1
      zuul_node:
        az: nova
        cloud: public
        external_id: 0835b9d6-fd2e-458a-9617-8ba3951b227b
        host_id: fe6a549c934f5f67345b1bd07db2b4711c0ee4717d98054273574436
        interface_ip: 199.204.45.144
        label: ubuntu-jammy-16
        node_properties: {}
        private_ipv4: 199.204.45.144
        private_ipv6: null
        provider: yul1
        public_ipv4: 199.204.45.144
        public_ipv6: 2604:e100:1:0:f816:3eff:fe4e:43
        region: ca-ymq-1
        slot: null
        uuid: null
  vars:
    atmosphere_image_prefix: harbor.atmosphere.dev/
    atmosphere_network_backend: openvswitch
    barbican_helm_values:
      pod:
        replicas:
          api: 1
    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) }}'
    ceph_version: 18.2.7
    cilium_helm_values:
      operator:
        replicas: 1
    cinder_helm_values:
      conf:
        ceph:
          pools:
            backup:
              replication: 1
            cinder.volumes:
              replication: 1
        cinder:
          DEFAULT:
            osapi_volume_workers: 2
      pod:
        replicas:
          api: 1
          scheduler: 1
    cluster_issuer_type: self-signed
    coredns_helm_values:
      replicaCount: 1
    csi_driver: local-path-provisioner
    glance_helm_values:
      conf:
        glance:
          DEFAULT:
            workers: 2
          glance_store:
            rbd_store_replication: 1
      pod:
        replicas:
          api: 1
    glance_images:
    - container_format: bare
      disk_format: raw
      is_public: true
      min_disk: 1
      name: cirros
      url: http://download.cirros-cloud.net/0.6.2/cirros-0.6.2-x86_64-disk.img
    heat_helm_values:
      conf:
        heat:
          DEFAULT:
            num_engine_workers: 2
          heat_api:
            workers: 2
          heat_api_cfn:
            workers: 2
          heat_api_cloudwatch:
            workers: 2
      pod:
        replicas:
          api: 1
          cfn: 1
          cloudwatch: 1
          engine: 1
    horizon_helm_values:
      pod:
        replicas:
          server: 1
    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 }}'
    kubernetes_keepalived_interface: br-mgmt
    magnum_helm_values:
      conf:
        magnum:
          api:
            workers: 2
          conductor:
            workers: 2
      pod:
        replicas:
          api: 1
          conductor: 1
    magnum_image_disk_format: qcow2
    magnum_images: '[ {{ _magnum_images[-1] }} ]'
    manila_helm_values:
      conf:
        manila:
          DEFAULT:
            osapi_share_workers: 2
      pod:
        replicas:
          api: 1
          scheduler: 1
    molecule_scenario: aio
    neutron_helm_values:
      conf:
        neutron:
          DEFAULT:
            api_workers: 2
            metadata_workers: 2
            rpc_workers: 2
      pod:
        replicas:
          rpc_server: 1
          server: 1
    nova_helm_values:
      conf:
        nova:
          DEFAULT:
            metadata_workers: 2
            osapi_compute_workers: 2
          conductor:
            workers: 2
          scheduler:
            workers: 2
      pod:
        replicas:
          api_metadata: 1
          conductor: 1
          novncproxy: 1
          osapi: 1
          scheduler: 1
          spiceproxy: 1
    octavia_helm_values:
      conf:
        octavia:
          controller_worker:
            workers: 2
        octavia_api_uwsgi:
          uwsgi:
            processes: 2
      pod:
        replicas:
          api: 1
          housekeeping: 1
          worker: 1
    ovn_helm_values:
      conf:
        auto_bridge_add:
          br-ex: null
      pod:
        replicas:
          ovn_northd: 1
          ovn_ovsdb_nb: 1
          ovn_ovsdb_sb: 1
    percona_xtradb_cluster_spec:
      allowUnsafeConfigurations: true
      haproxy:
        size: 1
      pxc:
        size: 1
    placement_helm_values:
      conf:
        placement_api_uwsgi:
          uwsgi:
            processes: 2
      pod:
        replicas:
          api: 1
    rook_ceph_cluster_radosgw_spec:
      dataPool:
        failureDomain: osd
      gateway:
        instances: 1
      metadataPool:
        failureDomain: osd
    staffeln_helm_values:
      pod:
        replicas:
          api: 1
          conductor: 1
    valkey_helm_values:
      replica:
        replicaCount: 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-aio explicit: None implied: {MatchAny:{ImpliedBranchMatcher:main}}
        source: vexxhost/atmosphere/.zuul.yaml@main#98>'
      - '<Job atmosphere-molecule-aio-openvswitch explicit: None implied: {MatchAny:{ImpliedBranchMatcher:main}}
        source: vexxhost/atmosphere/.zuul.yaml@main#280>'
      - '<Job atmosphere-molecule-aio-openvswitch explicit: None implied: None source:
        vexxhost/atmosphere/.zuul.yaml@main#324>'
      ansible_version: '9'
      attempts: 1
      branch: main
      build: b379b10553e44419a1ccee337418b1a4
      build_refs:
      - branch: main
        change: '3877'
        change_message: "feat(deploy): tier-1 perf \u2014 keystone pre-role gating
          and k8s-api cap\n\nDraft. Based on #3818 conceptually; merge target is `main`.\n\nThree
          complementary critical-path improvements on top of the parallel deploy orchestrator:\n\n###
          1. `PreRoleDependsOn` \u2014 asymmetric pre-role gating\nAdds a field to
          `Component` so a pre-role can wait for different dependencies than the main
          role. The orchestrator builds a `preGate` closure that waits on a shared
          `completionTracker`; the main role starts as soon as the component's own
          `DependsOn` are satisfied.\n\nApplied to Keystone: Keycloak realm / MFA
          / OIDC client / OpenID ConfigMap tasks moved to a new `keystone_pre` role
          that waits for Keycloak, while the Keystone Helm install runs in parallel
          with Keycloak startup. Potential saving **~3 min** from the serial Keycloak\u2192Keystone
          window.\n\n### 2. Neutron DAG audit\nDrops `nova` from `neutron.DependsOn`.
          The Neutron role does only Helm install + ingress \u2014 `neutron-metadata-agent`
          talks to the Nova API at runtime, not install time. Neutron now installs
          in parallel with Nova. Potential saving **~2\u20133 min**.\n\n### 3. Configurable
          `ResourceCoordinator`\nGeneralizes the resource semaphore from a fixed mutex
          (cap=1) to a per-resource cap. Adds a `k8s-api` resource (default cap 6)
          and tags heavy helm-driven components (keystone, neutron, nova, cinder,
          glance, placement, heat, barbican, octavia, magnum, manila, horizon) so
          apiserver load is smoothed during wave fan-out without serializing OpenStack.\n\n###
          Tests\n- `completion_test.go` \u2014 tracker Wait/MarkDone semantics\n-
          `resource_concurrency_test.go` \u2014 overrides + default cap\n- `orchestrator_test.go`
          \u2014 `buildPreGate` branching\n- Existing deployer/orchestrator tests
          updated for new `Deploy(ctx, comp, preGate)` signature\n\n### Backwards
          compatibility\nThe sequential `playbooks/openstack.yml --tags keystone`
          path is preserved: Keycloak tasks still exist in `roles/keystone/tasks/main.yml`
          guarded by `_pre_role_active`, following the existing `octavia` / `magnum`
          pattern.\n\n### Next steps after merge\nValidate actual performance in Zuul
          vs current #3818 baseline (OVN deploy 34.8 min, OVS 35.5 min). Expected
          savings: ~4\u20136 min critical-path.\n"
        change_url: https://github.com/vexxhost/atmosphere/pull/3877
        commit_id: 4a5b1c8bff7c0403db38f74fe14bfc39a97b33ca
        patchset: 4a5b1c8bff7c0403db38f74fe14bfc39a97b33ca
        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: fd9856c6f36e461cacb63682781ea7c9
      buildset_refs:
      - branch: main
        change: '3877'
        change_message: "feat(deploy): tier-1 perf \u2014 keystone pre-role gating
          and k8s-api cap\n\nDraft. Based on #3818 conceptually; merge target is `main`.\n\nThree
          complementary critical-path improvements on top of the parallel deploy orchestrator:\n\n###
          1. `PreRoleDependsOn` \u2014 asymmetric pre-role gating\nAdds a field to
          `Component` so a pre-role can wait for different dependencies than the main
          role. The orchestrator builds a `preGate` closure that waits on a shared
          `completionTracker`; the main role starts as soon as the component's own
          `DependsOn` are satisfied.\n\nApplied to Keystone: Keycloak realm / MFA
          / OIDC client / OpenID ConfigMap tasks moved to a new `keystone_pre` role
          that waits for Keycloak, while the Keystone Helm install runs in parallel
          with Keycloak startup. Potential saving **~3 min** from the serial Keycloak\u2192Keystone
          window.\n\n### 2. Neutron DAG audit\nDrops `nova` from `neutron.DependsOn`.
          The Neutron role does only Helm install + ingress \u2014 `neutron-metadata-agent`
          talks to the Nova API at runtime, not install time. Neutron now installs
          in parallel with Nova. Potential saving **~2\u20133 min**.\n\n### 3. Configurable
          `ResourceCoordinator`\nGeneralizes the resource semaphore from a fixed mutex
          (cap=1) to a per-resource cap. Adds a `k8s-api` resource (default cap 6)
          and tags heavy helm-driven components (keystone, neutron, nova, cinder,
          glance, placement, heat, barbican, octavia, magnum, manila, horizon) so
          apiserver load is smoothed during wave fan-out without serializing OpenStack.\n\n###
          Tests\n- `completion_test.go` \u2014 tracker Wait/MarkDone semantics\n-
          `resource_concurrency_test.go` \u2014 overrides + default cap\n- `orchestrator_test.go`
          \u2014 `buildPreGate` branching\n- Existing deployer/orchestrator tests
          updated for new `Deploy(ctx, comp, preGate)` signature\n\n### Backwards
          compatibility\nThe sequential `playbooks/openstack.yml --tags keystone`
          path is preserved: Keycloak tasks still exist in `roles/keystone/tasks/main.yml`
          guarded by `_pre_role_active`, following the existing `octavia` / `magnum`
          pattern.\n\n### Next steps after merge\nValidate actual performance in Zuul
          vs current #3818 baseline (OVN deploy 34.8 min, OVS 35.5 min). Expected
          savings: ~4\u20136 min critical-path.\n"
        change_url: https://github.com/vexxhost/atmosphere/pull/3877
        commit_id: 4a5b1c8bff7c0403db38f74fe14bfc39a97b33ca
        patchset: 4a5b1c8bff7c0403db38f74fe14bfc39a97b33ca
        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: "feat(deploy): tier-1 perf \u2014 keystone pre-role gating and
        k8s-api cap\n\nDraft. Based on #3818 conceptually; merge target is `main`.\n\nThree
        complementary critical-path improvements on top of the parallel deploy orchestrator:\n\n###
        1. `PreRoleDependsOn` \u2014 asymmetric pre-role gating\nAdds a field to `Component`
        so a pre-role can wait for different dependencies than the main role. The
        orchestrator builds a `preGate` closure that waits on a shared `completionTracker`;
        the main role starts as soon as the component's own `DependsOn` are satisfied.\n\nApplied
        to Keystone: Keycloak realm / MFA / OIDC client / OpenID ConfigMap tasks moved
        to a new `keystone_pre` role that waits for Keycloak, while the Keystone Helm
        install runs in parallel with Keycloak startup. Potential saving **~3 min**
        from the serial Keycloak\u2192Keystone window.\n\n### 2. Neutron DAG audit\nDrops
        `nova` from `neutron.DependsOn`. The Neutron role does only Helm install +
        ingress \u2014 `neutron-metadata-agent` talks to the Nova API at runtime,
        not install time. Neutron now installs in parallel with Nova. Potential saving
        **~2\u20133 min**.\n\n### 3. Configurable `ResourceCoordinator`\nGeneralizes
        the resource semaphore from a fixed mutex (cap=1) to a per-resource cap. Adds
        a `k8s-api` resource (default cap 6) and tags heavy helm-driven components
        (keystone, neutron, nova, cinder, glance, placement, heat, barbican, octavia,
        magnum, manila, horizon) so apiserver load is smoothed during wave fan-out
        without serializing OpenStack.\n\n### Tests\n- `completion_test.go` \u2014
        tracker Wait/MarkDone semantics\n- `resource_concurrency_test.go` \u2014 overrides
        + default cap\n- `orchestrator_test.go` \u2014 `buildPreGate` branching\n-
        Existing deployer/orchestrator tests updated for new `Deploy(ctx, comp, preGate)`
        signature\n\n### Backwards compatibility\nThe sequential `playbooks/openstack.yml
        --tags keystone` path is preserved: Keycloak tasks still exist in `roles/keystone/tasks/main.yml`
        guarded by `_pre_role_active`, following the existing `octavia` / `magnum`
        pattern.\n\n### Next steps after merge\nValidate actual performance in Zuul
        vs current #3818 baseline (OVN deploy 34.8 min, OVS 35.5 min). Expected savings:
        ~4\u20136 min critical-path.\n"
      change_url: https://github.com/vexxhost/atmosphere/pull/3877
      child_jobs: []
      commit_id: 4a5b1c8bff7c0403db38f74fe14bfc39a97b33ca
      event_id: 0720bfc0-4089-11f1-9779-315b398ba85f
      executor:
        hostname: 0a8996d2b663
        inventory_file: /var/lib/zuul/builds/b379b10553e44419a1ccee337418b1a4/ansible/inventory.yaml
        log_root: /var/lib/zuul/builds/b379b10553e44419a1ccee337418b1a4/work/logs
        result_data_file: /var/lib/zuul/builds/b379b10553e44419a1ccee337418b1a4/work/results.json
        src_root: /var/lib/zuul/builds/b379b10553e44419a1ccee337418b1a4/work/src
        work_root: /var/lib/zuul/builds/b379b10553e44419a1ccee337418b1a4/work
      include_vars: []
      items:
      - branch: main
        change: '3877'
        change_message: "feat(deploy): tier-1 perf \u2014 keystone pre-role gating
          and k8s-api cap\n\nDraft. Based on #3818 conceptually; merge target is `main`.\n\nThree
          complementary critical-path improvements on top of the parallel deploy orchestrator:\n\n###
          1. `PreRoleDependsOn` \u2014 asymmetric pre-role gating\nAdds a field to
          `Component` so a pre-role can wait for different dependencies than the main
          role. The orchestrator builds a `preGate` closure that waits on a shared
          `completionTracker`; the main role starts as soon as the component's own
          `DependsOn` are satisfied.\n\nApplied to Keystone: Keycloak realm / MFA
          / OIDC client / OpenID ConfigMap tasks moved to a new `keystone_pre` role
          that waits for Keycloak, while the Keystone Helm install runs in parallel
          with Keycloak startup. Potential saving **~3 min** from the serial Keycloak\u2192Keystone
          window.\n\n### 2. Neutron DAG audit\nDrops `nova` from `neutron.DependsOn`.
          The Neutron role does only Helm install + ingress \u2014 `neutron-metadata-agent`
          talks to the Nova API at runtime, not install time. Neutron now installs
          in parallel with Nova. Potential saving **~2\u20133 min**.\n\n### 3. Configurable
          `ResourceCoordinator`\nGeneralizes the resource semaphore from a fixed mutex
          (cap=1) to a per-resource cap. Adds a `k8s-api` resource (default cap 6)
          and tags heavy helm-driven components (keystone, neutron, nova, cinder,
          glance, placement, heat, barbican, octavia, magnum, manila, horizon) so
          apiserver load is smoothed during wave fan-out without serializing OpenStack.\n\n###
          Tests\n- `completion_test.go` \u2014 tracker Wait/MarkDone semantics\n-
          `resource_concurrency_test.go` \u2014 overrides + default cap\n- `orchestrator_test.go`
          \u2014 `buildPreGate` branching\n- Existing deployer/orchestrator tests
          updated for new `Deploy(ctx, comp, preGate)` signature\n\n### Backwards
          compatibility\nThe sequential `playbooks/openstack.yml --tags keystone`
          path is preserved: Keycloak tasks still exist in `roles/keystone/tasks/main.yml`
          guarded by `_pre_role_active`, following the existing `octavia` / `magnum`
          pattern.\n\n### Next steps after merge\nValidate actual performance in Zuul
          vs current #3818 baseline (OVN deploy 34.8 min, OVS 35.5 min). Expected
          savings: ~4\u20136 min critical-path.\n"
        change_url: https://github.com/vexxhost/atmosphere/pull/3877
        commit_id: 4a5b1c8bff7c0403db38f74fe14bfc39a97b33ca
        patchset: 4a5b1c8bff7c0403db38f74fe14bfc39a97b33ca
        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-aio-openvswitch
      jobtags: []
      max_attempts: 3
      message: ZmVhdChkZXBsb3kpOiB0aWVyLTEgcGVyZiDigJQga2V5c3RvbmUgcHJlLXJvbGUgZ2F0aW5nIGFuZCBrOHMtYXBpIGNhcAoKRHJhZnQuIEJhc2VkIG9uICMzODE4IGNvbmNlcHR1YWxseTsgbWVyZ2UgdGFyZ2V0IGlzIGBtYWluYC4KClRocmVlIGNvbXBsZW1lbnRhcnkgY3JpdGljYWwtcGF0aCBpbXByb3ZlbWVudHMgb24gdG9wIG9mIHRoZSBwYXJhbGxlbCBkZXBsb3kgb3JjaGVzdHJhdG9yOgoKIyMjIDEuIGBQcmVSb2xlRGVwZW5kc09uYCDigJQgYXN5bW1ldHJpYyBwcmUtcm9sZSBnYXRpbmcKQWRkcyBhIGZpZWxkIHRvIGBDb21wb25lbnRgIHNvIGEgcHJlLXJvbGUgY2FuIHdhaXQgZm9yIGRpZmZlcmVudCBkZXBlbmRlbmNpZXMgdGhhbiB0aGUgbWFpbiByb2xlLiBUaGUgb3JjaGVzdHJhdG9yIGJ1aWxkcyBhIGBwcmVHYXRlYCBjbG9zdXJlIHRoYXQgd2FpdHMgb24gYSBzaGFyZWQgYGNvbXBsZXRpb25UcmFja2VyYDsgdGhlIG1haW4gcm9sZSBzdGFydHMgYXMgc29vbiBhcyB0aGUgY29tcG9uZW50J3Mgb3duIGBEZXBlbmRzT25gIGFyZSBzYXRpc2ZpZWQuCgpBcHBsaWVkIHRvIEtleXN0b25lOiBLZXljbG9hayByZWFsbSAvIE1GQSAvIE9JREMgY2xpZW50IC8gT3BlbklEIENvbmZpZ01hcCB0YXNrcyBtb3ZlZCB0byBhIG5ldyBga2V5c3RvbmVfcHJlYCByb2xlIHRoYXQgd2FpdHMgZm9yIEtleWNsb2FrLCB3aGlsZSB0aGUgS2V5c3RvbmUgSGVsbSBpbnN0YWxsIHJ1bnMgaW4gcGFyYWxsZWwgd2l0aCBLZXljbG9hayBzdGFydHVwLiBQb3RlbnRpYWwgc2F2aW5nICoqfjMgbWluKiogZnJvbSB0aGUgc2VyaWFsIEtleWNsb2Fr4oaSS2V5c3RvbmUgd2luZG93LgoKIyMjIDIuIE5ldXRyb24gREFHIGF1ZGl0CkRyb3BzIGBub3ZhYCBmcm9tIGBuZXV0cm9uLkRlcGVuZHNPbmAuIFRoZSBOZXV0cm9uIHJvbGUgZG9lcyBvbmx5IEhlbG0gaW5zdGFsbCArIGluZ3Jlc3Mg4oCUIGBuZXV0cm9uLW1ldGFkYXRhLWFnZW50YCB0YWxrcyB0byB0aGUgTm92YSBBUEkgYXQgcnVudGltZSwgbm90IGluc3RhbGwgdGltZS4gTmV1dHJvbiBub3cgaW5zdGFsbHMgaW4gcGFyYWxsZWwgd2l0aCBOb3ZhLiBQb3RlbnRpYWwgc2F2aW5nICoqfjLigJMzIG1pbioqLgoKIyMjIDMuIENvbmZpZ3VyYWJsZSBgUmVzb3VyY2VDb29yZGluYXRvcmAKR2VuZXJhbGl6ZXMgdGhlIHJlc291cmNlIHNlbWFwaG9yZSBmcm9tIGEgZml4ZWQgbXV0ZXggKGNhcD0xKSB0byBhIHBlci1yZXNvdXJjZSBjYXAuIEFkZHMgYSBgazhzLWFwaWAgcmVzb3VyY2UgKGRlZmF1bHQgY2FwIDYpIGFuZCB0YWdzIGhlYXZ5IGhlbG0tZHJpdmVuIGNvbXBvbmVudHMgKGtleXN0b25lLCBuZXV0cm9uLCBub3ZhLCBjaW5kZXIsIGdsYW5jZSwgcGxhY2VtZW50LCBoZWF0LCBiYXJiaWNhbiwgb2N0YXZpYSwgbWFnbnVtLCBtYW5pbGEsIGhvcml6b24pIHNvIGFwaXNlcnZlciBsb2FkIGlzIHNtb290aGVkIGR1cmluZyB3YXZlIGZhbi1vdXQgd2l0aG91dCBzZXJpYWxpemluZyBPcGVuU3RhY2suCgojIyMgVGVzdHMKLSBgY29tcGxldGlvbl90ZXN0LmdvYCDigJQgdHJhY2tlciBXYWl0L01hcmtEb25lIHNlbWFudGljcwotIGByZXNvdXJjZV9jb25jdXJyZW5jeV90ZXN0LmdvYCDigJQgb3ZlcnJpZGVzICsgZGVmYXVsdCBjYXAKLSBgb3JjaGVzdHJhdG9yX3Rlc3QuZ29gIOKAlCBgYnVpbGRQcmVHYXRlYCBicmFuY2hpbmcKLSBFeGlzdGluZyBkZXBsb3llci9vcmNoZXN0cmF0b3IgdGVzdHMgdXBkYXRlZCBmb3IgbmV3IGBEZXBsb3koY3R4LCBjb21wLCBwcmVHYXRlKWAgc2lnbmF0dXJlCgojIyMgQmFja3dhcmRzIGNvbXBhdGliaWxpdHkKVGhlIHNlcXVlbnRpYWwgYHBsYXlib29rcy9vcGVuc3RhY2sueW1sIC0tdGFncyBrZXlzdG9uZWAgcGF0aCBpcyBwcmVzZXJ2ZWQ6IEtleWNsb2FrIHRhc2tzIHN0aWxsIGV4aXN0IGluIGByb2xlcy9rZXlzdG9uZS90YXNrcy9tYWluLnltbGAgZ3VhcmRlZCBieSBgX3ByZV9yb2xlX2FjdGl2ZWAsIGZvbGxvd2luZyB0aGUgZXhpc3RpbmcgYG9jdGF2aWFgIC8gYG1hZ251bWAgcGF0dGVybi4KCiMjIyBOZXh0IHN0ZXBzIGFmdGVyIG1lcmdlClZhbGlkYXRlIGFjdHVhbCBwZXJmb3JtYW5jZSBpbiBadXVsIHZzIGN1cnJlbnQgIzM4MTggYmFzZWxpbmUgKE9WTiBkZXBsb3kgMzQuOCBtaW4sIE9WUyAzNS41IG1pbikuIEV4cGVjdGVkIHNhdmluZ3M6IH404oCTNiBtaW4gY3JpdGljYWwtcGF0aC4K
      patchset: 4a5b1c8bff7c0403db38f74fe14bfc39a97b33ca
      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: 4a5b1c8bff7c0403db38f74fe14bfc39a97b33ca
          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/aio/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: 4a5b1c8bff7c0403db38f74fe14bfc39a97b33ca
          name: vexxhost/atmosphere
          required: false
          short_name: atmosphere
          src_dir: src/github.com/vexxhost/atmosphere
      ref: refs/pull/3877/head
      resources: {}
      tenant: oss
      timeout: 7200
      topic: null
      voting: true
