Skip to content

Parallel netcdf

Parallel netcdf #1593

Workflow file for this run

name: Build Gusto
on:
# Push to main or PR
push:
branches:
- main
pull_request:
schedule:
# * is a special character in YAML so you have to quote this string
# Scheduled build at 0330 UTC on Monday mornings to detect bitrot.
- cron: '30 3 * * 1'
jobs:
build:
name: "Build Gusto"
# The type of runner that the job will run on
runs-on: [self-hosted, Linux]
# The docker container to use.
container:
image: firedrakeproject/firedrake-vanilla:latest
steps:
- uses: actions/checkout@v4
- name: Cleanup
if: ${{ always() }}
run: |
cd ..
rm -rf build
- name: Install Gusto
run: |
. /home/firedrake/firedrake/bin/activate
python -m pip install -r requirements.txt
python -m pip install -e .
python -m pip install \
pytest-timeout pytest-xdist
- name: Gusto tests
run: |
. /home/firedrake/firedrake/bin/activate
firedrake-clean
export GUSTO_PARALLEL_LOG=FILE
export PYOP2_CFLAGS=-O0
python -m pip uninstall -y netCDF4
export HDF5_DIR=$PETSC_DIR/packages
export NETCDF4_DIR=$PETSC_DIR/packages
python -m pip install --no-binary netCDF4 --no-build-isolation netCDF4
python -m pytest \
-n 12 --dist worksteal \
--durations=100 \
--timeout=3600 \
--timeout-method=thread \
-o faulthandler_timeout=3660 \
-v unit-tests integration-tests examples
timeout-minutes: 120
- name: Test serial netCDF
run: |
. /home/firedrake/firedrake/bin/activate
python -m pip uninstall -y netCDF4
python -m pip cache remove netCDF4
python -m pip install --only-binary netCDF4 netCDF4
firedrake-clean
export GUSTO_PARALLEL_LOG=FILE
export PYOP2_CFLAGS=-O0
python -m pytest \
-n 12 --dist worksteal \
--durations=100 \
--timeout=3600 \
--timeout-method=thread \
-o faulthandler_timeout=3660 \
-v integration-tests/models/test_nc_outputting.py
timeout-minutes: 120
- name: Prepare logs
if: always()
run: |
mkdir logs
cd /tmp/pytest-of-firedrake/pytest-0/
find . -name "*.log" -exec cp --parents {} /__w/gusto/gusto/logs/ \;
- name: Upload artifact
if: always()
uses: actions/upload-pages-artifact@v3
with:
name: log-files
path: /__w/gusto/gusto/logs
retention-days: 5