Featuring SQ mech tool #1000
Workflow file for this run
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: main_workflow | |
on: | |
push: | |
branches: | |
- develop | |
- main | |
pull_request: | |
jobs: | |
lock_check: | |
continue-on-error: False | |
runs-on: ${{ matrix.os }} | |
strategy: | |
matrix: | |
os: [ ubuntu-latest, macos-latest, windows-latest ] | |
python-version: [ "3.10" ] | |
poetry-version: ["1.4.0"] | |
defaults: | |
run: | |
shell: bash | |
timeout-minutes: 10 | |
steps: | |
- uses: actions/checkout@v3 | |
- uses: actions/setup-python@v4 | |
with: | |
python-version: ${{ matrix.python-version }} | |
- name: Install and configure Poetry | |
uses: snok/install-poetry@v1 | |
with: | |
version: ${{ matrix.poetry-version }} | |
virtualenvs-create: true | |
virtualenvs-in-project: false | |
virtualenvs-path: ~/my-custom-path | |
installer-parallel: true | |
- name: Check if dependencies can be locked | |
run: poetry lock --check | |
- name: Poetry install requirements and check they can be locked | |
run: poetry install --all-extras --no-interaction -vvv | |
copyright_and_dependencies_check: | |
continue-on-error: False | |
runs-on: ${{ matrix.os }} | |
strategy: | |
matrix: | |
os: [ ubuntu-latest ] | |
python-version: [ "3.10" ] | |
timeout-minutes: 30 | |
steps: | |
- uses: actions/checkout@v3 | |
with: | |
fetch-depth: 0 | |
- uses: actions/setup-python@v4 | |
with: | |
python-version: ${{ matrix.python-version }} | |
- name: Install dependencies | |
run: pip install tomte[tox,cli]==0.2.14 | |
- name: Check copyright headers | |
run: tomte check-copyright --author valory --exclude-part abci --exclude-part http_client --exclude-part ipfs --exclude-part ledger --exclude-part p2p_libp2p_client --exclude-part gnosis_safe --exclude-part gnosis_safe_proxy_factory --exclude-part multisend --exclude-part service_registry --exclude-part protocols --exclude-part abstract_abci --exclude-part abstract_round_abci --exclude-part registration_abci --exclude-part reset_pause_abci --exclude-part termination_abci --exclude-part transaction_settlement_abci --exclude-part websocket_client --exclude-part contract_subscription --exclude-part mech --exclude-part mech_interact_abci --exclude-part http_server | |
- name: License compatibility check | |
run: tox -e liccheck | |
# TODO: reactivate once false positives are fixed | |
# - name: Check dependencies | |
# run: tox -e check-dependencies | |
- name: Check doc links | |
run: tomte check-doc-links | |
- name: Check doc IPFS hashes | |
run: tox -e check-doc-hashes | |
linter_checks: | |
continue-on-error: False | |
runs-on: ${{ matrix.os }} | |
strategy: | |
matrix: | |
os: [ ubuntu-latest ] | |
python-version: [ "3.10" ] | |
timeout-minutes: 30 | |
steps: | |
- uses: actions/checkout@v3 | |
- uses: actions/setup-python@v4 | |
with: | |
python-version: ${{ matrix.python-version }} | |
- name: Install dependencies | |
run: | | |
pip install tomte[tox,cli]==0.2.17 | |
# Install `mdspell` for spelling checks | |
sudo npm install -g markdown-spellcheck | |
- name: Security checks | |
# TODO: tomte check-security | |
run: echo "Skipped until service is bumped" | |
- name: Check packages | |
run: tox -e check-packages | |
- name: Check hash | |
run: tox -e check-hash | |
- name: Code checks | |
run: tomte check-code | |
- name: Check spelling | |
run: tomte check-spelling | |
- name: AbciApp consistency checks | |
run: | | |
tox -e check-abci-docstrings | |
tox -e check-abciapp-specs | |
tox -e check-handlers | |
tox -e analyse-service | |
scan: | |
name: gitleaks | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
with: | |
fetch-depth: 0 | |
- run: | | |
wget https://github.com/zricethezav/gitleaks/releases/download/v8.10.1/gitleaks_8.10.1_linux_x64.tar.gz && \ | |
tar -xzf gitleaks_8.10.1_linux_x64.tar.gz && \ | |
sudo install gitleaks /usr/bin && \ | |
gitleaks detect --report-format json --report-path leak_report -v | |
test: | |
continue-on-error: True | |
needs: | |
- lock_check | |
- copyright_and_dependencies_check | |
- linter_checks | |
runs-on: ${{ matrix.os }} | |
strategy: | |
matrix: | |
os: [ ubuntu-latest ] | |
python-version: [ "3.10" ] | |
timeout-minutes: 120 | |
steps: | |
- uses: actions/checkout@v2 | |
with: | |
fetch-depth: 0 | |
- uses: actions/setup-python@v3 | |
with: | |
python-version: ${{ matrix.python-version }} | |
- name: Install dependencies | |
run: | | |
sudo apt-get update --fix-missing | |
sudo apt-get autoremove | |
sudo apt-get autoclean | |
pip install tomte[tox,cli]==0.2.15 | |
pip install --user --upgrade setuptools | |
- name: Tool unit tests | |
env: | |
OPENAI_SECRET_KEY: ${{ secrets.OPENAI_API_KEY }} | |
STABILITY_API_KEY: ${{ secrets.STABILITY_AI_KEY }} | |
GOOGLE_API_KEY: ${{ secrets.GOOGLE_API_KEY }} | |
GOOGLE_ENGINE_ID: ${{ vars.GOOGLE_ENGINE_ID }} | |
CLAUDE_API_KEY: ${{ secrets.CLAUDE_API_KEY }} | |
REPLICATE_API_KEY: ${{ secrets.REPLICATE_API_KEY }} | |
NEWS_API_KEY: ${{ secrets.NEWS_API_KEY }} | |
OPENROUTER_API_KEY: ${{ secrets.OPEN_ROUTER_API_KEY }} | |
GNOSIS_RPC_URL: ${{ secrets.GNOSIS_RPC_URL }} | |
GEMINI_API_KEY: ${{ secrets.GEMINI_API_KEY }} | |
run: | | |
printenv | |
tox -e check-tools |