185 lines
7.9 KiB
YAML
185 lines
7.9 KiB
YAML
name: Test Fabric
|
|
|
|
# see: https://help.github.com/en/actions/reference/events-that-trigger-workflows
|
|
on:
|
|
push:
|
|
branches: [master, "release/*"]
|
|
pull_request:
|
|
branches: [master, "release/*"]
|
|
types: [opened, reopened, ready_for_review, synchronize] # added `ready_for_review` since draft is skipped
|
|
paths:
|
|
- ".actions/*"
|
|
- "requirements/fabric/**"
|
|
- "src/lightning/fabric/**"
|
|
- "src/lightning_fabric/*"
|
|
- "tests/tests_fabric/**"
|
|
- "pyproject.toml" # includes pytest config
|
|
- ".github/workflows/ci-tests-fabric.yml"
|
|
- "!requirements/*/docs.txt"
|
|
- "!*.md"
|
|
- "!**/*.md"
|
|
schedule:
|
|
# At the end of every day
|
|
- cron: "0 0 * * *"
|
|
|
|
concurrency:
|
|
group: ${{ github.workflow }}-${{ github.ref }}-${{ github.head_ref }}
|
|
cancel-in-progress: ${{ ! (github.ref == 'refs/heads/master' || startsWith(github.ref, 'refs/heads/release/')) }}
|
|
|
|
defaults:
|
|
run:
|
|
shell: bash
|
|
|
|
jobs:
|
|
fabric-cpu:
|
|
runs-on: ${{ matrix.os }}
|
|
if: github.event.pull_request.draft == false
|
|
strategy:
|
|
fail-fast: false
|
|
matrix:
|
|
include:
|
|
- { os: "macOS-11", pkg-name: "lightning", python-version: "3.8", pytorch-version: "1.11" }
|
|
- { os: "macOS-11", pkg-name: "lightning", python-version: "3.9", pytorch-version: "1.12" }
|
|
- { os: "macOS-11", pkg-name: "lightning", python-version: "3.10", pytorch-version: "1.13" }
|
|
- { os: "ubuntu-20.04", pkg-name: "lightning", python-version: "3.8", pytorch-version: "1.11" }
|
|
- { os: "ubuntu-20.04", pkg-name: "lightning", python-version: "3.9", pytorch-version: "1.12" }
|
|
- { os: "ubuntu-20.04", pkg-name: "lightning", python-version: "3.10", pytorch-version: "1.13" }
|
|
- { os: "windows-2022", pkg-name: "lightning", python-version: "3.8", pytorch-version: "1.11" }
|
|
- { os: "windows-2022", pkg-name: "lightning", python-version: "3.9", pytorch-version: "1.12" }
|
|
- { os: "windows-2022", pkg-name: "lightning", python-version: "3.10", pytorch-version: "1.13" }
|
|
# only run PyTorch latest with Python recent
|
|
- { os: "macOS-11", pkg-name: "lightning", python-version: "3.10", pytorch-version: "2.0" }
|
|
- { os: "ubuntu-20.04", pkg-name: "lightning", python-version: "3.10", pytorch-version: "2.0" }
|
|
- { os: "windows-2022", pkg-name: "lightning", python-version: "3.10", pytorch-version: "2.0" }
|
|
# only run PyTorch latest with Python latest, use Fabric scope to limit dependency issues
|
|
- { os: "macOS-12", pkg-name: "fabric", python-version: "3.11", pytorch-version: "2.0" }
|
|
- { os: "ubuntu-22.04", pkg-name: "fabric", python-version: "3.11", pytorch-version: "2.0" }
|
|
- { os: "windows-2022", pkg-name: "fabric", python-version: "3.11", pytorch-version: "2.0" }
|
|
# "oldest" versions tests, only on minimum Python
|
|
- {
|
|
os: "macOS-11",
|
|
pkg-name: "lightning",
|
|
python-version: "3.8",
|
|
pytorch-version: "1.11",
|
|
requires: "oldest",
|
|
}
|
|
- {
|
|
os: "ubuntu-20.04",
|
|
pkg-name: "lightning",
|
|
python-version: "3.8",
|
|
pytorch-version: "1.11",
|
|
requires: "oldest",
|
|
}
|
|
- {
|
|
os: "windows-2022",
|
|
pkg-name: "lightning",
|
|
python-version: "3.8",
|
|
pytorch-version: "1.11",
|
|
requires: "oldest",
|
|
}
|
|
# "fabric" installs the standalone package
|
|
- { os: "macOS-11", pkg-name: "fabric", python-version: "3.8", pytorch-version: "1.13" }
|
|
- { os: "ubuntu-20.04", pkg-name: "fabric", python-version: "3.8", pytorch-version: "1.13" }
|
|
- { os: "windows-2022", pkg-name: "fabric", python-version: "3.8", pytorch-version: "1.13" }
|
|
timeout-minutes: 25 # because of building grpcio on Mac
|
|
env:
|
|
PACKAGE_NAME: ${{ matrix.pkg-name }}
|
|
FREEZE_REQUIREMENTS: ${{ ! (github.ref == 'refs/heads/master' || startsWith(github.ref, 'refs/heads/release/')) }}
|
|
PYPI_CACHE_DIR: "_pip-wheels"
|
|
TORCH_URL_STABLE: "https://download.pytorch.org/whl/cpu/torch_stable.html"
|
|
TORCH_URL_TEST: "https://download.pytorch.org/whl/test/cpu/torch_test.html"
|
|
steps:
|
|
- uses: actions/checkout@v4
|
|
|
|
- name: Set up Python ${{ matrix.python-version }}
|
|
uses: actions/setup-python@v4
|
|
with:
|
|
python-version: ${{ matrix.python-version }}
|
|
|
|
- name: basic setup
|
|
run: pip install -q -r .actions/requirements.txt
|
|
|
|
- name: Set min. dependencies
|
|
if: ${{ matrix.requires == 'oldest' }}
|
|
run: python .actions/assistant.py replace_oldest_ver
|
|
|
|
- name: Adjust PyTorch versions in requirements files
|
|
if: ${{ matrix.requires != 'oldest' }}
|
|
run: |
|
|
pip install -q wget packaging
|
|
python -m wget https://raw.githubusercontent.com/Lightning-AI/utilities/main/scripts/adjust-torch-versions.py
|
|
for fpath in `ls requirements/**/*.txt`; do \
|
|
python ./adjust-torch-versions.py $fpath ${{ matrix.pytorch-version }}; \
|
|
done
|
|
cat requirements/fabric/base.txt
|
|
|
|
- name: pip wheels cache
|
|
uses: actions/cache/restore@v3
|
|
with:
|
|
path: ${{ env.PYPI_CACHE_DIR }}
|
|
key: pypi_wheels
|
|
- run: |
|
|
mkdir -p $PYPI_CACHE_DIR
|
|
ls -lh $PYPI_CACHE_DIR
|
|
|
|
- name: Env. variables
|
|
run: |
|
|
# Switch PyTorch URL
|
|
#python -c "print('TORCH_URL=' + str('${{env.TORCH_URL_TEST}}' if '${{ matrix.release }}' == 'pre' else '${{env.TORCH_URL_STABLE}}'))" >> $GITHUB_ENV
|
|
# Switch coverage scope
|
|
python -c "print('COVERAGE_SCOPE=' + str('lightning' if '${{matrix.pkg-name}}' == 'lightning' else 'lightning_fabric'))" >> $GITHUB_ENV
|
|
# if you install mono-package set dependency only for this subpackage
|
|
python -c "print('EXTRA_PREFIX=' + str('' if '${{matrix.pkg-name}}' != 'lightning' else 'fabric-'))" >> $GITHUB_ENV
|
|
|
|
- name: Install package & dependencies
|
|
timeout-minutes: 20
|
|
run: |
|
|
#python -m pip install -q pip -U
|
|
pip install -e ".[${EXTRA_PREFIX}test,${EXTRA_PREFIX}strategies]" -U --prefer-binary \
|
|
--find-links="${TORCH_URL}" --find-links="${PYPI_CACHE_DIR}"
|
|
pip list
|
|
- name: Dump handy wheels
|
|
if: github.event_name == 'push' && github.ref == 'refs/heads/master'
|
|
continue-on-error: true
|
|
uses: ./.github/actions/pip-wheels
|
|
with:
|
|
wheel-dir: ${{ env.PYPI_CACHE_DIR }}
|
|
torch-url: ${{ env.TORCH_URL }}
|
|
cache-key: "pypi_wheels"
|
|
|
|
- name: Adjust tests
|
|
if: ${{ matrix.pkg-name != 'lightning' }}
|
|
run: |
|
|
python .actions/assistant.py copy_replace_imports --source_dir="./tests" \
|
|
--source_import="lightning.fabric" --target_import="lightning_fabric"
|
|
|
|
- name: Testing Warnings
|
|
working-directory: tests/tests_fabric
|
|
# needs to run outside of `pytest`
|
|
run: python utilities/test_warnings.py
|
|
|
|
- name: Testing Fabric
|
|
working-directory: tests/tests_fabric
|
|
# NOTE: do not include coverage report here, see: https://github.com/nedbat/coveragepy/issues/1003
|
|
run: |
|
|
python -m coverage run --source ${{ env.COVERAGE_SCOPE }} \
|
|
-m pytest -v --timeout=30 --durations=50
|
|
|
|
- name: Statistics
|
|
if: success()
|
|
working-directory: tests/tests_fabric
|
|
run: |
|
|
coverage report
|
|
coverage xml
|
|
|
|
- name: Upload coverage to Codecov
|
|
uses: codecov/codecov-action@v3
|
|
# see: https://github.com/actions/toolkit/issues/399
|
|
continue-on-error: true
|
|
with:
|
|
token: ${{ secrets.CODECOV_TOKEN }}
|
|
file: tests/tests_fabric/coverage.xml
|
|
flags: ${{ env.COVERAGE_SCOPE }},cpu,pytest,python${{ matrix.python-version }}
|
|
name: CPU-coverage
|
|
fail_ci_if_error: false
|