Skip to content

Nightly pipeline normal session e2e tests #603

Nightly pipeline normal session e2e tests

Nightly pipeline normal session e2e tests #603

---
name: Nightly pipeline normal session e2e tests
on:
workflow_dispatch:
schedule:
- cron: '00 22 * * *'
concurrency:
group: "${{ github.ref }}-${{ github.workflow }}"
cancel-in-progress: true
jobs:
check-vars-and-secrets:
name: Check vars and secrets
uses: ./.github/workflows/_check-vars-and-secrets.yml
secrets: inherit
build-aleph-e2e-client-image:
needs: [check-vars-and-secrets]
name: Build aleph-e2e-client image
uses: ./.github/workflows/_build-aleph-e2e-client.yml
with:
ref: ${{ github.ref }}
secrets: inherit
build-production-aleph-node:
needs: [check-vars-and-secrets]
name: Build production aleph-node
uses: ./.github/workflows/_build-aleph-node.yml
with:
ref: ${{ github.ref }}
production: true
build-synthetic-node:
needs: [build-production-aleph-node]
name: Build synthetic node
uses: ./.github/workflows/_build-synthetic-node.yml
with:
# yamllint disable-line rule:line-length
artifact-aleph-node-image: ${{ needs.build-production-aleph-node.outputs.artifact-name-image }}
build-chain-bootstrapper-production:
name: Build chain-bootstrapper
uses: ./.github/workflows/_build-chain-bootstrapper.yml
with:
ref: ${{ github.ref }}
production: true
run-e2e-high-out-latency:
needs:
- build-synthetic-node
- build-aleph-e2e-client-image
- build-chain-bootstrapper-production
name: Run high out-latency test
runs-on: ubuntu-20.04
steps:
- name: Checkout source code
uses: actions/checkout@v4
- name: Run e2e test
uses: ./.github/actions/run-e2e-test
with:
test-case: high_out_latency_for_all
# yamllint disable-line rule:line-length
artifact-aleph-node-image: ${{ needs.build-synthetic-node.outputs.artifact-name-image }}
aleph-node-image-tag: aleph-node:syntheticnet
# yamllint disable-line rule:line-length
artifact-chain-bootstrapper-image: ${{ needs.build-chain-bootstrapper-production.outputs.artifact-name-image }}
compose-file: docker/docker-compose.synthetic-network.yml
# yamllint disable-line rule:line-length
artifact-aleph-e2e-client-image: ${{ needs.build-aleph-e2e-client-image.outputs.artifact-name-image }}
timeout-minutes: 40
run-e2e-sync-test-one_node_catching_up_and_then_becoming_necessary_for_consensus:
needs:
- build-synthetic-node
- build-aleph-e2e-client-image
- build-chain-bootstrapper-production
name: Sync test using synthetic-network - one node catching up and then
becoming necessary for consensus
runs-on: ubuntu-20.04
steps:
- name: Checkout source code
uses: actions/checkout@v4
- name: Run e2e test
uses: ./.github/actions/run-e2e-test
env:
NETWORK: "synthetic-network"
NODE_URL: "ws://Node0:9944"
VALIDATOR_COUNT: 7
with:
test-case: test::sync::one_node_catching_up_and_then_becoming_necessary_for_consensus
# yamllint disable-line rule:line-length
artifact-aleph-node-image: ${{ needs.build-synthetic-node.outputs.artifact-name-image }}
aleph-node-image-tag: aleph-node:syntheticnet
# yamllint disable-line rule:line-length
artifact-chain-bootstrapper-image: ${{ needs.build-chain-bootstrapper-production.outputs.artifact-name-image }}
compose-file: docker/docker-compose.synthetic-network_sync-tests.yml
node-count: 7
# yamllint disable-line rule:line-length
artifact-aleph-e2e-client-image: ${{ needs.build-aleph-e2e-client-image.outputs.artifact-name-image }}
timeout-minutes: 35
run-e2e-sync-test-one_node_catching_up:
needs:
- build-synthetic-node
- build-aleph-e2e-client-image
- build-chain-bootstrapper-production
name: Sync test using synthetic-network - one node catching up
runs-on: ubuntu-20.04
steps:
- name: Checkout source code
uses: actions/checkout@v4
- name: Run e2e test
uses: ./.github/actions/run-e2e-test
env:
NETWORK: "synthetic-network"
NODE_URL: "ws://Node0:9944"
VALIDATOR_COUNT: 7
with:
test-case: test::sync::one_node_catching_up
# yamllint disable-line rule:line-length
artifact-aleph-node-image: ${{ needs.build-synthetic-node.outputs.artifact-name-image }}
aleph-node-image-tag: aleph-node:syntheticnet
# yamllint disable-line rule:line-length
artifact-chain-bootstrapper-image: ${{ needs.build-chain-bootstrapper-production.outputs.artifact-name-image }}
compose-file: docker/docker-compose.synthetic-network_sync-tests.yml
node-count: 7
# yamllint disable-line rule:line-length
artifact-aleph-e2e-client-image: ${{ needs.build-aleph-e2e-client-image.outputs.artifact-name-image }}
timeout-minutes: 35
run-e2e-sync-test-into_two_groups_and_one_quorum_and_switch_quorum_between_them:
needs:
- build-synthetic-node
- build-aleph-e2e-client-image
- build-chain-bootstrapper-production
name: Sync test using synthetic-network - into two groups and one quorum
and switch quorum between them
runs-on: ubuntu-20.04
steps:
- name: Checkout source code
uses: actions/checkout@v4
- name: Run e2e test
uses: ./.github/actions/run-e2e-test
env:
NETWORK: "synthetic-network"
NODE_URL: "ws://Node0:9944"
VALIDATOR_COUNT: 7
with:
test-case: test::sync::into_two_groups_and_one_quorum_and_switch_quorum_between_them
# yamllint disable-line rule:line-length
artifact-aleph-node-image: ${{ needs.build-synthetic-node.outputs.artifact-name-image }}
aleph-node-image-tag: aleph-node:syntheticnet
# yamllint disable-line rule:line-length
artifact-chain-bootstrapper-image: ${{ needs.build-chain-bootstrapper-production.outputs.artifact-name-image }}
compose-file: docker/docker-compose.synthetic-network_sync-tests.yml
node-count: 7
# yamllint disable-line rule:line-length
artifact-aleph-e2e-client-image: ${{ needs.build-aleph-e2e-client-image.outputs.artifact-name-image }}
timeout-minutes: 35
run-e2e-sync-test-into_multiple_groups_of_two:
needs:
- build-synthetic-node
- build-aleph-e2e-client-image
- build-chain-bootstrapper-production
name: Sync test using synthetic-network - into multiple groups of two
runs-on: ubuntu-20.04
steps:
- name: Checkout source code
uses: actions/checkout@v4
- name: Run e2e test
uses: ./.github/actions/run-e2e-test
env:
NETWORK: "synthetic-network"
NODE_URL: "ws://Node0:9944"
VALIDATOR_COUNT: 7
with:
test-case: test::sync::into_multiple_groups_of_two
# yamllint disable-line rule:line-length
artifact-aleph-node-image: ${{ needs.build-synthetic-node.outputs.artifact-name-image }}
aleph-node-image-tag: aleph-node:syntheticnet
# yamllint disable-line rule:line-length
artifact-chain-bootstrapper-image: ${{ needs.build-chain-bootstrapper-production.outputs.artifact-name-image }}
compose-file: docker/docker-compose.synthetic-network_sync-tests.yml
node-count: 7
# yamllint disable-line rule:line-length
artifact-aleph-e2e-client-image: ${{ needs.build-aleph-e2e-client-image.outputs.artifact-name-image }}
timeout-minutes: 35
run-e2e-sync-test-into_two_equal_size_groups_with_no_quorum:
needs:
- build-synthetic-node
- build-aleph-e2e-client-image
- build-chain-bootstrapper-production
name: Sync test using synthetic-network - into two equal size groups
with no quorum
runs-on: ubuntu-20.04
steps:
- name: Checkout source code
uses: actions/checkout@v4
- name: Run e2e test
uses: ./.github/actions/run-e2e-test
env:
NETWORK: "synthetic-network"
NODE_URL: "ws://Node0:9944"
VALIDATOR_COUNT: 7
with:
test-case: test::sync::into_two_equal_size_groups_with_no_quorum
# yamllint disable-line rule:line-length
artifact-aleph-node-image: ${{ needs.build-synthetic-node.outputs.artifact-name-image }}
aleph-node-image-tag: aleph-node:syntheticnet
# yamllint disable-line rule:line-length
artifact-chain-bootstrapper-image: ${{ needs.build-chain-bootstrapper-production.outputs.artifact-name-image }}
compose-file: docker/docker-compose.synthetic-network_sync-tests.yml
node-count: 7
# yamllint disable-line rule:line-length
artifact-aleph-e2e-client-image: ${{ needs.build-aleph-e2e-client-image.outputs.artifact-name-image }}
timeout-minutes: 35
run-e2e-sync-test-into_two_groups_one_with_quorum:
needs:
- build-synthetic-node
- build-aleph-e2e-client-image
- build-chain-bootstrapper-production
name: Sync test using synthetic-network - into two groups one with
quorum
runs-on: ubuntu-20.04
steps:
- name: Checkout source code
uses: actions/checkout@v4
- name: Run e2e test
uses: ./.github/actions/run-e2e-test
env:
NETWORK: "synthetic-network"
NODE_URL: "ws://Node0:9944"
VALIDATOR_COUNT: 7
with:
test-case: test::sync::into_two_groups_one_with_quorum
# yamllint disable-line rule:line-length
artifact-aleph-node-image: ${{ needs.build-synthetic-node.outputs.artifact-name-image }}
aleph-node-image-tag: aleph-node:syntheticnet
# yamllint disable-line rule:line-length
artifact-chain-bootstrapper-image: ${{ needs.build-chain-bootstrapper-production.outputs.artifact-name-image }}
compose-file: docker/docker-compose.synthetic-network_sync-tests.yml
node-count: 7
# yamllint disable-line rule:line-length
artifact-aleph-e2e-client-image: ${{ needs.build-aleph-e2e-client-image.outputs.artifact-name-image }}
timeout-minutes: 35
run-e2e-finalization-stall:
needs:
- build-synthetic-node
- build-aleph-e2e-client-image
- build-chain-bootstrapper-production
name: Finalization-stall test using synthetic-network
runs-on: ubuntu-20.04
steps:
- name: Checkout source code
uses: actions/checkout@v4
- name: Run e2e test
uses: ./.github/actions/run-e2e-test
env:
NETWORK: "synthetic-network"
NODE_URL: "ws://Node0:9944"
VALIDATOR_COUNT: 5
TIMEOUT_MINUTES: "60m"
with:
test-case: test::sync::large_finalization_stall
# yamllint disable-line rule:line-length
artifact-aleph-node-image: ${{ needs.build-synthetic-node.outputs.artifact-name-image }}
aleph-node-image-tag: aleph-node:syntheticnet
# yamllint disable-line rule:line-length
artifact-chain-bootstrapper-image: ${{ needs.build-chain-bootstrapper-production.outputs.artifact-name-image }}
compose-file: docker/docker-compose.finalization_stall_with_pruning.yml
# yamllint disable-line rule:line-length
artifact-aleph-e2e-client-image: ${{ needs.build-aleph-e2e-client-image.outputs.artifact-name-image }}
timeout-minutes: 60
run-major-sync-test:
needs:
- build-production-aleph-node
- build-chain-bootstrapper-production
name: Run major sync test
runs-on: ubuntu-20.04
steps:
- name: Checkout source code
uses: actions/checkout@v4
- name: Download node binary from GH artifact
uses: actions/download-artifact@v4
with:
name: ${{ needs.build-production-aleph-node.outputs.artifact-name-binary }}
path: target/release/
- name: Download chain-bootstrapper from GH artifacts
uses: actions/download-artifact@v4
with:
name: ${{ needs.build-chain-bootstrapper-production.outputs.artifact-name-binary }}
path: target/release/
- name: Run test
timeout-minutes: 65
run: |
./.github/scripts/test_python_general.sh \
--aleph-node ../target/release/aleph-node \
--chain-bootstrapper ../target/release/chain-bootstrapper \
--testcase test_major_sync
run-network-flooding-test:
needs:
- check-vars-and-secrets
- build-production-aleph-node
- build-aleph-e2e-client-image
- build-chain-bootstrapper-production
name: Run network flooding test
runs-on: ubuntu-20.04
steps:
- name: Checkout aleph-node-flooder source code
uses: actions/checkout@v4
with:
ref: main
repository: Cardinal-Cryptography/aleph-node-flooder
fetch-depth: 0
token: ${{ secrets.CI_GH_TOKEN }}
- name: Build aleph-node with flooding routines for both sync-network and AlephBFT network
id: build-aleph-node-flooder
uses: ./.github/workflows/_build-aleph-node.yml
with:
production: false
additional-flags: "--features network_flooding_test"
- name: Checkout source code
uses: actions/checkout@v4
- name: Download node-flooding docker image
uses: actions/download-artifact@v4
with:
name: ${{ steps.build-aleph-node-flooder.outputs.artifact-name-image }}
- name: Load node-flooding docker image
shell: bash
run: |
docker load -i aleph-node.tar
docker tag aleph-node:latest aleph-node:flooding
docker image rm aleph-node:latest
mv aleph-node.tar aleph-node_flooding.tar
- name: Run e2e test
uses: ./.github/actions/run-e2e-test
env:
# more than one session
FINALIZATION_WAIT: 901
with:
test-case: finalization::finalization
# yamllint disable-line rule:line-length
artifact-aleph-node-image: ${{ needs.build-production-aleph-node.outputs.artifact-name-image }}
aleph-node-image-tag: aleph-node:latest
# yamllint disable-line rule:line-length
artifact-chain-bootstrapper-image: ${{ needs.build-chain-bootstrapper-production.outputs.artifact-name-image }}
compose-file: docker/docker-compose_network_flooding_test.yml
# yamllint disable-line rule:line-length
artifact-aleph-e2e-client-image: ${{ needs.build-aleph-e2e-client-image.outputs.artifact-name-image }}
timeout-minutes: 40
run-force-reorg-test:
needs:
- build-production-aleph-node
- build-chain-bootstrapper-production
name: Run force reorgs test
runs-on: [self-hosted, Linux, X64, medium]
steps:
- name: Checkout source code
uses: actions/checkout@v4
- name: Download node binary from GH artifact
uses: actions/download-artifact@v4
with:
name: ${{ needs.build-production-aleph-node.outputs.artifact-name-binary }}
path: target/release/
- name: Download chain-bootstrapper from GH artifacts
uses: actions/download-artifact@v4
with:
name: ${{ needs.build-chain-bootstrapper-production.outputs.artifact-name-binary }}
path: target/release/
- name: Run test
timeout-minutes: 25
run: |
./.github/scripts/test_python_general.sh \
--aleph-node ../target/release/aleph-node \
--chain-bootstrapper ../target/release/chain-bootstrapper \
--testcase test_force_reorg
run-e2e-no-quorum-without-high-out-latency:
needs:
- build-synthetic-node
- build-aleph-e2e-client-image
- build-chain-bootstrapper-production
name: Run high out-latency for every quorum
runs-on: ubuntu-20.04
steps:
- name: Checkout source code
uses: actions/checkout@v4
- name: Run e2e test
uses: ./.github/actions/run-e2e-test
with:
test-case: high_out_latency_for_each_quorum
# yamllint disable-line rule:line-length
artifact-aleph-node-image: ${{ needs.build-synthetic-node.outputs.artifact-name-image }}
aleph-node-image-tag: aleph-node:syntheticnet
compose-file: docker/docker-compose.synthetic-network.yml
# yamllint disable-line rule:line-length
artifact-chain-bootstrapper-image: ${{ needs.build-chain-bootstrapper-production.outputs.artifact-name-image }}
# yamllint disable-line rule:line-length
artifact-aleph-e2e-client-image: ${{ needs.build-aleph-e2e-client-image.outputs.artifact-name-image }}
timeout-minutes: 35
check-nightly-pipeline-completion:
needs: [run-e2e-high-out-latency,
run-e2e-sync-test-one_node_catching_up_and_then_becoming_necessary_for_consensus,
run-e2e-sync-test-one_node_catching_up,
run-e2e-sync-test-into_two_groups_and_one_quorum_and_switch_quorum_between_them,
run-e2e-sync-test-into_multiple_groups_of_two,
run-e2e-sync-test-into_two_equal_size_groups_with_no_quorum,
run-e2e-sync-test-into_two_groups_one_with_quorum,
run-force-reorg-test,
run-major-sync-test,
run-e2e-no-quorum-without-high-out-latency,
run-network-flooding-test]
name: Check nightly test suite completion
if: ${{ !cancelled() }}
runs-on: ubuntu-20.04
steps:
- name: All nightly tests completed
run: |
# due to the fact GitHub treats skipped jobs as success, and when any of dependant
# jobs fail, this check will be skipped, we need to check status manually
jq --exit-status 'all(.result == "success")' <<< '${{ toJson(needs) }}'
slack:
name: Slack notification
runs-on: ubuntu-20.04
needs: [check-nightly-pipeline-completion]
if: >
!cancelled() &&
github.event_name != 'workflow_dispatch'
steps:
- name: Send Slack message
uses: Cardinal-Cryptography/github-actions/slack-notification@v7
with:
notify-on: "failure"
env:
SLACK_WEBHOOK: ${{ secrets.SLACK_WEBHOOK_DEV_ONDUTY }}