chore(contracts): Avoid code duplication in AbstractPortal (#826) #1438
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Smart Contracts | |
on: | |
pull_request: | |
branches: | |
- main | |
- dev | |
- release/* | |
push: | |
branches: | |
- main | |
- dev | |
- release/* | |
env: | |
FOUNDRY_PROFILE: ci | |
jobs: | |
build-contracts: | |
runs-on: ubuntu-latest | |
defaults: | |
run: | |
working-directory: contracts | |
steps: | |
- name: Check out the repo | |
uses: actions/checkout@v3 | |
with: | |
submodules: recursive | |
- name: Install Pnpm | |
uses: pnpm/action-setup@v2 | |
with: | |
version: 9 | |
run_install: false | |
- name: Install Node.js | |
uses: actions/setup-node@v3 | |
with: | |
node-version: 18 | |
cache: pnpm | |
- name: Get pnpm store directory | |
shell: bash | |
run: | | |
echo "STORE_PATH=$(pnpm store path --silent)" >> $GITHUB_ENV | |
- uses: actions/cache@v3 | |
name: Setup pnpm cache | |
with: | |
path: ${{ env.STORE_PATH }} | |
key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }} | |
restore-keys: | | |
${{ runner.os }}-pnpm-store- | |
- name: Install dependencies | |
run: pnpm install --frozen-lockfile | |
- name: Install Foundry | |
uses: foundry-rs/foundry-toolchain@v1 | |
- name: Show the Foundry config | |
run: forge config | |
- name: Produce a build | |
run: forge build | |
- name: Add build summary | |
run: | | |
echo "## Build result" >> $GITHUB_STEP_SUMMARY | |
echo "✅ Passed" >> $GITHUB_STEP_SUMMARY | |
test-contracts: | |
runs-on: ubuntu-latest | |
defaults: | |
run: | |
working-directory: contracts | |
env: | |
FOUNDRY_FUZZ_RUNS: 1000 | |
needs: build-contracts | |
steps: | |
- name: Check out the repo | |
uses: actions/checkout@v3 | |
with: | |
submodules: recursive | |
- name: Install Pnpm | |
uses: pnpm/action-setup@v2 | |
with: | |
version: 9 | |
run_install: false | |
- name: Install Node.js | |
uses: actions/setup-node@v3 | |
with: | |
node-version: 18 | |
cache: pnpm | |
- name: Get pnpm store directory | |
shell: bash | |
run: | | |
echo "STORE_PATH=$(pnpm store path --silent)" >> $GITHUB_ENV | |
- uses: actions/cache@v3 | |
name: Setup pnpm cache | |
with: | |
path: ${{ env.STORE_PATH }} | |
key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }} | |
restore-keys: | | |
${{ runner.os }}-pnpm-store- | |
- name: Install dependencies | |
run: pnpm install --frozen-lockfile | |
- name: Install Foundry | |
uses: foundry-rs/foundry-toolchain@v1 | |
- name: Run the unit tests | |
run: forge test | |
- name: Add test summary | |
run: | | |
echo "## Unit tests result" >> $GITHUB_STEP_SUMMARY | |
echo "✅ Passed" >> $GITHUB_STEP_SUMMARY | |
coverage-contracts: | |
runs-on: ubuntu-latest | |
needs: build-contracts | |
steps: | |
- name: Check out the repo | |
uses: actions/checkout@v3 | |
with: | |
submodules: recursive | |
fetch-depth: 0 | |
- id: check-changes | |
run: | | |
if [ -n "$(git diff --name-only ${{ github.event.pull_request.base.sha }} ${{ github.event.pull_request.head.sha }} | grep '^contracts/')" ]; then | |
echo "::set-output name=changed::true" | |
else | |
echo "::set-output name=changed::false" | |
fi | |
- name: Install Pnpm | |
if: steps.check-changes.outputs.changed == 'true' | |
uses: pnpm/action-setup@v2 | |
with: | |
version: 9 | |
run_install: false | |
- name: Install Node.js | |
if: steps.check-changes.outputs.changed == 'true' | |
uses: actions/setup-node@v3 | |
with: | |
node-version: 18 | |
cache: pnpm | |
- name: Get pnpm store directory | |
if: steps.check-changes.outputs.changed == 'true' | |
shell: bash | |
run: | | |
echo "STORE_PATH=$(pnpm store path --silent)" >> $GITHUB_ENV | |
- uses: actions/cache@v3 | |
if: steps.check-changes.outputs.changed == 'true' | |
name: Setup pnpm cache | |
with: | |
path: ${{ env.STORE_PATH }} | |
key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }} | |
restore-keys: | | |
${{ runner.os }}-pnpm-store- | |
- name: Install dependencies | |
if: steps.check-changes.outputs.changed == 'true' | |
run: pnpm install --frozen-lockfile | |
- name: Install Foundry | |
if: steps.check-changes.outputs.changed == 'true' | |
uses: foundry-rs/foundry-toolchain@v1 | |
- name: Generate the coverage report using the unit tests | |
if: steps.check-changes.outputs.changed == 'true' | |
run: cd contracts && forge coverage --report lcov | |
- name: Move the report at the root of the project | |
if: steps.check-changes.outputs.changed == 'true' | |
run: mv contracts/lcov.info . | |
- name: Upload coverage report to Codecov | |
if: steps.check-changes.outputs.changed == 'true' | |
uses: codecov/codecov-action@v3 | |
with: | |
files: ./lcov.info | |
token: ${{ secrets.CODECOV_TOKEN }} | |
fail_ci_if_error: true | |
verbose: true | |
- name: Check test coverage | |
if: steps.check-changes.outputs.changed == 'true' | |
uses: terencetcf/github-actions-lcov-minimum-coverage-checker@v1 | |
with: | |
coverage-file: lcov.info | |
minimum-coverage: 94 | |
- name: Add coverage summary | |
if: steps.check-changes.outputs.changed == 'true' | |
run: | | |
echo "## Coverage result" >> $GITHUB_STEP_SUMMARY | |
echo "✅ Uploaded to Codecov" >> $GITHUB_STEP_SUMMARY | |
- name: Add coverage summary | |
if: steps.check-changes.outputs.changed == 'false' | |
run: | | |
echo "## Coverage result" >> $GITHUB_STEP_SUMMARY | |
echo "✅ No coverage report to upload" >> $GITHUB_STEP_SUMMARY | |
upgradeability-contracts: | |
runs-on: ubuntu-latest | |
defaults: | |
run: | |
working-directory: contracts | |
needs: build-contracts | |
steps: | |
- name: Check out the repo | |
uses: actions/checkout@v3 | |
with: | |
submodules: recursive | |
fetch-depth: 0 | |
- id: check-changes | |
run: | | |
if [ -n "$(git diff --name-only ${{ github.event.pull_request.base.sha }} ${{ github.event.pull_request.head.sha }} | grep '^contracts/')" ]; then | |
echo "::set-output name=changed::true" | |
else | |
echo "::set-output name=changed::false" | |
fi | |
- name: Install Pnpm | |
if: steps.check-changes.outputs.changed == 'true' | |
uses: pnpm/action-setup@v2 | |
with: | |
version: 9 | |
run_install: false | |
- name: Install Node.js | |
if: steps.check-changes.outputs.changed == 'true' | |
uses: actions/setup-node@v3 | |
with: | |
node-version: 18 | |
cache: pnpm | |
- name: Get pnpm store directory | |
if: steps.check-changes.outputs.changed == 'true' | |
shell: bash | |
run: | | |
echo "STORE_PATH=$(pnpm store path --silent)" >> $GITHUB_ENV | |
- uses: actions/cache@v3 | |
if: steps.check-changes.outputs.changed == 'true' | |
name: Setup pnpm cache | |
with: | |
path: ${{ env.STORE_PATH }} | |
key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }} | |
restore-keys: | | |
${{ runner.os }}-pnpm-store- | |
- name: Install dependencies | |
if: steps.check-changes.outputs.changed == 'true' | |
run: pnpm install --frozen-lockfile | |
- name: Install Pnpm | |
if: steps.check-changes.outputs.changed == 'true' | |
uses: pnpm/action-setup@v2 | |
with: | |
version: 9 | |
run_install: false | |
- name: Install Node.js | |
if: steps.check-changes.outputs.changed == 'true' | |
uses: actions/setup-node@v3 | |
with: | |
node-version: 18 | |
cache: pnpm | |
- name: Get pnpm store directory | |
if: steps.check-changes.outputs.changed == 'true' | |
shell: bash | |
run: | | |
echo "STORE_PATH=$(pnpm store path --silent)" >> $GITHUB_ENV | |
- uses: actions/cache@v3 | |
if: steps.check-changes.outputs.changed == 'true' | |
name: Setup pnpm cache | |
with: | |
path: ${{ env.STORE_PATH }} | |
key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }} | |
restore-keys: | | |
${{ runner.os }}-pnpm-store- | |
- name: Install dependencies | |
if: steps.check-changes.outputs.changed == 'true' | |
run: pnpm install --frozen-lockfile | |
- name: Install Foundry | |
if: steps.check-changes.outputs.changed == 'true' | |
uses: foundry-rs/foundry-toolchain@v1 | |
- name: Check contracts implementations | |
if: steps.check-changes.outputs.changed == 'true' | |
run: pnpm run check:implementations | |
- name: Create Linea Sepolia env file | |
if: steps.check-changes.outputs.changed == 'true' | |
run: | | |
cp ./env/.env.linea-sepolia .env | |
echo INFURA_KEY=${{ secrets.INFURA_KEY }} >> .env | |
- name: Check contracts upgradeability on Linea Sepolia | |
if: steps.check-changes.outputs.changed == 'true' | |
run: pnpm run check:upgradeability linea-sepolia | |
- name: Create Linea mainnet env file | |
if: steps.check-changes.outputs.changed == 'true' | |
run: | | |
rm .env | |
cp ./env/.env.linea .env | |
echo INFURA_KEY=${{ secrets.INFURA_KEY }} >> .env | |
- name: Check contracts upgradeability on Linea mainnet | |
if: steps.check-changes.outputs.changed == 'true' | |
run: pnpm run check:upgradeability linea | |
- name: Create Arbitrum Sepolia env file | |
if: steps.check-changes.outputs.changed == 'true' | |
run: | | |
rm .env | |
cp ./env/.env.arbitrum-sepolia .env | |
echo INFURA_KEY=${{ secrets.INFURA_KEY }} >> .env | |
- name: Check contracts upgradeability on Arbitrum Sepolia | |
if: steps.check-changes.outputs.changed == 'true' | |
run: pnpm run check:upgradeability arbitrum-sepolia | |
- name: Create Arbitrum mainnet env file | |
if: steps.check-changes.outputs.changed == 'true' | |
run: | | |
rm .env | |
cp ./env/.env.arbitrum .env | |
echo INFURA_KEY=${{ secrets.INFURA_KEY }} >> .env | |
- name: Check contracts upgradeability on Arbitrum mainnet | |
if: steps.check-changes.outputs.changed == 'true' | |
run: pnpm run check:upgradeability arbitrum | |
- name: Create Base Sepolia env file | |
if: steps.check-changes.outputs.changed == 'true' | |
run: | | |
rm .env | |
cp ./env/.env.base-sepolia .env | |
echo INFURA_KEY=${{ secrets.INFURA_KEY }} >> .env | |
- name: Check contracts upgradeability on Base Sepolia | |
if: steps.check-changes.outputs.changed == 'true' | |
run: pnpm run check:upgradeability base-sepolia | |
- name: Create Base mainnet env file | |
if: steps.check-changes.outputs.changed == 'true' | |
run: | | |
rm .env | |
cp ./env/.env.base .env | |
echo INFURA_KEY=${{ secrets.INFURA_KEY }} >> .env | |
- name: Check contracts upgradeability on Base | |
if: steps.check-changes.outputs.changed == 'true' | |
run: pnpm run check:upgradeability base | |
- name: Create BSC testnet env file | |
if: steps.check-changes.outputs.changed == 'true' | |
run: | | |
rm .env | |
cp ./env/.env.bsc-testnet .env | |
echo INFURA_KEY=${{ secrets.INFURA_KEY }} >> .env | |
- name: Check contracts upgradeability on BSC testnet | |
if: steps.check-changes.outputs.changed == 'true' | |
run: pnpm run check:upgradeability bsc-testnet | |
- name: Create BSC mainnet env file | |
if: steps.check-changes.outputs.changed == 'true' | |
run: | | |
rm .env | |
cp ./env/.env.bsc .env | |
echo INFURA_KEY=${{ secrets.INFURA_KEY }} >> .env | |
- name: Check contracts upgradeability on BSC mainnet | |
if: steps.check-changes.outputs.changed == 'true' | |
run: pnpm run check:upgradeability bsc | |
- name: Add upgradeability summary | |
if: steps.check-changes.outputs.changed == 'true' | |
run: | | |
echo "## Upgradeability check result" >> $GITHUB_STEP_SUMMARY | |
echo "✅ Contracts are upgradeable" >> $GITHUB_STEP_SUMMARY | |
- name: Add upgradeability summary | |
if: steps.check-changes.outputs.changed == 'false' | |
run: | | |
echo "## Upgradeability check result" >> $GITHUB_STEP_SUMMARY | |
echo "✅ No change detected in the contracts" >> $GITHUB_STEP_SUMMARY |