Skip to content

Example test runner: make script more readable / ensure examples do not process.exit #11535

Example test runner: make script more readable / ensure examples do not process.exit

Example test runner: make script more readable / ensure examples do not process.exit #11535

Workflow file for this run

name: VM
on:
pull_request:
types: [opened, reopened, synchronize]
workflow_dispatch:
env:
cwd: ${{github.workspace}}/packages/vm
defaults:
run:
working-directory: packages/vm
concurrency:
group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }}
cancel-in-progress: true
jobs:
vm-api:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
with:
submodules: recursive
- uses: actions/setup-node@v4
with:
node-version: 18
cache: 'npm'
- run: npm ci
working-directory: ${{github.workspace}}
- run: npm run lint
- run: npm run coverage
# - run: npm run test:API:browser -- disabled until we fix browser tests for vitest
- uses: codecov/codecov-action@v3
with:
files: ${{ env.cwd }}/coverage/lcov.info
flags: vm
vm-state:
runs-on: ubuntu-latest
strategy:
matrix:
fork: ['Berlin', 'London', 'Paris', 'Shanghai', 'Cancun']
fail-fast: false
steps:
- uses: actions/checkout@v4
with:
submodules: recursive
- uses: actions/setup-node@v4
with:
node-version: 18
cache: 'npm'
- run: npm ci
working-directory: ${{github.workspace}}
- run: npm run test:state -- --fork=${{ matrix.fork }} --verify-test-amount-alltests
vm-state-extended:
if: contains(join(github.event.pull_request.labels.*.name, ' '), 'Test all hardforks')
runs-on: ubuntu-latest
strategy:
matrix:
fork:
[
'Cancun',
'Shanghai',
'Paris',
'London',
'Berlin',
'MuirGlacier',
'Istanbul',
'Petersburg',
'Constantinople',
'Byzantium',
'SpuriousDragon',
'TangerineWhistle',
'Homestead',
'Chainstart',
]
fail-fast: false
steps:
- uses: actions/checkout@v4
with:
submodules: recursive
- uses: actions/setup-node@v4
with:
node-version: 18
cache: 'npm'
- run: npm ci
working-directory: ${{github.workspace}}
- run: npm run test:state -- --fork=${{ matrix.fork }} --verify-test-amount-alltests
vm-blockchain:
runs-on: ubuntu-latest
strategy:
matrix:
# Args to pass to the tester. Note that some have split the slow tests and only
# run on forks where applicable (see PR #489 for numbers on these)
# Tests were split with --dir and --excludeDir to balance execution times below the 9min mark.
args:
[
'--fork=Berlin --verify-test-amount-alltests',
'--fork=London --verify-test-amount-alltests',
'--fork=Paris --verify-test-amount-alltests',
'--fork=Shanghai --verify-test-amount-alltests',
'--fork=Cancun --verify-test-amount-alltests',
]
fail-fast: false
steps:
- uses: actions/checkout@v4
with:
submodules: recursive
- uses: actions/setup-node@v4
with:
node-version: 18
cache: 'npm'
- run: npm ci
working-directory: ${{github.workspace}}
- run: npm run test:blockchain -- ${{ matrix.args }}
vm-blockchain-extended:
if: contains(join(github.event.pull_request.labels.*.name, ' '), 'Test all hardforks')
runs-on: ubuntu-latest
strategy:
matrix:
# Args to pass to the tester.
args:
[
'--fork=Chainstart --verify-test-amount-alltests',
'--fork=Homestead --verify-test-amount-alltests',
'--fork=TangerineWhistle --verify-test-amount-alltests',
'--fork=SpuriousDragon --verify-test-amount-alltests',
'--fork=Byzantium --verify-test-amount-alltests',
'--fork=Constantinople --verify-test-amount-alltests',
'--fork=Petersburg --verify-test-amount-alltests',
'--fork=Istanbul --verify-test-amount-alltests',
'--fork=MuirGlacier --verify-test-amount-alltests',
'--fork=Berlin --verify-test-amount-alltests',
'--fork=London --verify-test-amount-alltests',
'--fork=Paris --verify-test-amount-alltests',
'--fork=Shanghai --verify-test-amount-alltests',
'--fork=Cancun --verify-test-amount-alltests',
'--fork=ByzantiumToConstantinopleFixAt5 --verify-test-amount-alltests',
'--fork=EIP158ToByzantiumAt5 --verify-test-amount-alltests',
'--fork=FrontierToHomesteadAt5 --verify-test-amount-alltests',
'--fork=HomesteadToDaoAt5 --verify-test-amount-alltests',
'--fork=HomesteadToEIP150At5 --verify-test-amount-alltests',
'--fork=BerlinToLondonAt5 --verify-test-amount-alltests',
]
fail-fast: false
steps:
- uses: actions/checkout@v4
with:
submodules: recursive
- uses: actions/setup-node@v4
with:
node-version: 18
cache: 'npm'
- run: npm ci
working-directory: ${{github.workspace}}
- run: npm run test:blockchain -- ${{ matrix.args }}
vm-benchmarks:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v4
with:
node-version: 18
cache: 'npm'
- run: npm ci
working-directory: ${{github.workspace}}
- run: npm run build:benchmarks
working-directory: ${{ env.cwd }}
- run: npm run benchmarks -- mainnetBlocks:10 | tee output.txt
working-directory: ${{ env.cwd }}
# Run git stash in case github-action-benchmark has trouble switching to gh-pages branch due to differing package-locks
- run: git stash
- name: Compare benchmarks
uses: rhysd/github-action-benchmark@v1
with:
tool: 'benchmarkjs'
# Where the output from the benchmark tool is stored
output-file-path: ${{ env.cwd }}/output.txt
# Location of data in gh-pages branch
benchmark-data-dir-path: dev/bench/vm
# Enable alert commit comment (default alert threshold: 200%)
comment-on-alert: true
# GitHub API token to make a commit comment
github-token: ${{ secrets.GITHUB_TOKEN }}
# Push and deploy to GitHub pages branch automatically (if on master)
auto-push: 'false'
# Re-apply git stash to prepare for saving back to cache.
# Avoids exit code 1 by checking if there are changes to be stashed first
- run: STASH_LIST=`git stash list` && [ ! -z $STASH_LIST ] && git stash apply || echo "No files to stash-apply. Skipping…"