fix(ci): Stop running multiple full syncs on different branches (#6664)

* Stop running multiple full syncs on different branches

* Fully fix concurrency, and require found cache or generated cache

* Use correct syntax and job dependencies
This commit is contained in:
teor 2023-05-11 21:15:20 +10:00 committed by GitHub
parent 6c0b51df8d
commit 8c8ac4ac20
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 34 additions and 38 deletions

View File

@ -314,7 +314,7 @@ jobs:
# #
# See the concurrency comment on the zebrad test-full-sync job for details. # See the concurrency comment on the zebrad test-full-sync job for details.
concurrency: concurrency:
group: ${{ github.workflow }}${{ github.ref }}-regenerate-stateful-disks group: ${{ github.workflow }}manual-${{ fromJSON(github.event.inputs.regenerate-disks) }}-regenerate-stateful-disks
cancel-in-progress: false cancel-in-progress: false
# Test that Zebra syncs and fully validates a few thousand blocks from a cached mandatory checkpoint disk # Test that Zebra syncs and fully validates a few thousand blocks from a cached mandatory checkpoint disk
@ -323,9 +323,9 @@ jobs:
# Otherwise, if the state rebuild was skipped, runs immediately after the build job. # Otherwise, if the state rebuild was skipped, runs immediately after the build job.
test-stateful-sync: test-stateful-sync:
name: Zebra checkpoint update name: Zebra checkpoint update
needs: regenerate-stateful-disks needs: [ regenerate-stateful-disks, get-available-disks ]
uses: ./.github/workflows/deploy-gcp-tests.yml uses: ./.github/workflows/deploy-gcp-tests.yml
if: ${{ !cancelled() && !failure() && github.event.inputs.regenerate-disks != 'true' && github.event.inputs.run-full-sync != 'true' && github.event.inputs.run-lwd-sync != 'true' }} if: ${{ !cancelled() && !failure() && (fromJSON(needs.get-available-disks.outputs.zebra_checkpoint_disk) || needs.regenerate-stateful-disks.result == 'success') && github.event.inputs.regenerate-disks != 'true' && github.event.inputs.run-full-sync != 'true' && github.event.inputs.run-lwd-sync != 'true' }}
with: with:
app_name: zebrad app_name: zebrad
test_id: sync-past-checkpoint test_id: sync-past-checkpoint
@ -381,10 +381,9 @@ jobs:
# it has no impact on this job.) # it has no impact on this job.)
# #
# TODO: # TODO:
# - allow multiple manual syncs on a branch, and isolate manual syncs from automatic syncs, by adding '-${{ github.run_id }}' when github.event.inputs.run-full-sync is true # - allow multiple manual syncs on a branch by adding '-${{ github.run_id }}' when github.event.inputs.run-full-sync is true
# - stop multiple automatic full syncs across different PRs by removing '${{ github.ref }}' when needs.get-available-disks.outputs.zebra_tip_disk is true
concurrency: concurrency:
group: ${{ github.workflow }}${{ github.ref }}-test-full-sync group: ${{ github.workflow }}manual-${{ fromJSON(github.event.inputs.run-full-sync) }}-test-full-sync
cancel-in-progress: false cancel-in-progress: false
# Test that Zebra can sync to the chain tip, using a cached Zebra tip state, # Test that Zebra can sync to the chain tip, using a cached Zebra tip state,
@ -398,9 +397,9 @@ jobs:
# Otherwise, if the state rebuild was skipped, runs immediately after the build job. # Otherwise, if the state rebuild was skipped, runs immediately after the build job.
test-update-sync: test-update-sync:
name: Zebra tip update name: Zebra tip update
needs: test-full-sync needs: [ test-full-sync, get-available-disks ]
uses: ./.github/workflows/deploy-gcp-tests.yml uses: ./.github/workflows/deploy-gcp-tests.yml
if: ${{ !cancelled() && !failure() && github.event.inputs.regenerate-disks != 'true' && github.event.inputs.run-full-sync != 'true' && github.event.inputs.run-lwd-sync != 'true' }} if: ${{ !cancelled() && !failure() && (fromJSON(needs.get-available-disks.outputs.zebra_tip_disk) || needs.test-full-sync.result == 'success') && github.event.inputs.regenerate-disks != 'true' && github.event.inputs.run-full-sync != 'true' && github.event.inputs.run-lwd-sync != 'true' }}
with: with:
app_name: zebrad app_name: zebrad
test_id: update-to-tip test_id: update-to-tip
@ -430,9 +429,9 @@ jobs:
# Otherwise, if the state rebuild was skipped, runs immediately after the build job. # Otherwise, if the state rebuild was skipped, runs immediately after the build job.
generate-checkpoints-mainnet: generate-checkpoints-mainnet:
name: Generate checkpoints mainnet name: Generate checkpoints mainnet
needs: test-full-sync needs: [ test-full-sync, get-available-disks ]
uses: ./.github/workflows/deploy-gcp-tests.yml uses: ./.github/workflows/deploy-gcp-tests.yml
if: ${{ !cancelled() && !failure() && github.event.inputs.regenerate-disks != 'true' && github.event.inputs.run-full-sync != 'true' && github.event.inputs.run-lwd-sync != 'true' }} if: ${{ !cancelled() && !failure() && (fromJSON(needs.get-available-disks.outputs.zebra_tip_disk) || needs.test-full-sync.result == 'success') && github.event.inputs.regenerate-disks != 'true' && github.event.inputs.run-full-sync != 'true' && github.event.inputs.run-lwd-sync != 'true' }}
with: with:
app_name: zebrad app_name: zebrad
test_id: generate-checkpoints-mainnet test_id: generate-checkpoints-mainnet
@ -496,10 +495,9 @@ jobs:
# it has no impact on this job.) # it has no impact on this job.)
# #
# TODO: # TODO:
# - allow multiple manual syncs on a branch, and isolate manual syncs from automatic syncs, by adding '-${{ github.run_id }}' when github.event.inputs.run-full-sync is true # - allow multiple manual syncs on a branch by adding '-${{ github.run_id }}' when github.event.inputs.run-full-sync is true
# - stop multiple automatic full syncs across different PRs by removing '${{ github.ref }}' when needs.get-available-disks-testnet.outputs.zebra_tip_disk is true
concurrency: concurrency:
group: ${{ github.workflow }}${{ github.ref }}-test-full-sync-testnet group: ${{ github.workflow }}manual-${{ fromJSON(github.event.inputs.run-full-sync) }}-test-full-sync-testnet
cancel-in-progress: false cancel-in-progress: false
# Test that Zebra can generate testnet checkpoints after syncing to the chain tip, # Test that Zebra can generate testnet checkpoints after syncing to the chain tip,
@ -515,9 +513,9 @@ jobs:
# Otherwise, if the state rebuild was skipped, runs immediately after the build job. # Otherwise, if the state rebuild was skipped, runs immediately after the build job.
generate-checkpoints-testnet: generate-checkpoints-testnet:
name: Generate checkpoints testnet name: Generate checkpoints testnet
needs: test-full-sync-testnet needs: [ test-full-sync-testnet, get-available-disks-testnet ]
uses: ./.github/workflows/deploy-gcp-tests.yml uses: ./.github/workflows/deploy-gcp-tests.yml
if: ${{ !cancelled() && !failure() && github.event.inputs.regenerate-disks != 'true' && github.event.inputs.run-full-sync != 'true' && github.event.inputs.run-lwd-sync != 'true' }} if: ${{ !cancelled() && !failure() && (fromJSON(needs.get-available-disks-testnet.outputs.zebra_tip_disk) || needs.test-full-sync-testnet.result == 'success') && github.event.inputs.regenerate-disks != 'true' && github.event.inputs.run-full-sync != 'true' && github.event.inputs.run-lwd-sync != 'true' }}
with: with:
app_name: zebrad app_name: zebrad
test_id: generate-checkpoints-testnet test_id: generate-checkpoints-testnet
@ -550,7 +548,7 @@ jobs:
# to also run on Mergify head branches, # to also run on Mergify head branches,
# add `|| (github.event_name == 'push' && startsWith(github.head_ref, 'mergify/merge-queue/'))`: # add `|| (github.event_name == 'push' && startsWith(github.head_ref, 'mergify/merge-queue/'))`:
# https://docs.github.com/en/actions/using-workflows/events-that-trigger-workflows#running-your-workflow-based-on-the-head-or-base-branch-of-a-pull-request-1 # https://docs.github.com/en/actions/using-workflows/events-that-trigger-workflows#running-your-workflow-based-on-the-head-or-base-branch-of-a-pull-request-1
if: ${{ !cancelled() && !failure() && ((github.event_name == 'push' && github.ref_name == 'main') || !fromJSON(needs.get-available-disks.outputs.lwd_tip_disk) || github.event.inputs.run-lwd-sync == 'true' ) }} if: ${{ !cancelled() && !failure() && (fromJSON(needs.get-available-disks.outputs.zebra_tip_disk) || needs.test-full-sync.result == 'success') && ((github.event_name == 'push' && github.ref_name == 'main') || !fromJSON(needs.get-available-disks.outputs.lwd_tip_disk) || github.event.inputs.run-lwd-sync == 'true' ) }}
with: with:
app_name: lightwalletd app_name: lightwalletd
test_id: lwd-full-sync test_id: lwd-full-sync
@ -574,7 +572,7 @@ jobs:
# #
# See the concurrency comment on the zebrad test-full-sync job for details. # See the concurrency comment on the zebrad test-full-sync job for details.
concurrency: concurrency:
group: ${{ github.workflow }}${{ github.ref }}-lightwalletd-full-sync group: ${{ github.workflow }}manual-${{ fromJSON(github.event.inputs.run-lwd-sync) }}-lightwalletd-full-sync
cancel-in-progress: false cancel-in-progress: false
# Test update sync of lightwalletd with a lightwalletd and Zebra tip state # Test update sync of lightwalletd with a lightwalletd and Zebra tip state
@ -586,9 +584,9 @@ jobs:
# Otherwise, if the state rebuild was skipped, runs immediately after the build job. # Otherwise, if the state rebuild was skipped, runs immediately after the build job.
lightwalletd-update-sync: lightwalletd-update-sync:
name: lightwalletd tip update name: lightwalletd tip update
needs: lightwalletd-full-sync needs: [ lightwalletd-full-sync, get-available-disks ]
uses: ./.github/workflows/deploy-gcp-tests.yml uses: ./.github/workflows/deploy-gcp-tests.yml
if: ${{ !cancelled() && !failure() && github.event.inputs.regenerate-disks != 'true' && github.event.inputs.run-full-sync != 'true' && github.event.inputs.run-lwd-sync != 'true' }} if: ${{ !cancelled() && !failure() && (fromJSON(needs.get-available-disks.outputs.lwd_tip_disk) || needs.lightwalletd-full-sync.result == 'success') && github.event.inputs.regenerate-disks != 'true' && github.event.inputs.run-full-sync != 'true' && github.event.inputs.run-lwd-sync != 'true' }}
with: with:
app_name: lightwalletd app_name: lightwalletd
test_id: lwd-update-sync test_id: lwd-update-sync
@ -614,11 +612,13 @@ jobs:
# #
# If the state version has changed, waits for the new cached state to be created. # If the state version has changed, waits for the new cached state to be created.
# Otherwise, if the state rebuild was skipped, runs immediately after the build job. # Otherwise, if the state rebuild was skipped, runs immediately after the build job.
#
# TODO: move this job below the rest of the mainnet jobs that just use Zebra cached state
lightwalletd-rpc-test: lightwalletd-rpc-test:
name: Zebra tip JSON-RPC name: Zebra tip JSON-RPC
needs: test-full-sync needs: [ test-full-sync, get-available-disks ]
uses: ./.github/workflows/deploy-gcp-tests.yml uses: ./.github/workflows/deploy-gcp-tests.yml
if: ${{ !cancelled() && !failure() && github.event.inputs.regenerate-disks != 'true' && github.event.inputs.run-full-sync != 'true' && github.event.inputs.run-lwd-sync != 'true' }} if: ${{ !cancelled() && !failure() && (fromJSON(needs.get-available-disks.outputs.zebra_tip_disk) || needs.test-full-sync.result == 'success') && github.event.inputs.regenerate-disks != 'true' && github.event.inputs.run-full-sync != 'true' && github.event.inputs.run-lwd-sync != 'true' }}
with: with:
app_name: lightwalletd app_name: lightwalletd
test_id: fully-synced-rpc test_id: fully-synced-rpc
@ -635,15 +635,15 @@ jobs:
# #
# Runs: # Runs:
# - after every PR is merged to `main` # - after every PR is merged to `main`
# - on every PR update
# #
# If the state version has changed, waits for the new cached states to be created. # If the state version has changed, waits for the new cached states to be created.
# Otherwise, if the state rebuild was skipped, runs immediately after the build job. # Otherwise, if the state rebuild was skipped, runs immediately after the build job.
# TODO: move this job under lightwalletd-full-sync to have a sequential logic
lightwalletd-transactions-test: lightwalletd-transactions-test:
name: lightwalletd tip send name: lightwalletd tip send
needs: lightwalletd-full-sync needs: [ lightwalletd-full-sync, get-available-disks ]
uses: ./.github/workflows/deploy-gcp-tests.yml uses: ./.github/workflows/deploy-gcp-tests.yml
if: ${{ !cancelled() && !failure() && github.event.inputs.regenerate-disks != 'true' && github.event.inputs.run-full-sync != 'true' && github.event.inputs.run-lwd-sync != 'true' }} if: ${{ !cancelled() && !failure() && (fromJSON(needs.get-available-disks.outputs.lwd_tip_disk) || needs.lightwalletd-full-sync.result == 'success') && github.event.inputs.regenerate-disks != 'true' && github.event.inputs.run-full-sync != 'true' && github.event.inputs.run-lwd-sync != 'true' }}
with: with:
app_name: lightwalletd app_name: lightwalletd
test_id: lwd-send-transactions test_id: lwd-send-transactions
@ -657,14 +657,6 @@ jobs:
zebra_state_dir: 'zebrad-cache' zebra_state_dir: 'zebrad-cache'
lwd_state_dir: 'lwd-cache' lwd_state_dir: 'lwd-cache'
secrets: inherit secrets: inherit
# We want to prevent multiple lightwalletd send transaction tests running at the same time,
# but we don't want to cancel running tests on `main` if a new PR gets merged,
# because we might never get a finished test.
#
# See the concurrency comment on the zebrad test-full-sync job for details.
concurrency:
group: ${{ github.workflow }}${{ github.ref }}-lightwalletd-transactions-test
cancel-in-progress: false
# Test that Zebra can handle gRPC wallet calls, using a cached Zebra tip state # Test that Zebra can handle gRPC wallet calls, using a cached Zebra tip state
# #
@ -676,9 +668,9 @@ jobs:
# Otherwise, if the state rebuild was skipped, runs immediately after the build job. # Otherwise, if the state rebuild was skipped, runs immediately after the build job.
lightwalletd-grpc-test: lightwalletd-grpc-test:
name: lightwalletd GRPC tests name: lightwalletd GRPC tests
needs: lightwalletd-full-sync needs: [ lightwalletd-full-sync, get-available-disks ]
uses: ./.github/workflows/deploy-gcp-tests.yml uses: ./.github/workflows/deploy-gcp-tests.yml
if: ${{ !cancelled() && !failure() && github.event.inputs.regenerate-disks != 'true' && github.event.inputs.run-full-sync != 'true' && github.event.inputs.run-lwd-sync != 'true' }} if: ${{ !cancelled() && !failure() && (fromJSON(needs.get-available-disks.outputs.lwd_tip_disk) || needs.lightwalletd-full-sync.result == 'success') && github.event.inputs.regenerate-disks != 'true' && github.event.inputs.run-full-sync != 'true' && github.event.inputs.run-lwd-sync != 'true' }}
with: with:
app_name: lightwalletd app_name: lightwalletd
test_id: lwd-grpc-wallet test_id: lwd-grpc-wallet
@ -692,6 +684,10 @@ jobs:
zebra_state_dir: 'zebrad-cache' zebra_state_dir: 'zebrad-cache'
lwd_state_dir: 'lwd-cache' lwd_state_dir: 'lwd-cache'
secrets: inherit secrets: inherit
## getblocktemplate-rpcs using cached Zebra state on mainnet
#
# TODO: move these below the rest of the mainnet jobs that just use Zebra cached state
# Test that Zebra can handle a getblocktemplate RPC call, using a cached Zebra tip state # Test that Zebra can handle a getblocktemplate RPC call, using a cached Zebra tip state
# #
@ -703,9 +699,9 @@ jobs:
# Otherwise, if the state rebuild was skipped, runs immediately after the build job. # Otherwise, if the state rebuild was skipped, runs immediately after the build job.
get-block-template-test: get-block-template-test:
name: get block template name: get block template
needs: test-full-sync needs: [ test-full-sync, get-available-disks ]
uses: ./.github/workflows/deploy-gcp-tests.yml uses: ./.github/workflows/deploy-gcp-tests.yml
if: ${{ !cancelled() && !failure() && github.event.inputs.regenerate-disks != 'true' && github.event.inputs.run-full-sync != 'true' && github.event.inputs.run-lwd-sync != 'true' }} if: ${{ !cancelled() && !failure() && (fromJSON(needs.get-available-disks.outputs.zebra_tip_disk) || needs.test-full-sync.result == 'success') && github.event.inputs.regenerate-disks != 'true' && github.event.inputs.run-full-sync != 'true' && github.event.inputs.run-lwd-sync != 'true' }}
with: with:
app_name: zebrad app_name: zebrad
test_id: get-block-template test_id: get-block-template
@ -729,9 +725,9 @@ jobs:
# Otherwise, if the state rebuild was skipped, runs immediately after the build job. # Otherwise, if the state rebuild was skipped, runs immediately after the build job.
submit-block-test: submit-block-test:
name: submit block name: submit block
needs: test-full-sync needs: [ test-full-sync, get-available-disks ]
uses: ./.github/workflows/deploy-gcp-tests.yml uses: ./.github/workflows/deploy-gcp-tests.yml
if: ${{ !cancelled() && !failure() && github.event.inputs.regenerate-disks != 'true' && github.event.inputs.run-full-sync != 'true' && github.event.inputs.run-lwd-sync != 'true' }} if: ${{ !cancelled() && !failure() && (fromJSON(needs.get-available-disks.outputs.zebra_tip_disk) || needs.test-full-sync.result == 'success') && github.event.inputs.regenerate-disks != 'true' && github.event.inputs.run-full-sync != 'true' && github.event.inputs.run-lwd-sync != 'true' }}
with: with:
app_name: zebrad app_name: zebrad
test_id: submit-block test_id: submit-block