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.78
      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
      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: 8e0debca-0c28-4474-83ce-c320a5935f64
        host_id: 41a201ef72a259be12e3756e510383f2b77edc2ac36483fdab96a683
        interface_ip: 199.204.45.78
        label: ubuntu-jammy
        node_properties: {}
        private_ipv4: 199.204.45.78
        private_ipv6: null
        provider: yul1
        public_ipv4: 199.204.45.78
        public_ipv6: 2604:e100:1:0:f816:3eff:fe50:1d33
        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: 8e0debca-0c28-4474-83ce-c320a5935f64
        host_id: 41a201ef72a259be12e3756e510383f2b77edc2ac36483fdab96a683
        interface_ip: 199.204.45.78
        label: ubuntu-jammy
        node_properties: {}
        private_ipv4: 199.204.45.78
        private_ipv6: null
        provider: yul1
        public_ipv4: 199.204.45.78
        public_ipv6: 2604:e100:1:0:f816:3eff:fe50:1d33
        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
    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#24>'
      - '<Job atmosphere-molecule-keycloak explicit: None implied: {MatchAny:{ImpliedBranchMatcher:main}}
        source: vexxhost/atmosphere/.zuul.yaml@main#273>'
      - '<Job atmosphere-molecule-keycloak explicit: None implied: None source: vexxhost/atmosphere/.zuul.yaml@main#295>'
      ansible_version: '9'
      attempts: 1
      branch: main
      build: ee64fda0371c4dc1856321a8a74d91c5
      build_refs:
      - branch: main
        change: '3935'
        change_message: "fix(kube-prometheus-stack): account for hugepage memory\n\n##
          Summary\n\n- update `NodeMemoryHighUtilization` to count free hugepage capacity
          as available memory\n- keep normal behavior for nodes without hugepage metrics
          by falling back to zero hugepage capacity\n- add rule tests for the hugepage-backed
          compute false positive and the genuine low-memory alert path\n- add a runbook
          entry for `NodeMemoryHighUtilization`\n\nFixes #3934\n\n## Test Method and
          Result\n\n### Generated rule check\n\nMethod:\n\n```console\njsonnet -J
          roles/kube_prometheus_stack/files/jsonnet/vendor \\\n  -J roles/kube_prometheus_stack/files/jsonnet
          \\\n  -e 'local rules = import \"rules.jsonnet\"; rules.node'\n```\n\nResult:\n\nThe
          generated `NodeMemoryHighUtilization` expression includes free hugepage
          capacity via `node_memory_HugePages_Free * node_memory_Hugepagesize_bytes`,
          plus a fallback for nodes without hugepage metrics using `node_memory_MemAvailable_bytes
          * 0`.\n\n### Local rule unit test\n\nMethod:\n\n```console\nCGO_ENABLED=0
          go test -count=1 -v -run 'TestPrometheusRules/NodeMemoryHighUtilization'
          ./roles/kube_prometheus_stack/\n```\n\nResult:\n\n```text\n--- PASS: TestPrometheusRules\n
          \   --- PASS: TestPrometheusRules/NodeMemoryHighUtilization\n    --- PASS:
          TestPrometheusRules/NodeMemoryHighUtilization#01\nPASS\n```\n\n### Live
          Prometheus validation on 38.108.68.19\n\nMethod:\n\n- Queried the deployed
          Prometheus pod `prometheus-kube-prometheus-stack-prometheus-0`.\n- Confirmed
          the AIO host currently has no reserved hugepages:\n\n```text\nHugePages_Total:
          \      0\nHugePages_Free:        0\n```\n\n- Queried current and fixed expressions
          against live node-exporter metrics.\n- Ran a synthetic `promtool test rules`
          case inside the live Prometheus pod using the issue shape: 755 GiB total
          memory, 17 GiB `MemAvailable`, and 720 free 1 GiB hugepages.\n- Also tested
          the genuine low-memory path for a node without hugepage metrics.\n\nResult:\n\n-
          Live AIO host: current and fixed utilization both evaluated to `44.86987878263691`;
          both alert vectors were empty, which is expected for this host.\n- Synthetic
          production-shaped case: current expression fired; fixed expression did not
          fire.\n- Synthetic real low-memory case: fixed expression still fired.\n-
          Prometheus pod validation completed with:\n\n```text\nUnit Testing:  /prometheus/node-memory-hugepages-test.yml\n
          \ SUCCESS\n```\n"
        change_url: https://github.com/vexxhost/atmosphere/pull/3935
        commit_id: a6d5b4572359d9b550f7137536df614196cc3bb6
        patchset: a6d5b4572359d9b550f7137536df614196cc3bb6
        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: 933e76d5dd7f43539c6b810dea28438b
      buildset_refs:
      - branch: main
        change: '3935'
        change_message: "fix(kube-prometheus-stack): account for hugepage memory\n\n##
          Summary\n\n- update `NodeMemoryHighUtilization` to count free hugepage capacity
          as available memory\n- keep normal behavior for nodes without hugepage metrics
          by falling back to zero hugepage capacity\n- add rule tests for the hugepage-backed
          compute false positive and the genuine low-memory alert path\n- add a runbook
          entry for `NodeMemoryHighUtilization`\n\nFixes #3934\n\n## Test Method and
          Result\n\n### Generated rule check\n\nMethod:\n\n```console\njsonnet -J
          roles/kube_prometheus_stack/files/jsonnet/vendor \\\n  -J roles/kube_prometheus_stack/files/jsonnet
          \\\n  -e 'local rules = import \"rules.jsonnet\"; rules.node'\n```\n\nResult:\n\nThe
          generated `NodeMemoryHighUtilization` expression includes free hugepage
          capacity via `node_memory_HugePages_Free * node_memory_Hugepagesize_bytes`,
          plus a fallback for nodes without hugepage metrics using `node_memory_MemAvailable_bytes
          * 0`.\n\n### Local rule unit test\n\nMethod:\n\n```console\nCGO_ENABLED=0
          go test -count=1 -v -run 'TestPrometheusRules/NodeMemoryHighUtilization'
          ./roles/kube_prometheus_stack/\n```\n\nResult:\n\n```text\n--- PASS: TestPrometheusRules\n
          \   --- PASS: TestPrometheusRules/NodeMemoryHighUtilization\n    --- PASS:
          TestPrometheusRules/NodeMemoryHighUtilization#01\nPASS\n```\n\n### Live
          Prometheus validation on 38.108.68.19\n\nMethod:\n\n- Queried the deployed
          Prometheus pod `prometheus-kube-prometheus-stack-prometheus-0`.\n- Confirmed
          the AIO host currently has no reserved hugepages:\n\n```text\nHugePages_Total:
          \      0\nHugePages_Free:        0\n```\n\n- Queried current and fixed expressions
          against live node-exporter metrics.\n- Ran a synthetic `promtool test rules`
          case inside the live Prometheus pod using the issue shape: 755 GiB total
          memory, 17 GiB `MemAvailable`, and 720 free 1 GiB hugepages.\n- Also tested
          the genuine low-memory path for a node without hugepage metrics.\n\nResult:\n\n-
          Live AIO host: current and fixed utilization both evaluated to `44.86987878263691`;
          both alert vectors were empty, which is expected for this host.\n- Synthetic
          production-shaped case: current expression fired; fixed expression did not
          fire.\n- Synthetic real low-memory case: fixed expression still fired.\n-
          Prometheus pod validation completed with:\n\n```text\nUnit Testing:  /prometheus/node-memory-hugepages-test.yml\n
          \ SUCCESS\n```\n"
        change_url: https://github.com/vexxhost/atmosphere/pull/3935
        commit_id: a6d5b4572359d9b550f7137536df614196cc3bb6
        patchset: a6d5b4572359d9b550f7137536df614196cc3bb6
        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: '3935'
      change_message: "fix(kube-prometheus-stack): account for hugepage memory\n\n##
        Summary\n\n- update `NodeMemoryHighUtilization` to count free hugepage capacity
        as available memory\n- keep normal behavior for nodes without hugepage metrics
        by falling back to zero hugepage capacity\n- add rule tests for the hugepage-backed
        compute false positive and the genuine low-memory alert path\n- add a runbook
        entry for `NodeMemoryHighUtilization`\n\nFixes #3934\n\n## Test Method and
        Result\n\n### Generated rule check\n\nMethod:\n\n```console\njsonnet -J roles/kube_prometheus_stack/files/jsonnet/vendor
        \\\n  -J roles/kube_prometheus_stack/files/jsonnet \\\n  -e 'local rules =
        import \"rules.jsonnet\"; rules.node'\n```\n\nResult:\n\nThe generated `NodeMemoryHighUtilization`
        expression includes free hugepage capacity via `node_memory_HugePages_Free
        * node_memory_Hugepagesize_bytes`, plus a fallback for nodes without hugepage
        metrics using `node_memory_MemAvailable_bytes * 0`.\n\n### Local rule unit
        test\n\nMethod:\n\n```console\nCGO_ENABLED=0 go test -count=1 -v -run 'TestPrometheusRules/NodeMemoryHighUtilization'
        ./roles/kube_prometheus_stack/\n```\n\nResult:\n\n```text\n--- PASS: TestPrometheusRules\n
        \   --- PASS: TestPrometheusRules/NodeMemoryHighUtilization\n    --- PASS:
        TestPrometheusRules/NodeMemoryHighUtilization#01\nPASS\n```\n\n### Live Prometheus
        validation on 38.108.68.19\n\nMethod:\n\n- Queried the deployed Prometheus
        pod `prometheus-kube-prometheus-stack-prometheus-0`.\n- Confirmed the AIO
        host currently has no reserved hugepages:\n\n```text\nHugePages_Total:       0\nHugePages_Free:
        \       0\n```\n\n- Queried current and fixed expressions against live node-exporter
        metrics.\n- Ran a synthetic `promtool test rules` case inside the live Prometheus
        pod using the issue shape: 755 GiB total memory, 17 GiB `MemAvailable`, and
        720 free 1 GiB hugepages.\n- Also tested the genuine low-memory path for a
        node without hugepage metrics.\n\nResult:\n\n- Live AIO host: current and
        fixed utilization both evaluated to `44.86987878263691`; both alert vectors
        were empty, which is expected for this host.\n- Synthetic production-shaped
        case: current expression fired; fixed expression did not fire.\n- Synthetic
        real low-memory case: fixed expression still fired.\n- Prometheus pod validation
        completed with:\n\n```text\nUnit Testing:  /prometheus/node-memory-hugepages-test.yml\n
        \ SUCCESS\n```\n"
      change_url: https://github.com/vexxhost/atmosphere/pull/3935
      child_jobs: []
      commit_id: a6d5b4572359d9b550f7137536df614196cc3bb6
      event_id: dc61c8c0-5324-11f1-9e74-41e0869f9750
      executor:
        hostname: 2d72f0692154
        inventory_file: /var/lib/zuul/builds/ee64fda0371c4dc1856321a8a74d91c5/ansible/inventory.yaml
        log_root: /var/lib/zuul/builds/ee64fda0371c4dc1856321a8a74d91c5/work/logs
        result_data_file: /var/lib/zuul/builds/ee64fda0371c4dc1856321a8a74d91c5/work/results.json
        src_root: /var/lib/zuul/builds/ee64fda0371c4dc1856321a8a74d91c5/work/src
        work_root: /var/lib/zuul/builds/ee64fda0371c4dc1856321a8a74d91c5/work
      include_vars: []
      items:
      - branch: main
        change: '3935'
        change_message: "fix(kube-prometheus-stack): account for hugepage memory\n\n##
          Summary\n\n- update `NodeMemoryHighUtilization` to count free hugepage capacity
          as available memory\n- keep normal behavior for nodes without hugepage metrics
          by falling back to zero hugepage capacity\n- add rule tests for the hugepage-backed
          compute false positive and the genuine low-memory alert path\n- add a runbook
          entry for `NodeMemoryHighUtilization`\n\nFixes #3934\n\n## Test Method and
          Result\n\n### Generated rule check\n\nMethod:\n\n```console\njsonnet -J
          roles/kube_prometheus_stack/files/jsonnet/vendor \\\n  -J roles/kube_prometheus_stack/files/jsonnet
          \\\n  -e 'local rules = import \"rules.jsonnet\"; rules.node'\n```\n\nResult:\n\nThe
          generated `NodeMemoryHighUtilization` expression includes free hugepage
          capacity via `node_memory_HugePages_Free * node_memory_Hugepagesize_bytes`,
          plus a fallback for nodes without hugepage metrics using `node_memory_MemAvailable_bytes
          * 0`.\n\n### Local rule unit test\n\nMethod:\n\n```console\nCGO_ENABLED=0
          go test -count=1 -v -run 'TestPrometheusRules/NodeMemoryHighUtilization'
          ./roles/kube_prometheus_stack/\n```\n\nResult:\n\n```text\n--- PASS: TestPrometheusRules\n
          \   --- PASS: TestPrometheusRules/NodeMemoryHighUtilization\n    --- PASS:
          TestPrometheusRules/NodeMemoryHighUtilization#01\nPASS\n```\n\n### Live
          Prometheus validation on 38.108.68.19\n\nMethod:\n\n- Queried the deployed
          Prometheus pod `prometheus-kube-prometheus-stack-prometheus-0`.\n- Confirmed
          the AIO host currently has no reserved hugepages:\n\n```text\nHugePages_Total:
          \      0\nHugePages_Free:        0\n```\n\n- Queried current and fixed expressions
          against live node-exporter metrics.\n- Ran a synthetic `promtool test rules`
          case inside the live Prometheus pod using the issue shape: 755 GiB total
          memory, 17 GiB `MemAvailable`, and 720 free 1 GiB hugepages.\n- Also tested
          the genuine low-memory path for a node without hugepage metrics.\n\nResult:\n\n-
          Live AIO host: current and fixed utilization both evaluated to `44.86987878263691`;
          both alert vectors were empty, which is expected for this host.\n- Synthetic
          production-shaped case: current expression fired; fixed expression did not
          fire.\n- Synthetic real low-memory case: fixed expression still fired.\n-
          Prometheus pod validation completed with:\n\n```text\nUnit Testing:  /prometheus/node-memory-hugepages-test.yml\n
          \ SUCCESS\n```\n"
        change_url: https://github.com/vexxhost/atmosphere/pull/3935
        commit_id: a6d5b4572359d9b550f7137536df614196cc3bb6
        patchset: a6d5b4572359d9b550f7137536df614196cc3bb6
        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: Zml4KGt1YmUtcHJvbWV0aGV1cy1zdGFjayk6IGFjY291bnQgZm9yIGh1Z2VwYWdlIG1lbW9yeQoKIyMgU3VtbWFyeQoKLSB1cGRhdGUgYE5vZGVNZW1vcnlIaWdoVXRpbGl6YXRpb25gIHRvIGNvdW50IGZyZWUgaHVnZXBhZ2UgY2FwYWNpdHkgYXMgYXZhaWxhYmxlIG1lbW9yeQotIGtlZXAgbm9ybWFsIGJlaGF2aW9yIGZvciBub2RlcyB3aXRob3V0IGh1Z2VwYWdlIG1ldHJpY3MgYnkgZmFsbGluZyBiYWNrIHRvIHplcm8gaHVnZXBhZ2UgY2FwYWNpdHkKLSBhZGQgcnVsZSB0ZXN0cyBmb3IgdGhlIGh1Z2VwYWdlLWJhY2tlZCBjb21wdXRlIGZhbHNlIHBvc2l0aXZlIGFuZCB0aGUgZ2VudWluZSBsb3ctbWVtb3J5IGFsZXJ0IHBhdGgKLSBhZGQgYSBydW5ib29rIGVudHJ5IGZvciBgTm9kZU1lbW9yeUhpZ2hVdGlsaXphdGlvbmAKCkZpeGVzICMzOTM0CgojIyBUZXN0IE1ldGhvZCBhbmQgUmVzdWx0CgojIyMgR2VuZXJhdGVkIHJ1bGUgY2hlY2sKCk1ldGhvZDoKCmBgYGNvbnNvbGUKanNvbm5ldCAtSiByb2xlcy9rdWJlX3Byb21ldGhldXNfc3RhY2svZmlsZXMvanNvbm5ldC92ZW5kb3IgXAogIC1KIHJvbGVzL2t1YmVfcHJvbWV0aGV1c19zdGFjay9maWxlcy9qc29ubmV0IFwKICAtZSAnbG9jYWwgcnVsZXMgPSBpbXBvcnQgInJ1bGVzLmpzb25uZXQiOyBydWxlcy5ub2RlJwpgYGAKClJlc3VsdDoKClRoZSBnZW5lcmF0ZWQgYE5vZGVNZW1vcnlIaWdoVXRpbGl6YXRpb25gIGV4cHJlc3Npb24gaW5jbHVkZXMgZnJlZSBodWdlcGFnZSBjYXBhY2l0eSB2aWEgYG5vZGVfbWVtb3J5X0h1Z2VQYWdlc19GcmVlICogbm9kZV9tZW1vcnlfSHVnZXBhZ2VzaXplX2J5dGVzYCwgcGx1cyBhIGZhbGxiYWNrIGZvciBub2RlcyB3aXRob3V0IGh1Z2VwYWdlIG1ldHJpY3MgdXNpbmcgYG5vZGVfbWVtb3J5X01lbUF2YWlsYWJsZV9ieXRlcyAqIDBgLgoKIyMjIExvY2FsIHJ1bGUgdW5pdCB0ZXN0CgpNZXRob2Q6CgpgYGBjb25zb2xlCkNHT19FTkFCTEVEPTAgZ28gdGVzdCAtY291bnQ9MSAtdiAtcnVuICdUZXN0UHJvbWV0aGV1c1J1bGVzL05vZGVNZW1vcnlIaWdoVXRpbGl6YXRpb24nIC4vcm9sZXMva3ViZV9wcm9tZXRoZXVzX3N0YWNrLwpgYGAKClJlc3VsdDoKCmBgYHRleHQKLS0tIFBBU1M6IFRlc3RQcm9tZXRoZXVzUnVsZXMKICAgIC0tLSBQQVNTOiBUZXN0UHJvbWV0aGV1c1J1bGVzL05vZGVNZW1vcnlIaWdoVXRpbGl6YXRpb24KICAgIC0tLSBQQVNTOiBUZXN0UHJvbWV0aGV1c1J1bGVzL05vZGVNZW1vcnlIaWdoVXRpbGl6YXRpb24jMDEKUEFTUwpgYGAKCiMjIyBMaXZlIFByb21ldGhldXMgdmFsaWRhdGlvbiBvbiAzOC4xMDguNjguMTkKCk1ldGhvZDoKCi0gUXVlcmllZCB0aGUgZGVwbG95ZWQgUHJvbWV0aGV1cyBwb2QgYHByb21ldGhldXMta3ViZS1wcm9tZXRoZXVzLXN0YWNrLXByb21ldGhldXMtMGAuCi0gQ29uZmlybWVkIHRoZSBBSU8gaG9zdCBjdXJyZW50bHkgaGFzIG5vIHJlc2VydmVkIGh1Z2VwYWdlczoKCmBgYHRleHQKSHVnZVBhZ2VzX1RvdGFsOiAgICAgICAwCkh1Z2VQYWdlc19GcmVlOiAgICAgICAgMApgYGAKCi0gUXVlcmllZCBjdXJyZW50IGFuZCBmaXhlZCBleHByZXNzaW9ucyBhZ2FpbnN0IGxpdmUgbm9kZS1leHBvcnRlciBtZXRyaWNzLgotIFJhbiBhIHN5bnRoZXRpYyBgcHJvbXRvb2wgdGVzdCBydWxlc2AgY2FzZSBpbnNpZGUgdGhlIGxpdmUgUHJvbWV0aGV1cyBwb2QgdXNpbmcgdGhlIGlzc3VlIHNoYXBlOiA3NTUgR2lCIHRvdGFsIG1lbW9yeSwgMTcgR2lCIGBNZW1BdmFpbGFibGVgLCBhbmQgNzIwIGZyZWUgMSBHaUIgaHVnZXBhZ2VzLgotIEFsc28gdGVzdGVkIHRoZSBnZW51aW5lIGxvdy1tZW1vcnkgcGF0aCBmb3IgYSBub2RlIHdpdGhvdXQgaHVnZXBhZ2UgbWV0cmljcy4KClJlc3VsdDoKCi0gTGl2ZSBBSU8gaG9zdDogY3VycmVudCBhbmQgZml4ZWQgdXRpbGl6YXRpb24gYm90aCBldmFsdWF0ZWQgdG8gYDQ0Ljg2OTg3ODc4MjYzNjkxYDsgYm90aCBhbGVydCB2ZWN0b3JzIHdlcmUgZW1wdHksIHdoaWNoIGlzIGV4cGVjdGVkIGZvciB0aGlzIGhvc3QuCi0gU3ludGhldGljIHByb2R1Y3Rpb24tc2hhcGVkIGNhc2U6IGN1cnJlbnQgZXhwcmVzc2lvbiBmaXJlZDsgZml4ZWQgZXhwcmVzc2lvbiBkaWQgbm90IGZpcmUuCi0gU3ludGhldGljIHJlYWwgbG93LW1lbW9yeSBjYXNlOiBmaXhlZCBleHByZXNzaW9uIHN0aWxsIGZpcmVkLgotIFByb21ldGhldXMgcG9kIHZhbGlkYXRpb24gY29tcGxldGVkIHdpdGg6CgpgYGB0ZXh0ClVuaXQgVGVzdGluZzogIC9wcm9tZXRoZXVzL25vZGUtbWVtb3J5LWh1Z2VwYWdlcy10ZXN0LnltbAogIFNVQ0NFU1MKYGBgCg==
      patchset: a6d5b4572359d9b550f7137536df614196cc3bb6
      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: 79fe3eb1d01f8ac5739b0b7bc4759c407b6e248d
          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: 79fe3eb1d01f8ac5739b0b7bc4759c407b6e248d
          untrusted/project_3/github.com/vexxhost/atmosphere:
            canonical_name: github.com/vexxhost/atmosphere
            checkout: main
            commit: a6d5b4572359d9b550f7137536df614196cc3bb6
          untrusted/project_4/opendev.org/openstack/openstack-helm:
            canonical_name: opendev.org/openstack/openstack-helm
            checkout: master
            commit: ebd6507b8b84365fe43c389f9571959da7b0826c
        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: a6d5b4572359d9b550f7137536df614196cc3bb6
          name: vexxhost/atmosphere
          required: false
          short_name: atmosphere
          src_dir: src/github.com/vexxhost/atmosphere
      ref: refs/pull/3935/head
      resources: {}
      tenant: oss
      timeout: 1800
      topic: null
      voting: true
