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.35
      ansible_port: 22
      ansible_python_interpreter: auto
      ansible_user: zuul
      atmosphere_image_prefix: harbor.atmosphere.dev/
      ceph_conf_overrides:
      - option: mon allow pool size one
        section: global
        value: true
      - option: osd crush chooseleaf type
        section: global
        value: 0
      - option: auth allow insecure global id reclaim
        section: mon
        value: false
      ceph_csi_rbd_helm_values:
        provisioner:
          replicaCount: 1
      ceph_fsid: 4837cbf8-4f90-4300-b3f6-726c9b9f89b4
      ceph_osd_devices:
      - /dev/ceph-{{ inventory_hostname_short }}-osd0/data
      - /dev/ceph-{{ inventory_hostname_short }}-osd1/data
      - /dev/ceph-{{ inventory_hostname_short }}-osd2/data
      cilium_helm_values:
        operator:
          replicas: 1
      csi_driver: local-path-provisioner
      kube_vip_address: 172.17.0.100
      kube_vip_interface: '{{ ansible_facts[''default_ipv4''].interface }}'
      kubernetes_hostname: '{{ ansible_facts[''default_ipv4''].address }}'
      molecule_scenario: csi
      nodepool:
        az: nova
        cloud: public
        external_id: e9600643-78b4-421b-ba96-8cade6441459
        host_id: 7cb77d063530dedbf6983b78a36ec607482cf1d282610499e8bd9357
        interface_ip: 199.204.45.35
        label: ubuntu-jammy
        node_properties: {}
        private_ipv4: 199.204.45.35
        private_ipv6: null
        provider: yul1
        public_ipv4: 199.204.45.35
        public_ipv6: 2604:e100:1:0:f816:3eff:fe51:36bf
        region: ca-ymq-1
        slot: null
      zuul_node:
        az: nova
        cloud: public
        external_id: e9600643-78b4-421b-ba96-8cade6441459
        host_id: 7cb77d063530dedbf6983b78a36ec607482cf1d282610499e8bd9357
        interface_ip: 199.204.45.35
        label: ubuntu-jammy
        node_properties: {}
        private_ipv4: 199.204.45.35
        private_ipv6: null
        provider: yul1
        public_ipv4: 199.204.45.35
        public_ipv6: 2604:e100:1:0:f816:3eff:fe51:36bf
        region: ca-ymq-1
        slot: null
        uuid: null
  vars:
    atmosphere_image_prefix: harbor.atmosphere.dev/
    ceph_conf_overrides:
    - option: mon allow pool size one
      section: global
      value: true
    - option: osd crush chooseleaf type
      section: global
      value: 0
    - option: auth allow insecure global id reclaim
      section: mon
      value: false
    ceph_csi_rbd_helm_values:
      provisioner:
        replicaCount: 1
    ceph_fsid: 4837cbf8-4f90-4300-b3f6-726c9b9f89b4
    ceph_osd_devices:
    - /dev/ceph-{{ inventory_hostname_short }}-osd0/data
    - /dev/ceph-{{ inventory_hostname_short }}-osd1/data
    - /dev/ceph-{{ inventory_hostname_short }}-osd2/data
    cilium_helm_values:
      operator:
        replicas: 1
    csi_driver: local-path-provisioner
    kube_vip_address: 172.17.0.100
    kube_vip_interface: '{{ ansible_facts[''default_ipv4''].interface }}'
    kubernetes_hostname: '{{ ansible_facts[''default_ipv4''].address }}'
    molecule_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#60>'
      - '<Job atmosphere-molecule-csi-local-path-provisioner explicit: None implied:
        {MatchAny:{ImpliedBranchMatcher:main}} source: vexxhost/atmosphere/.zuul.yaml@main#67>'
      - '<Job atmosphere-molecule-csi-local-path-provisioner explicit: None implied:
        None source: vexxhost/atmosphere/.zuul.yaml@main#273>'
      ansible_version: '9'
      attempts: 1
      branch: main
      build: 5837eb707a18497c8dd2fd1b9d46ff99
      build_refs:
      - branch: main
        change: '3764'
        change_message: "feat(charts): switch all uwsgi services to use wsgi module
          entrypoints\n\nUpstream OpenStack projects have removed wsgi script files
          (e.g., `barbican-wsgi-api`, `placement-api`) in favor of `wsgi` module entrypoints.
          Services still using `wsgi-file` break on latest releases.\n\n### Conversions\n\nAll
          standard OpenStack services now use `module` instead of `wsgi-file`:\n\n|
          Service | Module entrypoint |\n|---------|------------------|\n| Barbican
          | `barbican.wsgi.api:application` |\n| Placement | `placement.wsgi.api:application`
          |\n| Designate | `designate.wsgi.api:application` |\n| Heat API | `heat.wsgi.api:application`
          |\n| Heat CFN | `heat.wsgi.cfn:application` |\n| Neutron API | `neutron.wsgi.api:application`
          |\n| Magnum | `magnum.wsgi.api:application` (was `magnum.api.app:build_wsgi_app`)
          |\n\nEach entrypoint verified against upstream source (e.g., `openstack/barbican:barbican/wsgi/api.py`).\n\n```yaml\n#
          Before\nwsgi-file: /var/lib/openstack/bin/barbican-wsgi-api\n\n# After\nmodule:
          \"barbican.wsgi.api:application\"\n```\n\n### Patch fixes\n\n- Updated `charts/patches/`
          for all converted services to reflect `wsgi-file` \u2192 `module` change\n-
          Fixed stale context lines in Octavia and Manila patches (already using `module`
          in values but patches still referenced `wsgi-file`)\n\n### Not converted\n\n-
          **neutron-policy-server-wsgi** \u2014 custom component, no upstream wsgi
          module\n- **neutron-ovn-network-logging-parser-wsgi** \u2014 VEXXHOST Flask
          project, uses `create_app` factory pattern\n\n<!-- START COPILOT CODING
          AGENT SUFFIX -->\n\n\n\n<!-- START COPILOT ORIGINAL PROMPT -->\n\n\n\n<details>\n\n<summary>Original
          prompt</summary>\n\n> https://github.com/vexxhost/atmosphere/issues/3763\n\n\n</details>\n\n\n\n<!--
          START COPILOT CODING AGENT TIPS -->\n---\n\n\U0001F4A1 You can make Copilot
          smarter by setting up custom instructions, customizing its development environment
          and configuring Model Context Protocol (MCP) servers. Learn more [Copilot
          coding agent tips](https://gh.io/copilot-coding-agent-tips) in the docs."
        change_url: https://github.com/vexxhost/atmosphere/pull/3764
        commit_id: eb8073c17247f6ba46b3352b64201bed328034e2
        patchset: eb8073c17247f6ba46b3352b64201bed328034e2
        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: 77601f94c7354413a3710c01781687e9
      buildset_refs:
      - branch: main
        change: '3764'
        change_message: "feat(charts): switch all uwsgi services to use wsgi module
          entrypoints\n\nUpstream OpenStack projects have removed wsgi script files
          (e.g., `barbican-wsgi-api`, `placement-api`) in favor of `wsgi` module entrypoints.
          Services still using `wsgi-file` break on latest releases.\n\n### Conversions\n\nAll
          standard OpenStack services now use `module` instead of `wsgi-file`:\n\n|
          Service | Module entrypoint |\n|---------|------------------|\n| Barbican
          | `barbican.wsgi.api:application` |\n| Placement | `placement.wsgi.api:application`
          |\n| Designate | `designate.wsgi.api:application` |\n| Heat API | `heat.wsgi.api:application`
          |\n| Heat CFN | `heat.wsgi.cfn:application` |\n| Neutron API | `neutron.wsgi.api:application`
          |\n| Magnum | `magnum.wsgi.api:application` (was `magnum.api.app:build_wsgi_app`)
          |\n\nEach entrypoint verified against upstream source (e.g., `openstack/barbican:barbican/wsgi/api.py`).\n\n```yaml\n#
          Before\nwsgi-file: /var/lib/openstack/bin/barbican-wsgi-api\n\n# After\nmodule:
          \"barbican.wsgi.api:application\"\n```\n\n### Patch fixes\n\n- Updated `charts/patches/`
          for all converted services to reflect `wsgi-file` \u2192 `module` change\n-
          Fixed stale context lines in Octavia and Manila patches (already using `module`
          in values but patches still referenced `wsgi-file`)\n\n### Not converted\n\n-
          **neutron-policy-server-wsgi** \u2014 custom component, no upstream wsgi
          module\n- **neutron-ovn-network-logging-parser-wsgi** \u2014 VEXXHOST Flask
          project, uses `create_app` factory pattern\n\n<!-- START COPILOT CODING
          AGENT SUFFIX -->\n\n\n\n<!-- START COPILOT ORIGINAL PROMPT -->\n\n\n\n<details>\n\n<summary>Original
          prompt</summary>\n\n> https://github.com/vexxhost/atmosphere/issues/3763\n\n\n</details>\n\n\n\n<!--
          START COPILOT CODING AGENT TIPS -->\n---\n\n\U0001F4A1 You can make Copilot
          smarter by setting up custom instructions, customizing its development environment
          and configuring Model Context Protocol (MCP) servers. Learn more [Copilot
          coding agent tips](https://gh.io/copilot-coding-agent-tips) in the docs."
        change_url: https://github.com/vexxhost/atmosphere/pull/3764
        commit_id: eb8073c17247f6ba46b3352b64201bed328034e2
        patchset: eb8073c17247f6ba46b3352b64201bed328034e2
        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: '3764'
      change_message: "feat(charts): switch all uwsgi services to use wsgi module
        entrypoints\n\nUpstream OpenStack projects have removed wsgi script files
        (e.g., `barbican-wsgi-api`, `placement-api`) in favor of `wsgi` module entrypoints.
        Services still using `wsgi-file` break on latest releases.\n\n### Conversions\n\nAll
        standard OpenStack services now use `module` instead of `wsgi-file`:\n\n|
        Service | Module entrypoint |\n|---------|------------------|\n| Barbican
        | `barbican.wsgi.api:application` |\n| Placement | `placement.wsgi.api:application`
        |\n| Designate | `designate.wsgi.api:application` |\n| Heat API | `heat.wsgi.api:application`
        |\n| Heat CFN | `heat.wsgi.cfn:application` |\n| Neutron API | `neutron.wsgi.api:application`
        |\n| Magnum | `magnum.wsgi.api:application` (was `magnum.api.app:build_wsgi_app`)
        |\n\nEach entrypoint verified against upstream source (e.g., `openstack/barbican:barbican/wsgi/api.py`).\n\n```yaml\n#
        Before\nwsgi-file: /var/lib/openstack/bin/barbican-wsgi-api\n\n# After\nmodule:
        \"barbican.wsgi.api:application\"\n```\n\n### Patch fixes\n\n- Updated `charts/patches/`
        for all converted services to reflect `wsgi-file` \u2192 `module` change\n-
        Fixed stale context lines in Octavia and Manila patches (already using `module`
        in values but patches still referenced `wsgi-file`)\n\n### Not converted\n\n-
        **neutron-policy-server-wsgi** \u2014 custom component, no upstream wsgi module\n-
        **neutron-ovn-network-logging-parser-wsgi** \u2014 VEXXHOST Flask project,
        uses `create_app` factory pattern\n\n<!-- START COPILOT CODING AGENT SUFFIX
        -->\n\n\n\n<!-- START COPILOT ORIGINAL PROMPT -->\n\n\n\n<details>\n\n<summary>Original
        prompt</summary>\n\n> https://github.com/vexxhost/atmosphere/issues/3763\n\n\n</details>\n\n\n\n<!--
        START COPILOT CODING AGENT TIPS -->\n---\n\n\U0001F4A1 You can make Copilot
        smarter by setting up custom instructions, customizing its development environment
        and configuring Model Context Protocol (MCP) servers. Learn more [Copilot
        coding agent tips](https://gh.io/copilot-coding-agent-tips) in the docs."
      change_url: https://github.com/vexxhost/atmosphere/pull/3764
      child_jobs: []
      commit_id: eb8073c17247f6ba46b3352b64201bed328034e2
      event_id: c72400b0-21c7-11f1-9a74-c9ab76f15ac5
      executor:
        hostname: 0a8996d2b663
        inventory_file: /var/lib/zuul/builds/5837eb707a18497c8dd2fd1b9d46ff99/ansible/inventory.yaml
        log_root: /var/lib/zuul/builds/5837eb707a18497c8dd2fd1b9d46ff99/work/logs
        result_data_file: /var/lib/zuul/builds/5837eb707a18497c8dd2fd1b9d46ff99/work/results.json
        src_root: /var/lib/zuul/builds/5837eb707a18497c8dd2fd1b9d46ff99/work/src
        work_root: /var/lib/zuul/builds/5837eb707a18497c8dd2fd1b9d46ff99/work
      include_vars: []
      items:
      - branch: main
        change: '3764'
        change_message: "feat(charts): switch all uwsgi services to use wsgi module
          entrypoints\n\nUpstream OpenStack projects have removed wsgi script files
          (e.g., `barbican-wsgi-api`, `placement-api`) in favor of `wsgi` module entrypoints.
          Services still using `wsgi-file` break on latest releases.\n\n### Conversions\n\nAll
          standard OpenStack services now use `module` instead of `wsgi-file`:\n\n|
          Service | Module entrypoint |\n|---------|------------------|\n| Barbican
          | `barbican.wsgi.api:application` |\n| Placement | `placement.wsgi.api:application`
          |\n| Designate | `designate.wsgi.api:application` |\n| Heat API | `heat.wsgi.api:application`
          |\n| Heat CFN | `heat.wsgi.cfn:application` |\n| Neutron API | `neutron.wsgi.api:application`
          |\n| Magnum | `magnum.wsgi.api:application` (was `magnum.api.app:build_wsgi_app`)
          |\n\nEach entrypoint verified against upstream source (e.g., `openstack/barbican:barbican/wsgi/api.py`).\n\n```yaml\n#
          Before\nwsgi-file: /var/lib/openstack/bin/barbican-wsgi-api\n\n# After\nmodule:
          \"barbican.wsgi.api:application\"\n```\n\n### Patch fixes\n\n- Updated `charts/patches/`
          for all converted services to reflect `wsgi-file` \u2192 `module` change\n-
          Fixed stale context lines in Octavia and Manila patches (already using `module`
          in values but patches still referenced `wsgi-file`)\n\n### Not converted\n\n-
          **neutron-policy-server-wsgi** \u2014 custom component, no upstream wsgi
          module\n- **neutron-ovn-network-logging-parser-wsgi** \u2014 VEXXHOST Flask
          project, uses `create_app` factory pattern\n\n<!-- START COPILOT CODING
          AGENT SUFFIX -->\n\n\n\n<!-- START COPILOT ORIGINAL PROMPT -->\n\n\n\n<details>\n\n<summary>Original
          prompt</summary>\n\n> https://github.com/vexxhost/atmosphere/issues/3763\n\n\n</details>\n\n\n\n<!--
          START COPILOT CODING AGENT TIPS -->\n---\n\n\U0001F4A1 You can make Copilot
          smarter by setting up custom instructions, customizing its development environment
          and configuring Model Context Protocol (MCP) servers. Learn more [Copilot
          coding agent tips](https://gh.io/copilot-coding-agent-tips) in the docs."
        change_url: https://github.com/vexxhost/atmosphere/pull/3764
        commit_id: eb8073c17247f6ba46b3352b64201bed328034e2
        patchset: eb8073c17247f6ba46b3352b64201bed328034e2
        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: ZmVhdChjaGFydHMpOiBzd2l0Y2ggYWxsIHV3c2dpIHNlcnZpY2VzIHRvIHVzZSB3c2dpIG1vZHVsZSBlbnRyeXBvaW50cwoKVXBzdHJlYW0gT3BlblN0YWNrIHByb2plY3RzIGhhdmUgcmVtb3ZlZCB3c2dpIHNjcmlwdCBmaWxlcyAoZS5nLiwgYGJhcmJpY2FuLXdzZ2ktYXBpYCwgYHBsYWNlbWVudC1hcGlgKSBpbiBmYXZvciBvZiBgd3NnaWAgbW9kdWxlIGVudHJ5cG9pbnRzLiBTZXJ2aWNlcyBzdGlsbCB1c2luZyBgd3NnaS1maWxlYCBicmVhayBvbiBsYXRlc3QgcmVsZWFzZXMuCgojIyMgQ29udmVyc2lvbnMKCkFsbCBzdGFuZGFyZCBPcGVuU3RhY2sgc2VydmljZXMgbm93IHVzZSBgbW9kdWxlYCBpbnN0ZWFkIG9mIGB3c2dpLWZpbGVgOgoKfCBTZXJ2aWNlIHwgTW9kdWxlIGVudHJ5cG9pbnQgfAp8LS0tLS0tLS0tfC0tLS0tLS0tLS0tLS0tLS0tLXwKfCBCYXJiaWNhbiB8IGBiYXJiaWNhbi53c2dpLmFwaTphcHBsaWNhdGlvbmAgfAp8IFBsYWNlbWVudCB8IGBwbGFjZW1lbnQud3NnaS5hcGk6YXBwbGljYXRpb25gIHwKfCBEZXNpZ25hdGUgfCBgZGVzaWduYXRlLndzZ2kuYXBpOmFwcGxpY2F0aW9uYCB8CnwgSGVhdCBBUEkgfCBgaGVhdC53c2dpLmFwaTphcHBsaWNhdGlvbmAgfAp8IEhlYXQgQ0ZOIHwgYGhlYXQud3NnaS5jZm46YXBwbGljYXRpb25gIHwKfCBOZXV0cm9uIEFQSSB8IGBuZXV0cm9uLndzZ2kuYXBpOmFwcGxpY2F0aW9uYCB8CnwgTWFnbnVtIHwgYG1hZ251bS53c2dpLmFwaTphcHBsaWNhdGlvbmAgKHdhcyBgbWFnbnVtLmFwaS5hcHA6YnVpbGRfd3NnaV9hcHBgKSB8CgpFYWNoIGVudHJ5cG9pbnQgdmVyaWZpZWQgYWdhaW5zdCB1cHN0cmVhbSBzb3VyY2UgKGUuZy4sIGBvcGVuc3RhY2svYmFyYmljYW46YmFyYmljYW4vd3NnaS9hcGkucHlgKS4KCmBgYHlhbWwKIyBCZWZvcmUKd3NnaS1maWxlOiAvdmFyL2xpYi9vcGVuc3RhY2svYmluL2JhcmJpY2FuLXdzZ2ktYXBpCgojIEFmdGVyCm1vZHVsZTogImJhcmJpY2FuLndzZ2kuYXBpOmFwcGxpY2F0aW9uIgpgYGAKCiMjIyBQYXRjaCBmaXhlcwoKLSBVcGRhdGVkIGBjaGFydHMvcGF0Y2hlcy9gIGZvciBhbGwgY29udmVydGVkIHNlcnZpY2VzIHRvIHJlZmxlY3QgYHdzZ2ktZmlsZWAg4oaSIGBtb2R1bGVgIGNoYW5nZQotIEZpeGVkIHN0YWxlIGNvbnRleHQgbGluZXMgaW4gT2N0YXZpYSBhbmQgTWFuaWxhIHBhdGNoZXMgKGFscmVhZHkgdXNpbmcgYG1vZHVsZWAgaW4gdmFsdWVzIGJ1dCBwYXRjaGVzIHN0aWxsIHJlZmVyZW5jZWQgYHdzZ2ktZmlsZWApCgojIyMgTm90IGNvbnZlcnRlZAoKLSAqKm5ldXRyb24tcG9saWN5LXNlcnZlci13c2dpKiog4oCUIGN1c3RvbSBjb21wb25lbnQsIG5vIHVwc3RyZWFtIHdzZ2kgbW9kdWxlCi0gKipuZXV0cm9uLW92bi1uZXR3b3JrLWxvZ2dpbmctcGFyc2VyLXdzZ2kqKiDigJQgVkVYWEhPU1QgRmxhc2sgcHJvamVjdCwgdXNlcyBgY3JlYXRlX2FwcGAgZmFjdG9yeSBwYXR0ZXJuCgo8IS0tIFNUQVJUIENPUElMT1QgQ09ESU5HIEFHRU5UIFNVRkZJWCAtLT4KCgoKPCEtLSBTVEFSVCBDT1BJTE9UIE9SSUdJTkFMIFBST01QVCAtLT4KCgoKPGRldGFpbHM+Cgo8c3VtbWFyeT5PcmlnaW5hbCBwcm9tcHQ8L3N1bW1hcnk+Cgo+IGh0dHBzOi8vZ2l0aHViLmNvbS92ZXh4aG9zdC9hdG1vc3BoZXJlL2lzc3Vlcy8zNzYzCgoKPC9kZXRhaWxzPgoKCgo8IS0tIFNUQVJUIENPUElMT1QgQ09ESU5HIEFHRU5UIFRJUFMgLS0+Ci0tLQoK8J+SoSBZb3UgY2FuIG1ha2UgQ29waWxvdCBzbWFydGVyIGJ5IHNldHRpbmcgdXAgY3VzdG9tIGluc3RydWN0aW9ucywgY3VzdG9taXppbmcgaXRzIGRldmVsb3BtZW50IGVudmlyb25tZW50IGFuZCBjb25maWd1cmluZyBNb2RlbCBDb250ZXh0IFByb3RvY29sIChNQ1ApIHNlcnZlcnMuIExlYXJuIG1vcmUgW0NvcGlsb3QgY29kaW5nIGFnZW50IHRpcHNdKGh0dHBzOi8vZ2guaW8vY29waWxvdC1jb2RpbmctYWdlbnQtdGlwcykgaW4gdGhlIGRvY3Mu
      patchset: eb8073c17247f6ba46b3352b64201bed328034e2
      pipeline: check
      playbook_context:
        playbook_projects:
          trusted/project_0/github.com/vexxhost/zuul-config:
            canonical_name: github.com/vexxhost/zuul-config
            checkout: main
            commit: 9052b5a7781b3346e4cffd452a54448cbff54d8b
          trusted/project_1/opendev.org/zuul/zuul-jobs:
            canonical_name: opendev.org/zuul/zuul-jobs
            checkout: master
            commit: c75fe6ef19c05b98349573c971950c51bbf24758
          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: 9052b5a7781b3346e4cffd452a54448cbff54d8b
          untrusted/project_2/opendev.org/zuul/zuul-jobs:
            canonical_name: opendev.org/zuul/zuul-jobs
            checkout: master
            commit: c75fe6ef19c05b98349573c971950c51bbf24758
          untrusted/project_3/github.com/vexxhost/atmosphere:
            canonical_name: github.com/vexxhost/atmosphere
            checkout: main
            commit: eb8073c17247f6ba46b3352b64201bed328034e2
          untrusted/project_4/opendev.org/openstack/openstack-helm:
            canonical_name: opendev.org/openstack/openstack-helm
            checkout: master
            commit: f5ea292118ac93fc8d50a2424cc2c83907e1df6b
        playbooks:
        - path: untrusted/project_0/github.com/vexxhost/zuul-jobs/playbooks/molecule/run.yaml
          roles:
          - checkout: master
            checkout_description: project default branch
            link_name: ansible/playbook_0/role_1/zuul-jobs
            link_target: untrusted/project_2/opendev.org/zuul/zuul-jobs
            role_path: ansible/playbook_0/role_1/zuul-jobs/roles
          - checkout: main
            checkout_description: playbook branch
            link_name: ansible/playbook_0/role_2/zuul-jobs
            link_target: untrusted/project_0/github.com/vexxhost/zuul-jobs
            role_path: ansible/playbook_0/role_2/zuul-jobs/roles
        post_playbooks:
        - path: untrusted/project_3/github.com/vexxhost/atmosphere/test-playbooks/molecule/post.yml
          roles:
          - checkout: main
            checkout_description: playbook branch
            link_name: ansible/post_playbook_0/role_0/atmosphere
            link_target: untrusted/project_3/github.com/vexxhost/atmosphere
            role_path: ansible/post_playbook_0/role_0/atmosphere/roles
          - checkout: master
            checkout_description: project default branch
            link_name: ansible/post_playbook_0/role_1/openstack-helm
            link_target: untrusted/project_4/opendev.org/openstack/openstack-helm
            role_path: ansible/post_playbook_0/role_1/openstack-helm/roles
          - checkout: master
            checkout_description: project default branch
            link_name: ansible/post_playbook_0/role_3/zuul-jobs
            link_target: untrusted/project_2/opendev.org/zuul/zuul-jobs
            role_path: ansible/post_playbook_0/role_3/zuul-jobs/roles
          - checkout: main
            checkout_description: zuul branch
            link_name: ansible/post_playbook_0/role_4/zuul-jobs
            link_target: untrusted/project_0/github.com/vexxhost/zuul-jobs
            role_path: ansible/post_playbook_0/role_4/zuul-jobs/roles
        - path: trusted/project_0/github.com/vexxhost/zuul-config/playbooks/base/post.yaml
          roles:
          - checkout: master
            checkout_description: project default branch
            link_name: ansible/post_playbook_1/role_1/zuul-jobs
            link_target: trusted/project_1/opendev.org/zuul/zuul-jobs
            role_path: ansible/post_playbook_1/role_1/zuul-jobs/roles
          - checkout: main
            checkout_description: zuul branch
            link_name: ansible/post_playbook_1/role_2/zuul-jobs
            link_target: trusted/project_2/github.com/vexxhost/zuul-jobs
            role_path: ansible/post_playbook_1/role_2/zuul-jobs/roles
        - path: trusted/project_0/github.com/vexxhost/zuul-config/playbooks/base/post-logs.yaml
          roles:
          - checkout: master
            checkout_description: project default branch
            link_name: ansible/post_playbook_2/role_1/zuul-jobs
            link_target: trusted/project_1/opendev.org/zuul/zuul-jobs
            role_path: ansible/post_playbook_2/role_1/zuul-jobs/roles
          - checkout: main
            checkout_description: zuul branch
            link_name: ansible/post_playbook_2/role_2/zuul-jobs
            link_target: trusted/project_2/github.com/vexxhost/zuul-jobs
            role_path: ansible/post_playbook_2/role_2/zuul-jobs/roles
        pre_playbooks:
        - path: trusted/project_0/github.com/vexxhost/zuul-config/playbooks/base/pre.yaml
          roles:
          - checkout: master
            checkout_description: project default branch
            link_name: ansible/pre_playbook_0/role_1/zuul-jobs
            link_target: trusted/project_1/opendev.org/zuul/zuul-jobs
            role_path: ansible/pre_playbook_0/role_1/zuul-jobs/roles
          - checkout: main
            checkout_description: zuul branch
            link_name: ansible/pre_playbook_0/role_2/zuul-jobs
            link_target: trusted/project_2/github.com/vexxhost/zuul-jobs
            role_path: ansible/pre_playbook_0/role_2/zuul-jobs/roles
        - path: untrusted/project_0/github.com/vexxhost/zuul-jobs/playbooks/molecule/pre.yaml
          roles:
          - checkout: master
            checkout_description: project default branch
            link_name: ansible/pre_playbook_1/role_1/zuul-jobs
            link_target: untrusted/project_2/opendev.org/zuul/zuul-jobs
            role_path: ansible/pre_playbook_1/role_1/zuul-jobs/roles
          - checkout: main
            checkout_description: playbook branch
            link_name: ansible/pre_playbook_1/role_2/zuul-jobs
            link_target: untrusted/project_0/github.com/vexxhost/zuul-jobs
            role_path: ansible/pre_playbook_1/role_2/zuul-jobs/roles
        - path: untrusted/project_3/github.com/vexxhost/atmosphere/test-playbooks/molecule/pre.yml
          roles:
          - checkout: main
            checkout_description: playbook branch
            link_name: ansible/pre_playbook_2/role_0/atmosphere
            link_target: untrusted/project_3/github.com/vexxhost/atmosphere
            role_path: ansible/pre_playbook_2/role_0/atmosphere/roles
          - checkout: master
            checkout_description: project default branch
            link_name: ansible/pre_playbook_2/role_1/openstack-helm
            link_target: untrusted/project_4/opendev.org/openstack/openstack-helm
            role_path: ansible/pre_playbook_2/role_1/openstack-helm/roles
          - checkout: master
            checkout_description: project default branch
            link_name: ansible/pre_playbook_2/role_3/zuul-jobs
            link_target: untrusted/project_2/opendev.org/zuul/zuul-jobs
            role_path: ansible/pre_playbook_2/role_3/zuul-jobs/roles
          - checkout: main
            checkout_description: zuul branch
            link_name: ansible/pre_playbook_2/role_4/zuul-jobs
            link_target: untrusted/project_0/github.com/vexxhost/zuul-jobs
            role_path: ansible/pre_playbook_2/role_4/zuul-jobs/roles
      post_review: false
      post_timeout: null
      pre_timeout: null
      project:
        canonical_hostname: github.com
        canonical_name: github.com/vexxhost/atmosphere
        name: vexxhost/atmosphere
        short_name: atmosphere
        src_dir: src/github.com/vexxhost/atmosphere
      projects:
        github.com/vexxhost/atmosphere:
          canonical_hostname: github.com
          canonical_name: github.com/vexxhost/atmosphere
          checkout: main
          checkout_description: zuul branch
          commit: eb8073c17247f6ba46b3352b64201bed328034e2
          name: vexxhost/atmosphere
          required: false
          short_name: atmosphere
          src_dir: src/github.com/vexxhost/atmosphere
      ref: refs/pull/3764/head
      resources: {}
      tenant: oss
      timeout: 1800
      topic: null
      voting: true
