GitHub CI Testing
There are two categories of CI testing that we run on GitHub via GitHub actions:
Comprehensive (excluding GPUs)
Minimal/Short
The comprehensive testing is run only on one platform (Ubuntu) and utilizes Docker + Spack + the latest E4S release to build SUNDIALS in many different configurations with and without third-party libraries enabled.
The minimal/short testing runs on more platforms: Windows (MinGW and MSVC), and MacOS but it runs in only one configuration (using 64-bit indices and double precision) and without third-party libraries.
Building the Docker containers for CI
Original Setup
These are the steps that were originally performed by Cody Balos to build the Docker container(s) used for the comprehensive CI testing.
Create a
spack.yaml
for each configuration of SUNDIALS. E.g., int64 and double:
# This is a Spack Environment file.
#
# It describes a set of packages to be installed, along with
# configuration settings.
spack:
packages:
all:
providers:
blas: [openblas]
mpi: [openmpi]
# add package specs to the ``specs`` list
specs:
- hypre+int64~internal-superlu
- petsc+double+int64
- openmpi
- openblas+ilp64
- suite-sparse
- superlu-dist+int64 ^parmetis+int64
- trilinos+tpetra gotype=long_long
config: {}
modules:
enable: []
repos: []
upstreams: {}
container:
images:
os: ubuntu:20.04
Run
spack containerize > Dockerfile
in the directory of thespack.yaml
The Dockerfile produced in step 2 was then manually modified to leverage Spack’s buildcache feature and Docker’s ‘cache’ bind-mount. The gist is that if the Spack build fails while building the Docker image, the buildcache makes it possible to reuse the binaries for the packages that were already installed before the build failed. Without the buildcache, the spack build failing would result in all packages needing to be built again when re-attempting to build the Docker image.
Run
DOCKER_BUILDKIT docker build -t sundials-ci/<index-size>-<precision>:<tag>
Push
Automated building of new containers
We currently have six different containers, one for each combination of {int32, int64} and {single, double, extended} precision. These containers are pinned to an E4S release. When E4S does a release, we can rebuild these containers to use the packages from it. We add E4S as a mirror in the Spack environment so that its buildcache can be leveraged.
We also maintain two containers for the {int32, double} pair that are built automatically (in a GitHub action) every week against the latest Spack develop commit. This allows us to test against the latest versions of dependencies regularly and detect interface breakages.
Running Locally
It is possible to use the SUNDIALS CI containers available on GitHub for testing locally. This will allow you to get as close as possible to running tests in the CI environment on your own machine.
If you have Docker or Podman installed on your machine already,
than the easiest way to use the containers is via the CMake targets setup_local_ci
and test_local_ci
, for example:
$ cd builddir
$ make setup_local_ci
...
$ make test_local_ci
...
The setup_local_ci
target will pull the container for the configured SUNDIALS_PRECISION
and SUNDIALS_INDEX_SIZE
. Then the test_local_ci
target will run the full test suite
in the container.
The following CMake options are available for setting up local testing with the containers.
- SUNDIALS_TEST_CONTAINER_EXE
Path to docker or podman
Default: CMake will attempt to locate docker or podman automatically
- SUNDIALS_TEST_CONTAINER_RUN_EXTRA_ARGS
Extra arguments to pass to docker/podman run command
Default:
--tls-verify=false
- SUNDIALS_TEST_CONTAINER_MNT
Path to project root inside the container
Default:
/sundials
Alternatively, if you want to work with Docker directly, you can pull the image(s) and then
run the test suite manually. The run
command will pull the image and start the container:
docker run -t -d --name sundialsci-int32-double-latest --cap-add SYS_PTRACE -v "/path/to/your/sundials/development/repo":/sundials ghcr.io/llnl/sundials-ci-int32-double:latest
The exec
command can then be used to execute the test script:
docker exec -w /sundials/test sundialsci-int32-double-latest ./test_driver.sh --testtype CUSTOM --env env/docker.sh --tpls --sunrealtype double --indexsize 32
Alternatively, you can drop into a bash shell inside the container to run specific examples:
docker exec -it sundialsci-int32-double-latest bash
On Macs, it is recommended to use Podman (and then the
same steps above apply using podman
instead of docker
). Podman is
useful on Linux too, as it can run rootless easily.
Note
Its possible that the difference in your local machine architecture, and the
one used to build the docker container(s), results in different answers and
failing tests. You can provide the path to your own directory with answer
files by setting the environment variable SUNDIALS_TEST_ANSWER_DIR
with
the path, and adding the argument -e SUNDIALS_TEST_ANSWER_DIR
to the
docker run
command above.