Skip to content

Revamp CI with dependency and Python caching for efficient installs #5010

Revamp CI with dependency and Python caching for efficient installs

Revamp CI with dependency and Python caching for efficient installs #5010

Workflow file for this run

name: CI
on:
# allows us to run workflows manually
workflow_dispatch:
pull_request:
branches:
- develop
- master
push:
branches:
- develop
- master
env:
MPI_DIR: /usr
HDF5_ROOT: /usr
OMP_NUM_THREADS: 2
COVERALLS_PARALLEL: true
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
jobs:
setup:
runs-on: ubuntu-22.04
outputs:
matrix: ${{ steps.read-json.outputs.matrix }}
steps:
- uses: actions/checkout@v4
- name: Send JSON matrix contents to job output
id: read-json
shell: bash
run: |
echo "matrix<<EOF" >> $GITHUB_OUTPUT
cat $GITHUB_WORKSPACE/tools/ci/matrix.json >> $GITHUB_OUTPUT
main:
runs-on: ubuntu-22.04
timeout-minutes: 180
needs: setup
strategy:
matrix: "${{ fromJSON( needs.setup.outputs.matrix ) }}"
name: "${{ matrix.job-name }}"
env:
MPI: ${{ matrix.mpi }}
PHDF5: ${{ matrix.mpi }}
OMP: ${{ matrix.omp }}
DAGMC: ${{ matrix.dagmc }}
NCRYSTAL: ${{ matrix.ncrystal }}
EVENT: ${{ matrix.event }}
VECTFIT: ${{ matrix.vectfit }}
LIBMESH: ${{ matrix.libmesh }}
NPY_DISABLE_CPU_FEATURES: "AVX512F AVX512_SKX"
OPENBLAS_NUM_THREADS: 1
# libfabric complains about fork() as a result of using Python multiprocessing.
# We can work around it with RDMAV_FORK_SAFE=1 in libfabric < 1.13 and with
# FI_EFA_FORK_SAFE=1 in more recent versions.
RDMAV_FORK_SAFE: 1
steps:
- uses: actions/checkout@v4
- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v5
with:
python-version: ${{ matrix.python-version }}
- name: Environment Variables
run: |
echo "OPENMC_CROSS_SECTIONS=$HOME/nndc_hdf5/cross_sections.xml" >> $GITHUB_ENV
echo "OPENMC_ENDF_DATA=$HOME/endf-b-vii.1" >> $GITHUB_ENV
- name: Apt dependencies
shell: bash
run: |
sudo apt -y update
sudo apt install -y libpng-dev \
libnetcdf-dev \
libpnetcdf-dev \
libhdf5-serial-dev \
libeigen3-dev
- name: Optional apt dependencies for MPI
shell: bash
if: ${{ matrix.mpi == 'y' }}
run: |
sudo apt install -y libhdf5-mpich-dev \
libmpich-dev
sudo update-alternatives --set mpi /usr/bin/mpicc.mpich
sudo update-alternatives --set mpirun /usr/bin/mpirun.mpich
sudo update-alternatives --set mpi-x86_64-linux-gnu /usr/include/x86_64-linux-gnu/mpich
- name: Optional apt dependencies for vectfit
shell: bash
if: ${{ matrix.vectfit == 'y' }}
run: sudo apt install -y libblas-dev liblapack-dev
- name: Hash dependencies to check caches
run: |
$GITHUB_WORKSPACE/tools/ci/gha-caches.sh
- name: Restore NJOY2016
uses: actions/cache@v4
with:
path: |
~/NJOY2016/metaconfigure
~/NJOY2016/src
~/NJOY2016/build/njoy
~/NJOY2016/build/libnjoy.so
key: NJOY2016-${{ env.NJOY_HASH }}
- name: Restore DAGMC
if: ${{ matrix.dagmc == 'y' }}
uses: actions/cache@v4
with:
path: |
~/DAGMC
~/MOAB
key: DAGMC-${{ env.DAGMC_HASH }}/MOAB-${{ env.MOAB_HASH }}
- name: Restore NCrystal
if: ${{ matrix.ncrystal == 'y' }}
uses: actions/cache@v4
with:
path: |
~/ncrystal_src
~/ncrystal_bld
~/ncrystal_inst
key: NCrystal-${{ env.NC_HASH }}
- name: Restore vectfit
if: ${{ matrix.vectfit == 'y' }}
uses: actions/cache@v4
with:
path: |
~/pybind11
~/xtl
~/xtensor-python
~/xtensor-blas
~/vectfit
key: vectfit-${{ env.VF_HASH }}/pybind-${{ env.PYBIND_HASH }}
- name: Restore libmesh
if: ${{ matrix.libmesh == 'y' }}
uses: actions/cache@v4
with:
path: |
~/LIBMESH
key: libmesh-mpi-${{matrix.mpi}}-${{ env.NC_HASH }}
- name: install
shell: bash
run: |
$GITHUB_WORKSPACE/tools/ci/gha-install.sh
- name: display-config
shell: bash
run: |
openmc -v
- name: Restore endf-b-vii.1 cache
uses: actions/cache@v4
with:
path: |
~/nndc_hdf5
~/endf-b-vii.1
key: endf-b-vii.1-cache
- name: before
shell: bash
run: $GITHUB_WORKSPACE/tools/ci/gha-before-script.sh
- name: test
shell: bash
run: |
CTEST_OUTPUT_ON_FAILURE=1 make test -C $GITHUB_WORKSPACE/build/
$GITHUB_WORKSPACE/tools/ci/gha-script.sh
- name: after_success
shell: bash
run: |
cpp-coveralls -i src -i include -e src/external --exclude-pattern "/usr/*" --dump cpp_cov.json
coveralls --merge=cpp_cov.json --service=github
finish:
needs: main
runs-on: ubuntu-latest
steps:
- name: Coveralls Finished
uses: coverallsapp/github-action@v2
with:
github-token: ${{ secrets.github_token }}
parallel-finished: true