This repository has been archived by the owner on Nov 27, 2024. It is now read-only.
Fix for massively parallel performance regression #547
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: CI | |
# Trigger the workflow on push or pull request, | |
# but only for the master branch | |
on: | |
push: | |
branches: | |
- master | |
pull_request: | |
branches: | |
- master | |
jobs: | |
test: | |
runs-on: ubuntu-latest | |
strategy: | |
# Don't immediately kill all if one Python version fails | |
fail-fast: false | |
matrix: | |
python-version: ['3.8', '3.9', '3.10', '3.11'] | |
env: | |
CC: mpicc | |
PETSC_DIR: ${{ github.workspace }}/petsc | |
PETSC_ARCH: default | |
PETSC_CONFIGURE_OPTIONS: --with-debugging=1 --with-shared-libraries=1 --with-c2html=0 --with-fortran-bindings=0 | |
RDMAV_FORK_SAFE: 1 | |
PYOP2_CI_TESTS: 1 | |
timeout-minutes: 60 | |
steps: | |
- name: Install system dependencies | |
shell: bash | |
run: | | |
sudo apt update | |
sudo apt install build-essential mpich libmpich-dev \ | |
libblas-dev liblapack-dev gfortran | |
- name: Set correct Python version | |
uses: actions/setup-python@v2 | |
with: | |
python-version: ${{ matrix.python-version }} | |
- name: Clone PETSc | |
uses: actions/checkout@v2 | |
with: | |
repository: firedrakeproject/petsc | |
path: ${{ env.PETSC_DIR }} | |
- name: Build and install PETSc | |
shell: bash | |
working-directory: ${{ env.PETSC_DIR }} | |
run: | | |
./configure ${PETSC_CONFIGURE_OPTIONS} | |
make | |
- name: Build and install petsc4py | |
shell: bash | |
working-directory: ${{ env.PETSC_DIR }}/src/binding/petsc4py | |
run: | | |
python -m pip install --upgrade pip | |
python -m pip install --upgrade wheel 'cython<3' numpy | |
python -m pip install --no-deps . | |
- name: Checkout PyOP2 | |
uses: actions/checkout@v2 | |
with: | |
path: PyOP2 | |
- name: Install PyOP2 | |
shell: bash | |
working-directory: PyOP2 | |
run: | | |
# xargs is used to force installation of requirements in the order we specified. | |
xargs -l1 python -m pip install < requirements-ext.txt | |
xargs -l1 python -m pip install < requirements-git.txt | |
python -m pip install pulp | |
python -m pip install -U flake8 | |
python -m pip install -U pytest-timeout | |
python -m pip install . | |
- name: Run linting | |
shell: bash | |
working-directory: PyOP2 | |
run: make lint | |
- name: Run tests | |
shell: bash | |
working-directory: PyOP2 | |
run: pytest --tb=native --timeout=480 --timeout-method=thread -o faulthandler_timeout=540 -v test | |
timeout-minutes: 10 | |
- name: Build documentation | |
if: ${{ matrix.python-version == '3.10' }} | |
shell: bash | |
working-directory: PyOP2 | |
run: | | |
python -m pip install sphinx | |
make -C doc/sphinx html | |
- name: Upload to github pages | |
if: ${{ github.ref == 'refs/heads/master' && github.event_name == 'push' && matrix.python-version== '3.10' }} | |
uses: crazy-max/[email protected] | |
with: | |
build_dir: PyOP2/doc/sphinx/build/html | |
jekyll: false | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} |