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.246
      ansible_port: 22
      ansible_python_interpreter: auto
      ansible_user: zuul
      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
      cilium_ipv4_cidr: 172.24.0.0/16
      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: 96973787-5a5c-4aa3-9064-258c19399cbb
        host_id: a14e37c14509a0e10156ccf8c706cd5613db7e363735e5577c330644
        interface_ip: 199.204.45.246
        label: ubuntu-jammy
        node_properties: {}
        private_ipv4: 199.204.45.246
        private_ipv6: null
        provider: yul1
        public_ipv4: 199.204.45.246
        public_ipv6: 2604:e100:1:0:f816:3eff:fe58:ef34
        region: ca-ymq-1
        slot: null
      zuul_node:
        az: nova
        cloud: public
        external_id: 96973787-5a5c-4aa3-9064-258c19399cbb
        host_id: a14e37c14509a0e10156ccf8c706cd5613db7e363735e5577c330644
        interface_ip: 199.204.45.246
        label: ubuntu-jammy
        node_properties: {}
        private_ipv4: 199.204.45.246
        private_ipv6: null
        provider: yul1
        public_ipv4: 199.204.45.246
        public_ipv6: 2604:e100:1:0:f816:3eff:fe58:ef34
        region: ca-ymq-1
        slot: null
        uuid: null
  vars:
    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
    cilium_ipv4_cidr: 172.24.0.0/16
    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#17>'
      - '<Job atmosphere-molecule-csi explicit: None implied: {MatchAny:{ImpliedBranchMatcher:main}}
        source: vexxhost/atmosphere/.zuul.yaml@main#53>'
      - '<Job atmosphere-molecule-csi-local-path-provisioner explicit: None implied:
        {MatchAny:{ImpliedBranchMatcher:main}} source: vexxhost/atmosphere/.zuul.yaml@main#60>'
      - '<Job atmosphere-molecule-csi-local-path-provisioner explicit: None implied:
        None source: vexxhost/atmosphere/.zuul.yaml@main#72>'
      ansible_version: '9'
      attempts: 1
      branch: main
      build: e29d844c184146a89f87241776f30ae2
      build_refs:
      - branch: main
        change: '3672'
        change_message: 'feat(monitoring): add transceiver-exporter role


          ## Summary


          Add a new Ansible role to deploy the transceiver-exporter Helm chart, a
          Prometheus exporter for network transceivers (SFP, SFP+, QSFP). The chart
          deploys a DaemonSet on all servers with hostNetwork access and NET_ADMIN
          capability to read transceiver EEPROM data.


          ## Changes


          - Vendored `transceiver-exporter` Helm chart (v0.1.2) from [yaguangtang/transceiver-exporter](https://github.com/yaguangtang/transceiver-exporter)

          - Created `roles/transceiver_exporter` role following existing patterns
          (goldpinger, ingress_nginx)

          - Added image reference to `roles/defaults/vars/main.yml`

          - Added role to `playbooks/monitoring.yml` with conditional deployment


          ## Usage


          Deployment is **disabled by default**. To enable:


          ```yaml

          atmosphere_transceiver_exporter_enabled: true

          ```


          When enabled, the exporter runs as a DaemonSet on all servers, exposing
          optical power and transceiver health metrics on port 9458. A ServiceMonitor
          is enabled by default for Prometheus scraping.


          ## Jira


          A8E-85'
        change_url: https://github.com/vexxhost/atmosphere/pull/3672
        commit_id: 16bce223f502558d07bc0b4151d5c2751297551e
        patchset: 16bce223f502558d07bc0b4151d5c2751297551e
        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: 883571bec0054e0dba97a63c48313b15
      buildset_refs:
      - branch: main
        change: '3672'
        change_message: 'feat(monitoring): add transceiver-exporter role


          ## Summary


          Add a new Ansible role to deploy the transceiver-exporter Helm chart, a
          Prometheus exporter for network transceivers (SFP, SFP+, QSFP). The chart
          deploys a DaemonSet on all servers with hostNetwork access and NET_ADMIN
          capability to read transceiver EEPROM data.


          ## Changes


          - Vendored `transceiver-exporter` Helm chart (v0.1.2) from [yaguangtang/transceiver-exporter](https://github.com/yaguangtang/transceiver-exporter)

          - Created `roles/transceiver_exporter` role following existing patterns
          (goldpinger, ingress_nginx)

          - Added image reference to `roles/defaults/vars/main.yml`

          - Added role to `playbooks/monitoring.yml` with conditional deployment


          ## Usage


          Deployment is **disabled by default**. To enable:


          ```yaml

          atmosphere_transceiver_exporter_enabled: true

          ```


          When enabled, the exporter runs as a DaemonSet on all servers, exposing
          optical power and transceiver health metrics on port 9458. A ServiceMonitor
          is enabled by default for Prometheus scraping.


          ## Jira


          A8E-85'
        change_url: https://github.com/vexxhost/atmosphere/pull/3672
        commit_id: 16bce223f502558d07bc0b4151d5c2751297551e
        patchset: 16bce223f502558d07bc0b4151d5c2751297551e
        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: '3672'
      change_message: 'feat(monitoring): add transceiver-exporter role


        ## Summary


        Add a new Ansible role to deploy the transceiver-exporter Helm chart, a Prometheus
        exporter for network transceivers (SFP, SFP+, QSFP). The chart deploys a DaemonSet
        on all servers with hostNetwork access and NET_ADMIN capability to read transceiver
        EEPROM data.


        ## Changes


        - Vendored `transceiver-exporter` Helm chart (v0.1.2) from [yaguangtang/transceiver-exporter](https://github.com/yaguangtang/transceiver-exporter)

        - Created `roles/transceiver_exporter` role following existing patterns (goldpinger,
        ingress_nginx)

        - Added image reference to `roles/defaults/vars/main.yml`

        - Added role to `playbooks/monitoring.yml` with conditional deployment


        ## Usage


        Deployment is **disabled by default**. To enable:


        ```yaml

        atmosphere_transceiver_exporter_enabled: true

        ```


        When enabled, the exporter runs as a DaemonSet on all servers, exposing optical
        power and transceiver health metrics on port 9458. A ServiceMonitor is enabled
        by default for Prometheus scraping.


        ## Jira


        A8E-85'
      change_url: https://github.com/vexxhost/atmosphere/pull/3672
      child_jobs: []
      commit_id: 16bce223f502558d07bc0b4151d5c2751297551e
      event_id: 7bc68900-0e74-11f1-9ba7-49cd86ebdee5
      executor:
        hostname: 0a8996d2b663
        inventory_file: /var/lib/zuul/builds/e29d844c184146a89f87241776f30ae2/ansible/inventory.yaml
        log_root: /var/lib/zuul/builds/e29d844c184146a89f87241776f30ae2/work/logs
        result_data_file: /var/lib/zuul/builds/e29d844c184146a89f87241776f30ae2/work/results.json
        src_root: /var/lib/zuul/builds/e29d844c184146a89f87241776f30ae2/work/src
        work_root: /var/lib/zuul/builds/e29d844c184146a89f87241776f30ae2/work
      include_vars: []
      items:
      - branch: main
        change: '3672'
        change_message: 'feat(monitoring): add transceiver-exporter role


          ## Summary


          Add a new Ansible role to deploy the transceiver-exporter Helm chart, a
          Prometheus exporter for network transceivers (SFP, SFP+, QSFP). The chart
          deploys a DaemonSet on all servers with hostNetwork access and NET_ADMIN
          capability to read transceiver EEPROM data.


          ## Changes


          - Vendored `transceiver-exporter` Helm chart (v0.1.2) from [yaguangtang/transceiver-exporter](https://github.com/yaguangtang/transceiver-exporter)

          - Created `roles/transceiver_exporter` role following existing patterns
          (goldpinger, ingress_nginx)

          - Added image reference to `roles/defaults/vars/main.yml`

          - Added role to `playbooks/monitoring.yml` with conditional deployment


          ## Usage


          Deployment is **disabled by default**. To enable:


          ```yaml

          atmosphere_transceiver_exporter_enabled: true

          ```


          When enabled, the exporter runs as a DaemonSet on all servers, exposing
          optical power and transceiver health metrics on port 9458. A ServiceMonitor
          is enabled by default for Prometheus scraping.


          ## Jira


          A8E-85'
        change_url: https://github.com/vexxhost/atmosphere/pull/3672
        commit_id: 16bce223f502558d07bc0b4151d5c2751297551e
        patchset: 16bce223f502558d07bc0b4151d5c2751297551e
        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: ZmVhdChtb25pdG9yaW5nKTogYWRkIHRyYW5zY2VpdmVyLWV4cG9ydGVyIHJvbGUKCiMjIFN1bW1hcnkKCkFkZCBhIG5ldyBBbnNpYmxlIHJvbGUgdG8gZGVwbG95IHRoZSB0cmFuc2NlaXZlci1leHBvcnRlciBIZWxtIGNoYXJ0LCBhIFByb21ldGhldXMgZXhwb3J0ZXIgZm9yIG5ldHdvcmsgdHJhbnNjZWl2ZXJzIChTRlAsIFNGUCssIFFTRlApLiBUaGUgY2hhcnQgZGVwbG95cyBhIERhZW1vblNldCBvbiBhbGwgc2VydmVycyB3aXRoIGhvc3ROZXR3b3JrIGFjY2VzcyBhbmQgTkVUX0FETUlOIGNhcGFiaWxpdHkgdG8gcmVhZCB0cmFuc2NlaXZlciBFRVBST00gZGF0YS4KCiMjIENoYW5nZXMKCi0gVmVuZG9yZWQgYHRyYW5zY2VpdmVyLWV4cG9ydGVyYCBIZWxtIGNoYXJ0ICh2MC4xLjIpIGZyb20gW3lhZ3Vhbmd0YW5nL3RyYW5zY2VpdmVyLWV4cG9ydGVyXShodHRwczovL2dpdGh1Yi5jb20veWFndWFuZ3RhbmcvdHJhbnNjZWl2ZXItZXhwb3J0ZXIpCi0gQ3JlYXRlZCBgcm9sZXMvdHJhbnNjZWl2ZXJfZXhwb3J0ZXJgIHJvbGUgZm9sbG93aW5nIGV4aXN0aW5nIHBhdHRlcm5zIChnb2xkcGluZ2VyLCBpbmdyZXNzX25naW54KQotIEFkZGVkIGltYWdlIHJlZmVyZW5jZSB0byBgcm9sZXMvZGVmYXVsdHMvdmFycy9tYWluLnltbGAKLSBBZGRlZCByb2xlIHRvIGBwbGF5Ym9va3MvbW9uaXRvcmluZy55bWxgIHdpdGggY29uZGl0aW9uYWwgZGVwbG95bWVudAoKIyMgVXNhZ2UKCkRlcGxveW1lbnQgaXMgKipkaXNhYmxlZCBieSBkZWZhdWx0KiouIFRvIGVuYWJsZToKCmBgYHlhbWwKYXRtb3NwaGVyZV90cmFuc2NlaXZlcl9leHBvcnRlcl9lbmFibGVkOiB0cnVlCmBgYAoKV2hlbiBlbmFibGVkLCB0aGUgZXhwb3J0ZXIgcnVucyBhcyBhIERhZW1vblNldCBvbiBhbGwgc2VydmVycywgZXhwb3Npbmcgb3B0aWNhbCBwb3dlciBhbmQgdHJhbnNjZWl2ZXIgaGVhbHRoIG1ldHJpY3Mgb24gcG9ydCA5NDU4LiBBIFNlcnZpY2VNb25pdG9yIGlzIGVuYWJsZWQgYnkgZGVmYXVsdCBmb3IgUHJvbWV0aGV1cyBzY3JhcGluZy4KCiMjIEppcmEKCkE4RS04NQ==
      patchset: 16bce223f502558d07bc0b4151d5c2751297551e
      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: 571c0efa3491d12ecb8fc1169c510716d55c0fc2
          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: 571c0efa3491d12ecb8fc1169c510716d55c0fc2
          untrusted/project_3/github.com/vexxhost/atmosphere:
            canonical_name: github.com/vexxhost/atmosphere
            checkout: main
            commit: 16bce223f502558d07bc0b4151d5c2751297551e
          untrusted/project_4/opendev.org/openstack/openstack-helm:
            canonical_name: opendev.org/openstack/openstack-helm
            checkout: master
            commit: 8fa093de316a94eeff942a3dd8cd3b43d35f2249
        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: 16bce223f502558d07bc0b4151d5c2751297551e
          name: vexxhost/atmosphere
          required: false
          short_name: atmosphere
          src_dir: src/github.com/vexxhost/atmosphere
      ref: refs/pull/3672/head
      resources: {}
      tenant: oss
      timeout: 1800
      topic: null
      voting: true
