Skip to content
name: regression-tests
on:
workflow_dispatch:
inputs:
zkevm_agglayer_commit_id:
description: 0xPolygon/agglayer (commit id)
required: true
zkevm_bridge_service_commit_id:
description: 0xPolygonHermez/zkevm-bridge-service (commit id)
required: true
zkevm_bridge_ui_commit_id:
description: 0xPolygonHermez/zkevm-bridge-ui (commit id)
required: true
zkevm_dac_commit_id:
description: 0xPolygon/cdk-data-availability (commit id)
required: true
zkevm_node_commit_id:
description: 0xPolygon/cdk-validium-node (commit id)
required: true
bake_time:
description: bake time (minutes)
required: false
default: 30
jobs:
regression-tests:
runs-on: ubuntu-latest
steps:
- name: Log inputs
run: |
echo "zkevm_agglayer_commit_id: ${{ github.event.inputs.zkevm_agglayer_commit_id }}"
echo "zkevm_bridge_service_commit_id: ${{ github.event.inputs.zkevm_bridge_service_commit_id }}"
echo "zkevm_bridge_ui_commit_id: ${{ github.event.inputs.zkevm_bridge_ui_commit_id }}"
echo "zkevm_dac_commit_id: ${{ github.event.inputs.zkevm_dac_commit_id }}"
echo "zkevm_node_commit_id: ${{ github.event.inputs.zkevm_node_commit_id }}"
echo "bake_time: ${{ github.event.inputs.bake_time }}"
- uses: actions/checkout@v2
- uses: docker/setup-buildx-action@v1
# Build docker images.
- name: Build zkevm-agglayer
run: |
git clone https://github.com/0xPolygon/agglayer.git
pushd agglayer || exit
git checkout "${{ github.event.inputs.zkevm_agglayer_commit_id }}"
docker build -t zkevm-agglayer:local -f ./docker/Dockerfile .
popd || exit
rm -rf agglayer
- name: Build zkevm-bridge-service
run: |
git clone https://github.com/0xPolygonHermez/zkevm-bridge-service.git
pushd zkevm-bridge-service || exit
git checkout "${{ github.event.inputs.zkevm_bridge_service_commit_id }}"
docker build -t zkevm-bridge-service:local -f ./Dockerfile .
popd || exit
rm -rf zkevm-bridge-service
- name: Build zkevm-bridge-ui
run: |
git clone https://github.com/0xPolygonHermez/zkevm-bridge-ui.git
pushd zkevm-bridge-ui || exit
git checkout "${{ github.event.inputs.zkevm_bridge_ui_commit_id }}"
docker build -t zkevm-bridge-ui:local -f ./Dockerfile .
popd || exit
rm -rf zkevm-bridge-ui
- name: Build cdk-data-availability
run: |
git clone https://github.com/0xPolygon/cdk-data-availability.git
pushd cdk-data-availability || exit
git checkout "${{ github.event.inputs.zkevm_dac_commit_id }}"
docker build -t cdk-data-availability:local -f ./Dockerfile .
popd || exit
rm -rf cdk-data-availability
- name: Build cdk-validium-node
run: |
git clone https://github.com/0xPolygon/cdk-validium-node.git
pushd cdk-validium-node || exit
git checkout "${{ github.event.inputs.zkevm_node_commit_id }}"
docker build -t cdk-validium-node:local -f ./Dockerfile .
popd || exit
rm -rf cdk-validium-node
# Install tools.
- name: Install kurtosis
run: |
echo "deb [trusted=yes] https://apt.fury.io/kurtosis-tech/ /" | sudo tee /etc/apt/sources.list.d/kurtosis.list
sudo apt update
sudo apt install kurtosis-cli
kurtosis analytics disable
- name: Install yq
run: pip3 install yq
- name: Install foundry
uses: foundry-rs/foundry-toolchain@v1
# Deploy components.
- name: Update params.yml to use local docker images
run: |
yq -Y --in-place '.zkevm_agglayer_image = "zkevm-agglayer:local"' params.yml
yq -Y --in-place '.zkevm_bridge_service_image = "zkevm-bridge-service:local"' params.yml
yq -Y --in-place '.zkevm_bridge_ui_image = "zkevm-bridge-ui:local"' params.yml
yq -Y --in-place '.cdk_da_image = "cdk-data-availability:local"' params.yml
yq -Y --in-place '.cdk_validium_node_image = "cdk-validium-node:local"' params.yml
- name: Deploy Kurtosis CDK package
run: kurtosis run --enclave cdk-v1 --args-file params.yml .
- name: Monitor and report any potential regressions to CI logs
run: |
bake_time="${{ github.event.inputs.bake_time }}"
end_minute=$(( $(date +'%M') + bake_time))
export ETH_RPC_URL="$(kurtosis port print cdk-v1 zkevm-node-rpc-001 http-rpc)"
INITIAL_STATUS=$(cast rpc zkevm_verifiedBatchNumber 2>/dev/null)
incremented=false
while [ $(date +'%M') -lt $end_minute ]; do
# Attempt to connect to the service
if STATUS=$(cast rpc zkevm_verifiedBatchNumber 2>/dev/null); then
echo "ZKEVM_VERIFIED_BATCH_NUMBER: $STATUS"
# Check if STATUS has incremented
if [ "$STATUS" != "$INITIAL_STATUS" ]; then
incremented=true
echo "ZKEVM_VERIFIED_BATCH_NUMBER successfully incremented to $STATUS. Exiting..."
exit 0
fi
else
echo "Failed to connect, waiting and retrying..."
sleep 60
continue
fi
sleep 60
done
if ! $incremented; then
echo "ZKEVM_VERIFIED_BATCH_NUMBER did not increment. This may indicate chain experienced a regression. Please investigate."
exit 1
fi