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.19.214.33
      ansible_port: 22
      ansible_python_interpreter: auto
      ansible_user: zuul
      nodepool:
        az: nova
        cloud: public
        external_id: 9d38911d-0316-4fdf-b468-4012c90e204f
        host_id: b3056f425dc12eb7c2b177d04ce92ce8e9d8895ce2af8682a7cd0f26
        interface_ip: 199.19.214.33
        label: ubuntu-jammy
        node_properties: {}
        private_ipv4: 199.19.214.33
        private_ipv6: null
        provider: yul1
        public_ipv4: 199.19.214.33
        public_ipv6: 2604:e100:1:0:f816:3eff:fe1d:9a98
        region: ca-ymq-1
        slot: null
      zuul_node:
        az: nova
        cloud: public
        external_id: 9d38911d-0316-4fdf-b468-4012c90e204f
        host_id: b3056f425dc12eb7c2b177d04ce92ce8e9d8895ce2af8682a7cd0f26
        interface_ip: 199.19.214.33
        label: ubuntu-jammy
        node_properties: {}
        private_ipv4: 199.19.214.33
        private_ipv6: null
        provider: yul1
        public_ipv4: 199.19.214.33
        public_ipv6: 2604:e100:1:0:f816:3eff:fe1d:9a98
        region: ca-ymq-1
        slot: null
        uuid: null
  vars:
    zuul:
      _inheritance_path:
      - '<Job base explicit: None implied: {MatchAny:{ImpliedBranchMatcher:main}}
        source: vexxhost/zuul-config/zuul.d/jobs.yaml@main#1>'
      - '<Job atmosphere-go-test explicit: None implied: {MatchAny:{ImpliedBranchMatcher:main}}
        source: vexxhost/atmosphere/.zuul.yaml@main#24>'
      - '<Job atmosphere-go-test explicit: None implied: None source: vexxhost/atmosphere/.zuul.yaml@main#324>'
      ansible_version: '9'
      attempts: 1
      branch: main
      build: 87c270efca3942f296ace8034b87ff3b
      build_refs:
      - branch: main
        change: '3877'
        change_message: "feat(deploy): tier-1 perf \u2014 pre-role deps, neutron audit,
          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: e365a63168e4009dce8421456e1a3f3bb6cf6655
        patchset: e365a63168e4009dce8421456e1a3f3bb6cf6655
        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: 7f0281c7e53340c8abb21ae8f6b27bed
      buildset_refs:
      - branch: main
        change: '3877'
        change_message: "feat(deploy): tier-1 perf \u2014 pre-role deps, neutron audit,
          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: e365a63168e4009dce8421456e1a3f3bb6cf6655
        patchset: e365a63168e4009dce8421456e1a3f3bb6cf6655
        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 pre-role deps, neutron audit,
        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: e365a63168e4009dce8421456e1a3f3bb6cf6655
      event_id: b8c37570-3fd4-11f1-84cd-c2e92b812ca4
      executor:
        hostname: 0a8996d2b663
        inventory_file: /var/lib/zuul/builds/87c270efca3942f296ace8034b87ff3b/ansible/inventory.yaml
        log_root: /var/lib/zuul/builds/87c270efca3942f296ace8034b87ff3b/work/logs
        result_data_file: /var/lib/zuul/builds/87c270efca3942f296ace8034b87ff3b/work/results.json
        src_root: /var/lib/zuul/builds/87c270efca3942f296ace8034b87ff3b/work/src
        work_root: /var/lib/zuul/builds/87c270efca3942f296ace8034b87ff3b/work
      include_vars: []
      items:
      - branch: main
        change: '3877'
        change_message: "feat(deploy): tier-1 perf \u2014 pre-role deps, neutron audit,
          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: e365a63168e4009dce8421456e1a3f3bb6cf6655
        patchset: e365a63168e4009dce8421456e1a3f3bb6cf6655
        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-go-test
      jobtags: []
      max_attempts: 3
      message: ZmVhdChkZXBsb3kpOiB0aWVyLTEgcGVyZiDigJQgcHJlLXJvbGUgZGVwcywgbmV1dHJvbiBhdWRpdCwgazhzLWFwaSBjYXAKCkRyYWZ0LiBCYXNlZCBvbiAjMzgxOCBjb25jZXB0dWFsbHk7IG1lcmdlIHRhcmdldCBpcyBgbWFpbmAuCgpUaHJlZSBjb21wbGVtZW50YXJ5IGNyaXRpY2FsLXBhdGggaW1wcm92ZW1lbnRzIG9uIHRvcCBvZiB0aGUgcGFyYWxsZWwgZGVwbG95IG9yY2hlc3RyYXRvcjoKCiMjIyAxLiBgUHJlUm9sZURlcGVuZHNPbmAg4oCUIGFzeW1tZXRyaWMgcHJlLXJvbGUgZ2F0aW5nCkFkZHMgYSBmaWVsZCB0byBgQ29tcG9uZW50YCBzbyBhIHByZS1yb2xlIGNhbiB3YWl0IGZvciBkaWZmZXJlbnQgZGVwZW5kZW5jaWVzIHRoYW4gdGhlIG1haW4gcm9sZS4gVGhlIG9yY2hlc3RyYXRvciBidWlsZHMgYSBgcHJlR2F0ZWAgY2xvc3VyZSB0aGF0IHdhaXRzIG9uIGEgc2hhcmVkIGBjb21wbGV0aW9uVHJhY2tlcmA7IHRoZSBtYWluIHJvbGUgc3RhcnRzIGFzIHNvb24gYXMgdGhlIGNvbXBvbmVudCdzIG93biBgRGVwZW5kc09uYCBhcmUgc2F0aXNmaWVkLgoKQXBwbGllZCB0byBLZXlzdG9uZTogS2V5Y2xvYWsgcmVhbG0gLyBNRkEgLyBPSURDIGNsaWVudCAvIE9wZW5JRCBDb25maWdNYXAgdGFza3MgbW92ZWQgdG8gYSBuZXcgYGtleXN0b25lX3ByZWAgcm9sZSB0aGF0IHdhaXRzIGZvciBLZXljbG9haywgd2hpbGUgdGhlIEtleXN0b25lIEhlbG0gaW5zdGFsbCBydW5zIGluIHBhcmFsbGVsIHdpdGggS2V5Y2xvYWsgc3RhcnR1cC4gUG90ZW50aWFsIHNhdmluZyAqKn4zIG1pbioqIGZyb20gdGhlIHNlcmlhbCBLZXljbG9ha+KGkktleXN0b25lIHdpbmRvdy4KCiMjIyAyLiBOZXV0cm9uIERBRyBhdWRpdApEcm9wcyBgbm92YWAgZnJvbSBgbmV1dHJvbi5EZXBlbmRzT25gLiBUaGUgTmV1dHJvbiByb2xlIGRvZXMgb25seSBIZWxtIGluc3RhbGwgKyBpbmdyZXNzIOKAlCBgbmV1dHJvbi1tZXRhZGF0YS1hZ2VudGAgdGFsa3MgdG8gdGhlIE5vdmEgQVBJIGF0IHJ1bnRpbWUsIG5vdCBpbnN0YWxsIHRpbWUuIE5ldXRyb24gbm93IGluc3RhbGxzIGluIHBhcmFsbGVsIHdpdGggTm92YS4gUG90ZW50aWFsIHNhdmluZyAqKn4y4oCTMyBtaW4qKi4KCiMjIyAzLiBDb25maWd1cmFibGUgYFJlc291cmNlQ29vcmRpbmF0b3JgCkdlbmVyYWxpemVzIHRoZSByZXNvdXJjZSBzZW1hcGhvcmUgZnJvbSBhIGZpeGVkIG11dGV4IChjYXA9MSkgdG8gYSBwZXItcmVzb3VyY2UgY2FwLiBBZGRzIGEgYGs4cy1hcGlgIHJlc291cmNlIChkZWZhdWx0IGNhcCA2KSBhbmQgdGFncyBoZWF2eSBoZWxtLWRyaXZlbiBjb21wb25lbnRzIChrZXlzdG9uZSwgbmV1dHJvbiwgbm92YSwgY2luZGVyLCBnbGFuY2UsIHBsYWNlbWVudCwgaGVhdCwgYmFyYmljYW4sIG9jdGF2aWEsIG1hZ251bSwgbWFuaWxhLCBob3Jpem9uKSBzbyBhcGlzZXJ2ZXIgbG9hZCBpcyBzbW9vdGhlZCBkdXJpbmcgd2F2ZSBmYW4tb3V0IHdpdGhvdXQgc2VyaWFsaXppbmcgT3BlblN0YWNrLgoKIyMjIFRlc3RzCi0gYGNvbXBsZXRpb25fdGVzdC5nb2Ag4oCUIHRyYWNrZXIgV2FpdC9NYXJrRG9uZSBzZW1hbnRpY3MKLSBgcmVzb3VyY2VfY29uY3VycmVuY3lfdGVzdC5nb2Ag4oCUIG92ZXJyaWRlcyArIGRlZmF1bHQgY2FwCi0gYG9yY2hlc3RyYXRvcl90ZXN0LmdvYCDigJQgYGJ1aWxkUHJlR2F0ZWAgYnJhbmNoaW5nCi0gRXhpc3RpbmcgZGVwbG95ZXIvb3JjaGVzdHJhdG9yIHRlc3RzIHVwZGF0ZWQgZm9yIG5ldyBgRGVwbG95KGN0eCwgY29tcCwgcHJlR2F0ZSlgIHNpZ25hdHVyZQoKIyMjIEJhY2t3YXJkcyBjb21wYXRpYmlsaXR5ClRoZSBzZXF1ZW50aWFsIGBwbGF5Ym9va3Mvb3BlbnN0YWNrLnltbCAtLXRhZ3Mga2V5c3RvbmVgIHBhdGggaXMgcHJlc2VydmVkOiBLZXljbG9hayB0YXNrcyBzdGlsbCBleGlzdCBpbiBgcm9sZXMva2V5c3RvbmUvdGFza3MvbWFpbi55bWxgIGd1YXJkZWQgYnkgYF9wcmVfcm9sZV9hY3RpdmVgLCBmb2xsb3dpbmcgdGhlIGV4aXN0aW5nIGBvY3RhdmlhYCAvIGBtYWdudW1gIHBhdHRlcm4uCgojIyMgTmV4dCBzdGVwcyBhZnRlciBtZXJnZQpWYWxpZGF0ZSBhY3R1YWwgcGVyZm9ybWFuY2UgaW4gWnV1bCB2cyBjdXJyZW50ICMzODE4IGJhc2VsaW5lIChPVk4gZGVwbG95IDM0LjggbWluLCBPVlMgMzUuNSBtaW4pLiBFeHBlY3RlZCBzYXZpbmdzOiB+NOKAkzYgbWluIGNyaXRpY2FsLXBhdGguCg==
      patchset: e365a63168e4009dce8421456e1a3f3bb6cf6655
      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/atmosphere:
            canonical_name: github.com/vexxhost/atmosphere
            checkout: main
            commit: e365a63168e4009dce8421456e1a3f3bb6cf6655
          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/zuul-jobs:
            canonical_name: github.com/vexxhost/zuul-jobs
            checkout: main
            commit: a6e68243e02ef030ce5e75f8b67630880c475f33
        playbooks:
        - path: untrusted/project_0/github.com/vexxhost/atmosphere/test-playbooks/go-test/run.yml
          roles:
          - checkout: main
            checkout_description: playbook branch
            link_name: ansible/playbook_0/role_0/atmosphere
            link_target: untrusted/project_0/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_2/zuul-jobs
            link_target: untrusted/project_2/opendev.org/zuul/zuul-jobs
            role_path: ansible/playbook_0/role_2/zuul-jobs/roles
          - checkout: main
            checkout_description: zuul branch
            link_name: ansible/playbook_0/role_3/zuul-jobs
            link_target: untrusted/project_3/github.com/vexxhost/zuul-jobs
            role_path: ansible/playbook_0/role_3/zuul-jobs/roles
        post_playbooks:
        - 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_0/role_1/zuul-jobs
            link_target: trusted/project_1/opendev.org/zuul/zuul-jobs
            role_path: ansible/post_playbook_0/role_1/zuul-jobs/roles
          - checkout: main
            checkout_description: zuul branch
            link_name: ansible/post_playbook_0/role_2/zuul-jobs
            link_target: trusted/project_2/github.com/vexxhost/zuul-jobs
            role_path: ansible/post_playbook_0/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_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
        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
      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: e365a63168e4009dce8421456e1a3f3bb6cf6655
          name: vexxhost/atmosphere
          required: false
          short_name: atmosphere
          src_dir: src/github.com/vexxhost/atmosphere
      ref: refs/pull/3877/head
      resources: {}
      tenant: oss
      timeout: 1800
      topic: null
      voting: true
