Skip to content

Fix dependencies conflict between tensorflow and decomon in binder env #435

Fix dependencies conflict between tensorflow and decomon in binder env

Fix dependencies conflict between tensorflow and decomon in binder env #435

Workflow file for this run

name: CI
on:
push:
branches:
- "**"
pull_request:
workflow_dispatch:
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true
jobs:
linters:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: create requirements.txt so that pip cache with setup-python works
run: echo "pre-commit" > requirements_precommit.txt
- uses: actions/setup-python@v4
with:
python-version: 3.8
cache: pip
cache-dependency-path: requirements_precommit.txt
- name: install pre-commit
run: python -m pip install pre-commit
- name: get cached pre-commit hooks
uses: actions/cache@v3
with:
path: ~/.cache/pre-commit
key: pre-commit|${{ env.pythonLocation }}|${{ hashFiles('.pre-commit-config.yaml') }}
- name: pre-commit checks
run: pre-commit run --all-files --show-diff-on-failure --color=always
type-checking:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: actions/setup-python@v4
with:
python-version: 3.9
cache: pip
cache-dependency-path: pyproject.toml
- name: Install dependencies
run: |
python -m pip install --upgrade pip
python -m pip install --upgrade tox setuptools
- name: Restore cached .tox
id: cache-tox
uses: actions/cache@v3
with:
path: .tox
key:
tox-${{ matrix.python-version }}-${{ matrix.os }}-${{ hashFiles('pyproject.toml') }}
restore-keys:
tox-${{ matrix.python-version }}-${{ matrix.os }}
- name: Run mypy via tox
run: python -m tox -e type
tests:
strategy:
fail-fast: false
matrix:
python-version: ["3.9", "3.11"]
os: ["ubuntu-latest", "macos-latest", "windows-latest"]
backend: ["tf", "torch"]
runs-on: ${{ matrix.os }}
defaults:
run:
shell: bash
steps:
- uses: actions/checkout@v3
- uses: actions/setup-python@v4
with:
python-version: ${{ matrix.python-version }}
cache: pip
cache-dependency-path: pyproject.toml
- name: Install dependencies
run: |
python -m pip install --upgrade pip
python -m pip install --upgrade tox setuptools
- name: Restore cached .tox
id: cache-tox
uses: actions/cache@v3
with:
path: .tox
key:
tox-${{ matrix.python-version }}-${{ matrix.os }}-${{ matrix.backend }}-${{ hashFiles('pyproject.toml') }}
restore-keys:
tox-${{ matrix.python-version }}-${{ matrix.os }}-${{ matrix.backend }}
tox-${{ matrix.python-version }}-${{ matrix.os }}
- name: Pick proper tox env
shell: python
run: |
import os; import platform; import sys; from pathlib import Path
platform_mapping = {
"Linux": "linux",
"Darwin": "macos",
"Windows": "win",
}
pythonversion = f'py{"" if platform.python_implementation() == "CPython" else "py"}3{sys.version_info.minor}'
platformversion=platform_mapping[platform.system()]
toxenv = f"{pythonversion}-{platformversion}"
toxenv += "-${{ matrix.backend }}"
set_toxenv_cmd = f"TOXENV={toxenv}"
print(f"Picked: {toxenv}")
with Path(os.environ["GITHUB_ENV"]).open("ta") as file_handler:
file_handler.write(set_toxenv_cmd)
- name: Run tox target env for ${{ env.TOXENV }}
run: |
python -m tox -e convert-doc-to-test # extract code blocks from doc to test them
python -m tox # launch environment set by TOXENV at previous step
- name: Check if coverage report exists
id: check-coverage-report
run: |
if [ -f coverage.xml ]; then
coverage_exists=true
else
coverage_exists=false
fi
echo ${coverage_exists}
echo "coverage_exists=${coverage_exists}" >> $GITHUB_OUTPUT
- name: Export coverage report (if existing)
if: steps.check-coverage-report.outputs.coverage_exists == 'true'
uses: actions/upload-artifact@v3
with:
name: coverage
path: |
coverage.xml
coverage_html
build-doc:
uses: ./.github/workflows/build-doc.yml
deploy-doc:
# for default branch (main)
if: github.ref == format('refs/heads/{0}', github.event.repository.default_branch)
needs: [build-doc, tests, linters]
uses: ./.github/workflows/deploy-doc.yml
with:
doc-version: ${{ needs.build-doc.outputs.doc-version }}
binder-env-fullref: ${{ github.repository }}/${{ github.ref_name}}