Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Allow running integration tests separately #87

Closed
wants to merge 23 commits into from
46 changes: 39 additions & 7 deletions .github/workflows/integration.yml
Original file line number Diff line number Diff line change
@@ -1,24 +1,56 @@
name: Integration Tests

on:
workflow_dispatch:
inputs:
scriptName:
type: choice
description: "Script to run"
options:
- omnichain_swap
- omnichain_staking
- omnichain_multioutput
- messaging_counter
- messaging_message
- messaging_value
- messaging_warriors
schedule:
- cron: "0 0 * * *" # Runs every day at midnight
workflow_dispatch:

jobs:
integration:
scheduled_integration_tests:
if: github.event_name == 'schedule'
runs-on: ubuntu-latest

steps:
- name: Checkout code
uses: actions/checkout@v2

- name: Install jq
run: sudo apt-get update && sudo apt-get install -y jq

- name: Run All Scripts in scripts/test Directory
run: |
sudo apt-get update
sudo apt-get install -y jq
for script in scripts/test/*; do
if [ -f "$script" ] && [ -x "$script" ]; then
echo "Running $script..."
./$script
fi
done
env:
PRIVATE_KEY: ${{ secrets.PRIVATE_KEY }}

manual_integration_tests:
if: github.event_name == 'workflow_dispatch'
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v2

- name: Integration
run: ./scripts/integration.sh
- name: Install jq
run: sudo apt-get update && sudo apt-get install -y jq

- name: Run Script
run: |
sh ${{ github.workspace }}/scripts/test/${{ github.event.inputs.scriptName }}.sh
env:
PRIVATE_KEY: ${{ secrets.PRIVATE_KEY }}
2 changes: 2 additions & 0 deletions scripts/common.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
#!/bin/bash
SENDER=0x2cD3D070aE1BD365909dD859d29F387AA96911e1
160 changes: 0 additions & 160 deletions scripts/integration.sh

This file was deleted.

24 changes: 24 additions & 0 deletions scripts/test/messaging_counter.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
#!/bin/bash

set -e

source "$(dirname "$0")/../common.sh"

pushd "./messaging/counter"

yarn

npx hardhat compile --force

echo "Testing CCM Counter"

CCM_COUNTER_CONTRACT=$(npx hardhat deploy --networks goerli_testnet,mumbai_testnet --json | jq -r '.goerli_testnet')
echo $CCM_COUNTER_CONTRACT
CCM_COUNTER_TX_OUT=$(npx hardhat interact --network goerli_testnet --contract $CCM_COUNTER_CONTRACT --destination mumbai_testnet --amount 0.01 --json)
echo $CCM_COUNTER_TX_OUT
CCM_COUNTER_TX=$(echo $CCM_COUNTER_TX_OUT | jq -r '.hash')
echo $CCM_COUNTER_TX
CCM_COUNTER_CCTX=$(npx hardhat cctx $CCM_COUNTER_TX --json)
echo $CCM_COUNTER_CCTX

popd
23 changes: 23 additions & 0 deletions scripts/test/messaging_message.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
#!/bin/bash

set -e

source "$(dirname "$0")/../common.sh"

pushd "./messaging/message"

yarn

npx hardhat compile --force

echo "Testing CCM Message"

CCM_MESSAGE_CONTRACT=$(npx hardhat deploy --networks goerli_testnet,mumbai_testnet --json)
CCM_MESSAGE_TX_OUT=$(npx hardhat interact --network goerli_testnet --contract $(echo $CCM_MESSAGE_CONTRACT | jq -r '.goerli_testnet') --message "Hello World" --destination mumbai_testnet --amount 0.01 --json )
echo $CCM_MESSAGE_TX_OUT
CCM_MESSAGE_TX=$(echo $CCM_MESSAGE_TX_OUT | jq -r '.hash')
echo $CCM_MESSAGE_TX
CCM_MESSAGE_CCTX=$(npx hardhat cctx $CCM_MESSAGE_TX --json)
echo $CCM_MESSAGE_CCTX

popd
28 changes: 28 additions & 0 deletions scripts/test/messaging_value.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
#!/bin/bash

set -e

source "$(dirname "$0")/../common.sh"

pushd "./messaging/value"

yarn

npx hardhat compile --force

echo "Testing CCM Value"

CCM_VALUE_CONTRACT=$(npx hardhat deploy --networks goerli_testnet,mumbai_testnet --json | jq -r '.goerli_testnet')
echo $CCM_VALUE_CONTRACT
PROTOCOL_FEE=$(npx hardhat fees --json | jq -r ".feesCCM.mumbai_testnet.protocolFee")
GAS_FEE=$(npx hardhat fees --json | jq -r ".feesCCM.mumbai_testnet.gasFee")
# Multiply to be on the safe side
CCM_FEE=$(echo "$PROTOCOL_FEE + $GAS_FEE * 3" | bc -l)
CCM_VALUE_TX_OUT=$(npx hardhat interact --network goerli_testnet --contract $CCM_VALUE_CONTRACT --destination mumbai_testnet --amount $CCM_FEE --json)
echo $CCM_VALUE_TX_OUT
CCM_VALUE_TX=$(echo $CCM_VALUE_TX_OUT | jq -r '.hash')
echo $CCM_VALUE_TX
CCM_VALUE_CCTX=$(npx hardhat cctx $CCM_VALUE_TX --json)
echo $CCM_VALUE_CCTX

popd
26 changes: 26 additions & 0 deletions scripts/test/messaging_warriors.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
#!/bin/bash

set -e

source "$(dirname "$0")/../common.sh"

pushd "./messaging/warriors"

yarn

npx hardhat compile --force

echo "Testing CCM Warriors"

CCM_NFT_CONTRACT=$(npx hardhat deploy --networks goerli_testnet,mumbai_testnet --json | jq -r '.goerli_testnet')
echo $CCM_NFT_CONTRACT

CCM_NFT_MINT=$(npx hardhat mint --network goerli_testnet --contract $CCM_NFT_CONTRACT --json)
CCM_NFT_TX_OUT=$(npx hardhat interact --network goerli_testnet --contract $CCM_NFT_CONTRACT --token $CCM_NFT_MINT --destination mumbai_testnet --amount 0.01 --to $SENDER --json)
echo $CCM_NFT_TX_OUT
CCM_NFT_TX=$(echo $CCM_NFT_TX_OUT | jq -r '.hash')
echo $CCM_NFT_TX
CCM_NFT_CCTX=$(npx hardhat cctx $CCM_NFT_TX --json)
echo $CCM_NFT_CCTX

popd
24 changes: 24 additions & 0 deletions scripts/test/omnichain_mutlioutput.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
#!/bin/bash

set -e

source "$(dirname "$0")/../common.sh"

pushd "./omnichain/multioutput"

yarn

npx hardhat compile --force

echo "Testing omnichain Multioutput"

OMNI_MULTIOUTPUT_CONTRACT=$(npx hardhat deploy --network zeta_testnet --json | jq -r '.address')
echo $OMNI_MULTIOUTPUT_CONTRACT

npx hardhat destination --contract $OMNI_MULTIOUTPUT_CONTRACT --network zeta_testnet --destination mumbai_testnet
OMNI_MULTIOUTPUT_TX=$(npx hardhat interact --contract $OMNI_MULTIOUTPUT_CONTRACT --network goerli_testnet --amount 0.01 --recipient $SENDER --json | jq -r '.hash')
echo $OMNI_MULTIOUTPUT_TX
OMNI_MULTIOUTPUT_CCTX=$(npx hardhat cctx $OMNI_MULTIOUTPUT_TX --json)
echo $OMNI_MULTIOUTPUT_CCTX

popd
Loading
Loading