Skip to content

feat: add base

feat: add base #52

name: Test Partners
on:
pull_request_target:
branches: [ master ]
types: [ labeled ]
paths:
- '**/partners_summary.py'
- '**/snapshot.py'
- '**/tests.partners.on_pull_req.yaml'
- '**/contracts.py'
- '**/events.py'
- '**/middleware.py'
- '**/requirements.txt'
jobs:
test_partners:
if: ${{ github.event.label.name == 'safe to test' }}
runs-on: ${{ matrix.os }}
strategy:
matrix:
os: [ ubuntu-latest, macos-latest, windows-latest ]
network: [ mainnet, ftm-main ]
include:
- os: ubuntu-latest
path: ~/.cache/pip
- os: macos-latest
path: ~/Library/Caches/pip
- os: windows-latest
path: ~\AppData\Local\pip\Cache
# Providers for all chains.
- network: mainnet
provider: WEB3_PROVIDER
- network: ftm-main
provider: FTM_WEB3_PROVIDER
fail-fast: false
steps:
- name: Check out repository code
uses: actions/checkout@v3
with:
ref: ${{github.event.pull_request.head.sha}}
persist-credentials: false
- name: Setup Python (faster than using Python container)
uses: actions/setup-python@v2
with:
python-version: "3.10"
- name: Cache dependencies
uses: actions/cache@v3
with:
key: ${{ runner.os }}-pip-${{ hashFiles('**/requirements.txt') }}
path: ${{ matrix.path }}
- name: Cache joblib middleware cache
uses: actions/cache@v3
with:
# Include requirements.txt so we recache if web3 version changes (via brownie)
key: partners-${{ runner.os }}-${{ matrix.network }}-${{ hashFiles('**/middleware.py') }}-${{ hashFiles('**/requirements.txt') }}
path: ./cache/*/joblib/web3/middleware/filter/middleware
- name: Cache compilers and brownie deployments
uses: actions/cache@v3
with:
key: partners-${{ runner.os }}-brownie-cache-${{ matrix.network }}
path: |
~/.brownie/deployments.db
~/.solcx
~/.vvm
- name: Prep dependencies
run: pip install wheel && pip install "Cython<3.0" "pyyaml==5.4.1" --no-build-isolation
- name: Install dependencies
run: pip install -r requirements.txt
- name: Setup brownie networks
run: brownie networks modify ${{ matrix.network }} host=${{ secrets[matrix.provider] }}
# continue-on-error is needed because this step will raise an exception on Windows, but will still correctly set the host.
continue-on-error: true
- name: Test partners_summary.py
env:
# Explorer tokens for all chains:
ETHERSCAN_TOKEN: ${{ secrets.ETHERSCAN_TOKEN }}
FTMSCAN_TOKEN: ${{ secrets.FTMSCAN_TOKEN }}
YPRICEAPI_SIGNER: ${{ secrets.YPRICEAPI_SIGNER }}
YPRICEAPI_SIGNATURE: ${{ secrets.YPRICEAPI_SIGNATURE }}
run: brownie run partners_summary --network ${{ matrix.network }}