xref: /libCEED/.gitlab-ci.yml (revision 7bfe0f0e497883534890a072c2a8b865352898b0)
1stages:
2  - test
3
4noether-rocm:
5  stage: test
6  tags:
7    - rocm
8  interruptible: true
9  script:
10    - rm -f .SUCCESS
11# Environment
12    - export COVERAGE=1 CC=gcc CXX=g++ FC=gfortran HIPCC=hipcc
13    - echo "-------------- nproc ---------------" && NPROC_CPU=$(nproc) && NPROC_GPU=$(($(nproc)<8?$(nproc):8)) && echo "NPROC_CPU" $NPROC_CPU && echo "NPROC_GPU" $NPROC_GPU
14    - echo "-------------- CC ------------------" && $CC --version
15    - echo "-------------- CXX -----------------" && $CXX --version
16    - echo "-------------- FC ------------------" && $FC --version
17    - echo "-------------- HIPCC ---------------" && $HIPCC --version
18    - echo "-------------- GCOV ----------------" && gcov --version
19# Libraries for backends
20# -- MAGMA from dev branch
21    - echo "-------------- MAGMA ---------------"
22    - export MAGMA_DIR=/projects/hipMAGMA && git -C $MAGMA_DIR describe
23# -- LIBXSMM v1.17
24    - cd .. && export XSMM_VERSION=libxsmm-1.17 && { [[ -d $XSMM_VERSION ]] || { git clone --depth 1 --branch 1.17 https://github.com/hfp/libxsmm.git $XSMM_VERSION && make -C $XSMM_VERSION -j$(nproc); }; } && export XSMM_DIR=$PWD/$XSMM_VERSION && cd libCEED
25    - echo "-------------- LIBXSMM -------------" && git -C $XSMM_DIR describe --tags
26# -- OCCA v1.1.0
27    - cd .. && export OCCA_VERSION=occa-1.1.0 OCCA_OPENCL_ENABLED=0 && { [[ -d $OCCA_VERSION ]] || { git clone --depth 1 --branch v1.1.0 https://github.com/libocca/occa.git $OCCA_VERSION && make -C $OCCA_VERSION -j$(nproc); }; } && export OCCA_DIR=$PWD/$OCCA_VERSION && cd libCEED
28    - echo "-------------- OCCA ----------------" && make -C $OCCA_DIR info
29# libCEED
30    - make configure HIP_DIR=/opt/rocm OPT='-O -march=native -ffp-contract=fast'
31#    Note: OCCA backends currently disabled in CI
32    - BACKENDS_CPU=$(OCCA_DIR= make info-backends-all | grep -o '/cpu[^ ]*') && BACKENDS_GPU=$(OCCA_DIR= make info-backends | grep -o '/gpu[^ ]*')
33    - echo "-------------- libCEED -------------" && make info
34    - echo "-------------- BACKENDS_CPU --------" && echo $BACKENDS_CPU
35    - echo "-------------- BACKENDS_GPU --------" && echo $BACKENDS_GPU
36    - make -j$NPROC_CPU
37# Remove OCCA after verifying it compiles
38# CodeCov of OCCA backend not useful since testing is intentionally disabled
39    - export OCCA_DIR= && make -j$NPROC_CPU -W build/interface/ceed-register.o
40# -- libCEED only tests
41    - echo "-------------- core tests ----------"
42    - echo '[{"subject":"/","metrics":[{"name":"Transfer Size (KB)","value":"19.5","desiredSize":"smaller"},{"name":"Speed Index","value":0,"desiredSize":"smaller"},{"name":"Total Score","value":92,"desiredSize":"larger"},{"name":"Requests","value":4,"desiredSize":"smaller"}]}]' > performance.json
43#    Note: PETSC_DIR is set by default in GitLab runner env, unsetting to isolate core tests
44    - export PETSC_DIR= PETSC_ARCH=
45    - make -k -j$NPROC_CPU BACKENDS="$BACKENDS_CPU" JUNIT_BATCH="cpu" junit realsearch=%
46    - make -k -j$NPROC_GPU BACKENDS="$BACKENDS_GPU" JUNIT_BATCH="hip" junit realsearch=%
47# Libraries for examples
48# -- PETSc with HIP (minimal)
49    - export PETSC_DIR=/projects/petsc PETSC_ARCH=mpich-hip && git -C $PETSC_DIR describe
50    - echo "-------------- PETSc ---------------" && make -C $PETSC_DIR info
51    - make -k -j$NPROC_CPU BACKENDS="$BACKENDS_CPU" JUNIT_BATCH="cpu" junit search="petsc fluids solids"
52    - make -k -j$NPROC_GPU BACKENDS="$BACKENDS_GPU" JUNIT_BATCH="hip" junit search="petsc fluids solids"
53# -- MFEM v4.2
54    - cd .. && export MFEM_VERSION=mfem-4.2 && { [[ -d $MFEM_VERSION ]] || { git clone --depth 1 --branch v4.2 https://github.com/mfem/mfem.git $MFEM_VERSION && make -C $MFEM_VERSION -j$(nproc) serial CXXFLAGS="-O -std=c++11"; }; } && export MFEM_DIR=$PWD/$MFEM_VERSION && cd libCEED
55    - echo "-------------- MFEM ----------------" && make -C $MFEM_DIR info
56    - make -k -j$NPROC_CPU BACKENDS="$BACKENDS_CPU" JUNIT_BATCH="cpu" junit search=mfem
57    - make -k -j$NPROC_GPU BACKENDS="$BACKENDS_GPU" JUNIT_BATCH="hip" junit search=mfem
58# -- Nek5000 v19.0
59    - export COVERAGE=0
60    - cd .. && export NEK5K_VERSION=Nek5000-19.0 && { [[ -d $NEK5K_VERSION ]] || { git clone --depth 1 --branch v19.0 https://github.com/Nek5000/Nek5000.git $NEK5K_VERSION && cd $NEK5K_VERSION/tools && ./maketools genbox genmap reatore2 && cd ../..; }; } && export NEK5K_DIR=$PWD/$NEK5K_VERSION && export PATH=$NEK5K_DIR/bin:$PATH MPI=0 && cd libCEED
61    - echo "-------------- Nek5000 -------------" && git -C $NEK5K_DIR describe --tags
62    - make -k -j$NPROC_CPU BACKENDS="$BACKENDS_CPU" JUNIT_BATCH="cpu" junit search=nek
63    - make -k -j$NPROC_GPU BACKENDS="$BACKENDS_GPU" JUNIT_BATCH="hip" junit search=nek
64# Clang-tidy
65    - echo "-------------- clang-tidy ----------" && clang-tidy --version
66    - TIDY_OPTS="-fix-errors" make -j$NPROC_CPU tidy && git diff --exit-code
67# Report status
68    - touch .SUCCESS
69  after_script:
70    - |
71      if [ -f .SUCCESS ]; then
72        lcov --directory . --capture --output-file coverage.info;
73        bash <(curl -s https://codecov.io/bash) -f coverage.info -t ${CODECOV_ACCESS_TOKEN} -F interface;
74        bash <(curl -s https://codecov.io/bash) -f coverage.info -t ${CODECOV_ACCESS_TOKEN} -F gallery;
75        bash <(curl -s https://codecov.io/bash) -f coverage.info -t ${CODECOV_ACCESS_TOKEN} -F backends;
76        bash <(curl -s https://codecov.io/bash) -f coverage.info -t ${CODECOV_ACCESS_TOKEN} -F tests;
77        bash <(curl -s https://codecov.io/bash) -f coverage.info -t ${CODECOV_ACCESS_TOKEN} -F examples;
78      fi
79  artifacts:
80    paths:
81      - build/*.junit
82    reports:
83      junit: build/*.junit
84      performance: performance.json
85
86noether-float:
87  stage: test
88  tags:
89    - rocm
90  interruptible: true
91  script:
92# Environment
93    - export COVERAGE=1 CC=gcc CXX=g++ FC= HIPCC=hipcc
94    - echo "-------------- nproc ---------------" && NPROC_CPU=$(nproc) && NPROC_GPU=$(($(nproc)<8?$(nproc):8)) && echo "NPROC_CPU" $NPROC_CPU && echo "NPROC_GPU" $NPROC_GPU
95    - echo "-------------- CC ------------------" && $CC --version
96    - echo "-------------- CXX -----------------" && $CXX --version
97    - echo "-------------- HIPCC ---------------" && $HIPCC --version
98    - echo "-------------- GCOV ----------------" && gcov --version
99# Libraries for backends
100# -- MAGMA from dev branch
101    - echo "-------------- MAGMA ---------------"
102    - export MAGMA_DIR=/projects/hipMAGMA && git -C $MAGMA_DIR describe
103# -- LIBXSMM v1.17
104    - cd .. && export XSMM_VERSION=libxsmm-1.17 && { [[ -d $XSMM_VERSION ]] || { git clone --depth 1 --branch 1.17 https://github.com/hfp/libxsmm.git $XSMM_VERSION && make -C $XSMM_VERSION -j$(nproc); }; } && export XSMM_DIR=$PWD/$XSMM_VERSION && cd libCEED
105    - echo "-------------- LIBXSMM -------------" && git -C $XSMM_DIR describe --tags
106# libCEED
107# First change to single precision
108    - sed -i 's/ceed-f64/ceed-f32/1' include/ceed/ceed.h
109# Build libCEED
110    - make configure HIP_DIR=/opt/rocm OPT='-O -march=native -ffp-contract=fast'
111    - BACKENDS_CPU=$(make info-backends-all | grep -o '/cpu[^ ]*') && BACKENDS_GPU=$(make info-backends | grep -o '/gpu[^ ]*')
112    - echo "-------------- libCEED -------------" && make info
113    - echo "-------------- BACKENDS_CPU --------" && echo $BACKENDS_CPU
114    - echo "-------------- BACKENDS_GPU --------" && echo $BACKENDS_GPU
115    - make -j$NPROC_CPU
116# -- libCEED only tests
117    - echo "-------------- core tests ----------"
118    - echo '[{"subject":"/","metrics":[{"name":"Transfer Size (KB)","value":"19.5","desiredSize":"smaller"},{"name":"Speed Index","value":0,"desiredSize":"smaller"},{"name":"Total Score","value":92,"desiredSize":"larger"},{"name":"Requests","value":4,"desiredSize":"smaller"}]}]' > performance.json
119#    Note: PETSC_DIR is set by default in GitLab runner env, unsetting to isolate core tests
120    - export PETSC_DIR= PETSC_ARCH=
121    - make -k -j$NPROC_CPU BACKENDS="$BACKENDS_CPU" JUNIT_BATCH="float-cpu" junit realsearch=%
122    - make -k -j$NPROC_GPU BACKENDS="$BACKENDS_GPU" JUNIT_BATCH="float-hip" junit realsearch=%
123# Report status
124    - echo "SUCCESS" > .job_status
125  after_script:
126    - |
127      if [ $(cat .job_status) == "SUCCESS" ]; then
128        lcov --directory . --capture --output-file coverage.info;
129        bash <(curl -s https://codecov.io/bash) -f coverage.info -t ${CODECOV_ACCESS_TOKEN} -F interface;
130        bash <(curl -s https://codecov.io/bash) -f coverage.info -t ${CODECOV_ACCESS_TOKEN} -F gallery;
131        bash <(curl -s https://codecov.io/bash) -f coverage.info -t ${CODECOV_ACCESS_TOKEN} -F backends;
132        bash <(curl -s https://codecov.io/bash) -f coverage.info -t ${CODECOV_ACCESS_TOKEN} -F tests;
133        bash <(curl -s https://codecov.io/bash) -f coverage.info -t ${CODECOV_ACCESS_TOKEN} -F examples;
134      fi
135    - sed -i 's/ceed-f32/ceed-f64/1' include/ceed/ceed.h
136  artifacts:
137    paths:
138      - build/*.junit
139    reports:
140      junit: build/*.junit
141      performance: performance.json
142
143lv-cuda:
144  stage: test
145  tags:
146    - cuda
147  interruptible: true
148  before_script:
149# Environment
150    - ulimit -v $[1024*1024*32] # 32 GiB in units of 1024 bytes
151    - . /opt/rh/gcc-toolset-10/enable
152    - export COVERAGE=1 CC=gcc CXX=g++ FC=gfortran
153    - export CUDA_DIR=/usr/local/cuda-11.4
154    - export CUDA_VISIBLE_DEVICES=GPU-c4529365-8229-f689-b43d-ccd7f1677079 # our RTX 2080 Super via nvidia-smi -L
155    - echo "-------------- nproc ---------------" && NPROC_CPU=$(nproc) && NPROC_GPU=1 && echo "NPROC_CPU" $NPROC_CPU && echo "NPROC_GPU" $NPROC_GPU
156    - echo "-------------- CC ------------------" && $CC --version
157    - echo "-------------- CXX -----------------" && $CXX --version
158    - echo "-------------- FC ------------------" && $FC --version
159    - echo "-------------- NVCC ----------------" && $CUDA_DIR/bin/nvcc --version
160# libCEED
161    - make configure OPT='-O -march=native -ffp-contract=fast'
162    - echo "-------------- libCEED -------------" && make info
163    - BACKENDS_GPU=$(make info-backends | grep -o '/gpu[^ ]*')
164    - echo "-------------- BACKENDS_GPU --------" && echo $BACKENDS_GPU
165    - export PETSC_DIR=/home/jeth8984/petsc PETSC_ARCH=cuda-O && git -C $PETSC_DIR describe
166  script:
167    - rm -f .SUCCESS
168    - nice make -k -j$NPROC_CPU -l$NPROC_CPU
169    - echo "-------------- quick CPU tests to get everything built (no junit) --------------"
170    - nice make -k -j$NPROC_CPU -l$NPROC_CPU test BACKENDS=/cpu/self/avx/blocked realsearch=%
171    - echo "-------------- CUDA tests without PETSc (makes *.junit) --------------"
172    - nice make -k -j$NPROC_GPU JUNIT_BATCH="cuda" junit PETSC_DIR= BACKENDS="$BACKENDS_GPU" realsearch=%
173    - echo "-------------- CUDA tests with PETSc (makes *.junit) --------------"
174# skip fluids and solids due to CUDA_ERROR_LAUNCH_OUT_OF_RESOURCES on RTX 2080 Super
175    - nice make -k -j$NPROC_GPU JUNIT_BATCH="cuda" junit BACKENDS="$BACKENDS_GPU" search="petsc"
176# Report status
177    - touch .SUCCESS
178  after_script:
179    - |
180      if [ -f .SUCCESS ]; then
181        lcov --directory . --capture --output-file coverage.info;
182        bash <(curl -s https://codecov.io/bash) -f coverage.info -t ${CODECOV_ACCESS_TOKEN} -F interface;
183        bash <(curl -s https://codecov.io/bash) -f coverage.info -t ${CODECOV_ACCESS_TOKEN} -F gallery;
184        bash <(curl -s https://codecov.io/bash) -f coverage.info -t ${CODECOV_ACCESS_TOKEN} -F backends;
185        bash <(curl -s https://codecov.io/bash) -f coverage.info -t ${CODECOV_ACCESS_TOKEN} -F tests;
186        bash <(curl -s https://codecov.io/bash) -f coverage.info -t ${CODECOV_ACCESS_TOKEN} -F examples;
187      fi
188  artifacts:
189    paths:
190      - build/*.junit
191    reports:
192      junit: build/*.junit
193