From febfb34260c356b026b0eeb744cd90750db4bb3e Mon Sep 17 00:00:00 2001 From: Alex Richert Date: Wed, 22 May 2024 13:56:30 -0700 Subject: [PATCH 01/14] update developer.yml --- .github/workflows/developer.yml | 25 +++++++++---------------- 1 file changed, 9 insertions(+), 16 deletions(-) diff --git a/.github/workflows/developer.yml b/.github/workflows/developer.yml index cd802787..a70c982d 100644 --- a/.github/workflows/developer.yml +++ b/.github/workflows/developer.yml @@ -29,37 +29,30 @@ jobs: python3 -m pip install gcovr - name: checkout - uses: actions/checkout@v2 + uses: actions/checkout@v4 with: path: ip - name: build run: | - cd ip - mkdir build - cd build - cmake -DENABLE_DOCS=YES -DOPENMP=ON -DCMAKE_Fortran_FLAGS="-g -fprofile-abs-path -fprofile-arcs -ftest-coverage -O0 -fsanitize=address" -DCMAKE_C_FLAGS="-g -fprofile-abs-path -fprofile-arcs -ftest-coverage -O0 -fsanitize=address" -DCMAKE_BUILD_TYPE=Debug -DBUILD_SHARED_LIBS=ON -DBUILD_8=ON .. - make -j2 VERBOSE=1 + cmake -S ip -B ip/build -DENABLE_DOCS=YES -DOPENMP=ON -DCMAKE_Fortran_FLAGS="-g -fprofile-abs-path -fprofile-arcs -ftest-coverage -O0 -fsanitize=address" -DCMAKE_C_FLAGS="-g -fprofile-abs-path -fprofile-arcs -ftest-coverage -O0 -fsanitize=address" -DCMAKE_BUILD_TYPE=Debug -DBUILD_SHARED_LIBS=ON -DBUILD_8=ON + cmake --build ip/build --parallel 2 --verbose - name: test - run: | - cd $GITHUB_WORKSPACE/ip/build - ctest -j2 --verbose --output-on-failure --rerun-failed + run: ctest --test-dir -j2 --verbose --output-on-failure --rerun-failed - name: run-gcovr - run: | - cd $GITHUB_WORKSPACE/ip/build - gcovr -r .. -v --html-details --exclude ../tests --exclude CMakeFiles --print-summary -o test-coverage.html + run: gcovr -r ip -v --html-details --exclude ip/tests --exclude ip/build/CMakeFiles --print-summary -o test-coverage.html - name: upload-test-coverage - uses: actions/upload-artifact@v2 + uses: actions/upload-artifact@v4 with: name: ip-test-coverage path: | - ip/build/*.html - ip/build/*.css + *.html + *.css - - uses: actions/upload-artifact@v2 + - uses: actions/upload-artifact@v4 with: name: docs path: | From 75c7ffeac45f19cfef0689806373d0bcc7d9c3a5 Mon Sep 17 00:00:00 2001 From: Alex Richert Date: Wed, 22 May 2024 13:58:36 -0700 Subject: [PATCH 02/14] update Intel.yml --- .github/workflows/Intel.yml | 35 +++++++++-------------------------- 1 file changed, 9 insertions(+), 26 deletions(-) diff --git a/.github/workflows/Intel.yml b/.github/workflows/Intel.yml index 2c08edeb..78b962f3 100644 --- a/.github/workflows/Intel.yml +++ b/.github/workflows/Intel.yml @@ -12,49 +12,32 @@ on: branches: - develop -# Use custom shell with -l so .bash_profile is sourced which loads intel/oneapi/setvars.sh -# without having to do it in manually every step -defaults: - run: - shell: bash -leo pipefail {0} - jobs: Intel: runs-on: ubuntu-latest strategy: matrix: openmp: [ ON, OFF ] - compilers: ["CC=icc FC=ifort", "CC=icx FC=ifx"] + compilers: ["oneapi", "classic"] steps: - # See https://software.intel.com/content/www/us/en/develop/articles/oneapi-repo-instructions.html - - name: install-intel - run: | - cd /tmp - wget https://apt.repos.intel.com/intel-gpg-keys/GPG-PUB-KEY-INTEL-SW-PRODUCTS.PUB - sudo apt-key add GPG-PUB-KEY-INTEL-SW-PRODUCTS.PUB - rm GPG-PUB-KEY-INTEL-SW-PRODUCTS.PUB - echo "deb https://apt.repos.intel.com/oneapi all main" | sudo tee /etc/apt/sources.list.d/oneAPI.list - sudo apt-get update - sudo apt-get install intel-oneapi-openmp intel-oneapi-compiler-fortran-2023.2.1 intel-oneapi-compiler-dpcpp-cpp-and-cpp-classic-2023.2.1 intel-oneapi-mkl-devel-2023.2.0 - echo "source /opt/intel/oneapi/setvars.sh" >> ~/.bash_profile + - name: "Install Intel" + uses: NOAA-EMC/ci-install-intel-toolkit@develop + with: + compiler-setup: ${{ matrix.compilers }} - name: checkout - uses: actions/checkout@v2 + uses: actions/checkout@v4 with: path: ip - name: build run: | - cd ip - mkdir build - cd build - ${{ matrix.compilers }} cmake -DOPENMP=${{ matrix.openmp }} -DBUILD_SHARED_LIBS=OFF -DBUILD_8=ON .. - make -j2 VERBOSE=1 + cmake -S ip -B ip/build -DOPENMP=${{ matrix.openmp }} -DBUILD_SHARED_LIBS=OFF -DBUILD_8=ON + cmake --build ip/build --parallel 2 --verbose - name: test run: | ulimit -s unlimited - cd $GITHUB_WORKSPACE/ip/build - ctest --verbose --output-on-failure --rerun-failed + ctest --test-dir ip/build --verbose --output-on-failure --rerun-failed From 095d7e6dd9c4c50ef5f0c3ae7085d323bbac6040 Mon Sep 17 00:00:00 2001 From: Alex Richert Date: Wed, 22 May 2024 14:00:16 -0700 Subject: [PATCH 03/14] update Linux.yml --- .github/workflows/Linux.yml | 15 +++++---------- 1 file changed, 5 insertions(+), 10 deletions(-) diff --git a/.github/workflows/Linux.yml b/.github/workflows/Linux.yml index 95baece0..5fd24f9c 100644 --- a/.github/workflows/Linux.yml +++ b/.github/workflows/Linux.yml @@ -27,19 +27,16 @@ jobs: steps: - name: checkout - uses: actions/checkout@v2 + uses: actions/checkout@v4 with: path: ip - name: build run: | sudo apt install libopenblas-serial-dev - cd ip - mkdir build - cd build - cmake -DCMAKE_PREFIX_PATH="~/" -DOPENMP=${{ matrix.openmp }} ${{ matrix.options }} -DCMAKE_INSTALL_PREFIX=~/install -DBLA_VENDOR=OpenBLAS .. - make -j2 VERBOSE=1 - make install + cmake -S ip -B ip/build -DCMAKE_PREFIX_PATH="~/" -DOPENMP=${{ matrix.openmp }} ${{ matrix.options }} -DCMAKE_INSTALL_PREFIX=~/install -DBLA_VENDOR=OpenBLAS + cmake --build ip/build --parallel 2 --verbose + cmake --install # Ensure that manual setting of '-DBLA_VENDOR=...' is reflected in output CMake config if [ $(grep -c "BLA_VENDOR OpenBLAS" ~/install/lib/cmake/ip/ip-config.cmake) -eq 0 ]; then echo "OpenBLAS not set as BLA_VENDOR in ip-config.cmake!" @@ -47,6 +44,4 @@ jobs: fi - name: test - run: | - cd $GITHUB_WORKSPACE/ip/build - ctest --verbose --output-on-failure --rerun-failed + run: ctest --test-dir ip/build --verbose --output-on-failure --rerun-failed From 928b005b93b35e9d5717d4517fb37234f4db6ad7 Mon Sep 17 00:00:00 2001 From: Alex Richert Date: Wed, 22 May 2024 14:01:35 -0700 Subject: [PATCH 04/14] fix Linux.yml --- .github/workflows/Linux.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/Linux.yml b/.github/workflows/Linux.yml index 5fd24f9c..e1ec6781 100644 --- a/.github/workflows/Linux.yml +++ b/.github/workflows/Linux.yml @@ -36,7 +36,7 @@ jobs: sudo apt install libopenblas-serial-dev cmake -S ip -B ip/build -DCMAKE_PREFIX_PATH="~/" -DOPENMP=${{ matrix.openmp }} ${{ matrix.options }} -DCMAKE_INSTALL_PREFIX=~/install -DBLA_VENDOR=OpenBLAS cmake --build ip/build --parallel 2 --verbose - cmake --install + cmake --install ip/build # Ensure that manual setting of '-DBLA_VENDOR=...' is reflected in output CMake config if [ $(grep -c "BLA_VENDOR OpenBLAS" ~/install/lib/cmake/ip/ip-config.cmake) -eq 0 ]; then echo "OpenBLAS not set as BLA_VENDOR in ip-config.cmake!" From 4822185aac4cff2e3961ef63bc50fa98ecd3cfc8 Mon Sep 17 00:00:00 2001 From: Alex Richert Date: Wed, 22 May 2024 14:01:47 -0700 Subject: [PATCH 05/14] update MacOS.yml --- .github/workflows/MacOS.yml | 15 +++++---------- 1 file changed, 5 insertions(+), 10 deletions(-) diff --git a/.github/workflows/MacOS.yml b/.github/workflows/MacOS.yml index 9a6efc9c..ab042304 100644 --- a/.github/workflows/MacOS.yml +++ b/.github/workflows/MacOS.yml @@ -26,22 +26,17 @@ jobs: steps: - name: checkout - uses: actions/checkout@v2 + uses: actions/checkout@v4 with: path: ip - name: build run: | - cd ip - mkdir build - cd build - cmake -DOPENMP=${{ matrix.openmp }} -DBUILD_SHARED_LIBS=${{ matrix.sharedlibs }} -DCMAKE_INSTALL_PREFIX=~/install -DBUILD_8=ON .. - make -j2 VERBOSE=2 - make install + cmake -S ip -B ip/build -DOPENMP=${{ matrix.openmp }} -DBUILD_SHARED_LIBS=${{ matrix.sharedlibs }} -DCMAKE_INSTALL_PREFIX=~/install -DBUILD_8=ON + cmake --build ip/build --parallel 2 --verbose + cmake --install ip/build ls -l ~/install ls -l ~/install/lib - name: test - run: | - cd $GITHUB_WORKSPACE/ip/build - ctest --verbose --output-on-failure --rerun-failed + run: ctest --test-dir ip/build --verbose --output-on-failure --rerun-failed From 342461c709b32396ac42943f44a3f6ac7f3837a1 Mon Sep 17 00:00:00 2001 From: Alex Richert Date: Wed, 22 May 2024 14:18:05 -0700 Subject: [PATCH 06/14] update Spack.yml --- .github/workflows/Spack.yml | 53 ++++++++++--------------------------- 1 file changed, 14 insertions(+), 39 deletions(-) diff --git a/.github/workflows/Spack.yml b/.github/workflows/Spack.yml index 7b9577d8..86eae19a 100644 --- a/.github/workflows/Spack.yml +++ b/.github/workflows/Spack.yml @@ -25,51 +25,26 @@ jobs: runs-on: ${{ matrix.os }} steps: - - - name: checkout-ip - uses: actions/checkout@v4 - with: - path: ip - - name: spack-build-and-test - run: | - sudo apt install libopenblas-serial-dev - git clone -c feature.manyFiles=true https://github.com/spack/spack - . spack/share/spack/setup-env.sh - spack env create ip-env - spack env activate ip-env - cp $GITHUB_WORKSPACE/ip/spack/package.py $SPACK_ROOT/var/spack/repos/builtin/packages/ip/package.py - spack develop --no-clone --path $GITHUB_WORKSPACE/ip ip@develop - spack add ip@develop%gcc@11 ${{ matrix.variants }} target=x86_64 - precision=$(echo ${{ matrix.variants }} | grep -oP " precision=\K[4d8]") - if [ "$precision" == "d" ]; then spack add grib-util@develop ; fi - spack external find cmake gmake - spack external find --path /usr/lib/x86_64-linux-gnu/openblas-serial openblas - spack config add "packages:lapack:buildable:false" - spack concretize - # Run installation and run CTest suite - spack install --fail-fast --test root - # Run 'spack load' and check that key build options were respected - spack load ip - if [[ "${{ matrix.variants }}" =~ "+shared" ]]; then suffix="so" ; else suffix="a"; fi - libvar=IP_LIB${precision} - ls ${!libvar} | grep -cE "/libip_${precision}\."$suffix'$' + - name: "Build Spack package" + uses: NOAA-EMC/ci-test-spack-package@develop + with: + package-name: ip + package-variants: ${{ matrix.variants }} target=x86_64 ${{ matrix.variants == "+openmp +shared +pic precision=d" && 'grib-util@develop' || '' }} + custom-recipe: spack/package.py + spack-compiler: gcc + spack-externals: gmake cmake openblas + repo-cache-key-suffix: ${{ matrix.os }}-${{ matrix.variants }}-1 # This job validates the Spack recipe by making sure each cmake build option is represented recipe-check: runs-on: ubuntu-latest steps: - - - name: checkout-ip - uses: actions/checkout@v4 - with: - path: ip - name: recipe-check - run: | - echo "If this jobs fails, look at the most recently output CMake option below and make sure that option appears in spack/package.py" - for opt in $(grep -ioP '^option\(\K(?!(ENABLE_DOCS|TEST_TIME_LIMIT))[^ ]+' $GITHUB_WORKSPACE/ip/CMakeLists.txt) ; do - echo "Checking for presence of '$opt' CMake option in package.py" - grep -cP "define.+\b${opt}\b" $GITHUB_WORKSPACE/ip/spack/package.py - done + uses: NOAA-EMC/ci-check-spack-recipe@develop + with: + recipe-file: package/spack/package.py + cmakelists-txt: package/CMakeLists.txt + ignore-list: ENABLE_DOCS,TEST_TIME_LIMIT From 89422742a06b2d1e93a21cc7e5032c8bd5f2c837 Mon Sep 17 00:00:00 2001 From: Alex Richert Date: Wed, 22 May 2024 14:20:02 -0700 Subject: [PATCH 07/14] fix Spack.yml --- .github/workflows/Spack.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/Spack.yml b/.github/workflows/Spack.yml index 86eae19a..b9d7ff7c 100644 --- a/.github/workflows/Spack.yml +++ b/.github/workflows/Spack.yml @@ -30,7 +30,7 @@ jobs: uses: NOAA-EMC/ci-test-spack-package@develop with: package-name: ip - package-variants: ${{ matrix.variants }} target=x86_64 ${{ matrix.variants == "+openmp +shared +pic precision=d" && 'grib-util@develop' || '' }} + package-variants: ${{ matrix.variants }} target=x86_64 ${{ matrix.variants == '+openmp +shared +pic precision=d' && 'grib-util@develop' || '' }} custom-recipe: spack/package.py spack-compiler: gcc spack-externals: gmake cmake openblas From 13874bd3df08e395f227ad9344245b8e330e5eba Mon Sep 17 00:00:00 2001 From: Alex Richert Date: Wed, 22 May 2024 14:21:38 -0700 Subject: [PATCH 08/14] fix developer.yml --- .github/workflows/developer.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/developer.yml b/.github/workflows/developer.yml index a70c982d..852d4bf1 100644 --- a/.github/workflows/developer.yml +++ b/.github/workflows/developer.yml @@ -39,7 +39,7 @@ jobs: cmake --build ip/build --parallel 2 --verbose - name: test - run: ctest --test-dir -j2 --verbose --output-on-failure --rerun-failed + run: ctest --test-dir ip/build -j2 --verbose --output-on-failure --rerun-failed - name: run-gcovr run: gcovr -r ip -v --html-details --exclude ip/tests --exclude ip/build/CMakeFiles --print-summary -o test-coverage.html From 0a99ef389bd6af914c7ececb61a5129806b04dbe Mon Sep 17 00:00:00 2001 From: Alex Richert Date: Wed, 22 May 2024 14:24:14 -0700 Subject: [PATCH 09/14] fix Spack.yml --- .github/workflows/Spack.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/Spack.yml b/.github/workflows/Spack.yml index b9d7ff7c..7a36b0d8 100644 --- a/.github/workflows/Spack.yml +++ b/.github/workflows/Spack.yml @@ -30,7 +30,7 @@ jobs: uses: NOAA-EMC/ci-test-spack-package@develop with: package-name: ip - package-variants: ${{ matrix.variants }} target=x86_64 ${{ matrix.variants == '+openmp +shared +pic precision=d' && 'grib-util@develop' || '' }} + package-variants: ${{ matrix.variants }} ${{ matrix.variants == '+openmp +shared +pic precision=d' && 'grib-util@develop' || '' }} custom-recipe: spack/package.py spack-compiler: gcc spack-externals: gmake cmake openblas From 4b7e94e4db4a108fd8731168dc22466b1d1340bc Mon Sep 17 00:00:00 2001 From: Alex Richert Date: Wed, 22 May 2024 14:41:02 -0700 Subject: [PATCH 10/14] (re)install openblas in Spack.yml --- .github/workflows/Spack.yml | 3 +++ 1 file changed, 3 insertions(+) diff --git a/.github/workflows/Spack.yml b/.github/workflows/Spack.yml index 7a36b0d8..d0b8acc1 100644 --- a/.github/workflows/Spack.yml +++ b/.github/workflows/Spack.yml @@ -26,6 +26,9 @@ jobs: steps: + - name: "Install OpenBLAS" + run: sudo apt install libopenblas-serial-dev + - name: "Build Spack package" uses: NOAA-EMC/ci-test-spack-package@develop with: From 64a1caa616e5ac13ef8cd431583fb1fd75a710cb Mon Sep 17 00:00:00 2001 From: Alex Richert Date: Wed, 22 May 2024 14:45:51 -0700 Subject: [PATCH 11/14] update MacOS.yml --- .github/workflows/MacOS.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/MacOS.yml b/.github/workflows/MacOS.yml index ab042304..eeb23c9f 100644 --- a/.github/workflows/MacOS.yml +++ b/.github/workflows/MacOS.yml @@ -32,7 +32,7 @@ jobs: - name: build run: | - cmake -S ip -B ip/build -DOPENMP=${{ matrix.openmp }} -DBUILD_SHARED_LIBS=${{ matrix.sharedlibs }} -DCMAKE_INSTALL_PREFIX=~/install -DBUILD_8=ON + cmake -S ip -B ip/build -DOPENMP=${{ matrix.openmp }} -DBUILD_SHARED_LIBS=${{ matrix.sharedlibs }} -DCMAKE_INSTALL_PREFIX=~/install -DBUILD_8=ON -DCMAKE_BUILD_TYPE=Debug cmake --build ip/build --parallel 2 --verbose cmake --install ip/build ls -l ~/install From 78257e236b6bac38e15799f5fbead756d8b12e3d Mon Sep 17 00:00:00 2001 From: Alex Richert Date: Wed, 22 May 2024 14:56:59 -0700 Subject: [PATCH 12/14] fix Spack.yml (grib-util +tests) --- .github/workflows/Spack.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/Spack.yml b/.github/workflows/Spack.yml index d0b8acc1..3dea86a2 100644 --- a/.github/workflows/Spack.yml +++ b/.github/workflows/Spack.yml @@ -33,7 +33,7 @@ jobs: uses: NOAA-EMC/ci-test-spack-package@develop with: package-name: ip - package-variants: ${{ matrix.variants }} ${{ matrix.variants == '+openmp +shared +pic precision=d' && 'grib-util@develop' || '' }} + package-variants: ${{ matrix.variants }} ${{ matrix.variants == '+openmp +shared +pic precision=d' && 'grib-util@develop +tests' || '' }} custom-recipe: spack/package.py spack-compiler: gcc spack-externals: gmake cmake openblas From 6af4ac9f7d0544f77b1a4a53b49bb1f3be237a7c Mon Sep 17 00:00:00 2001 From: Alex Richert Date: Wed, 22 May 2024 15:09:04 -0700 Subject: [PATCH 13/14] fix Spack.yml --- .github/workflows/Spack.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/Spack.yml b/.github/workflows/Spack.yml index 3dea86a2..d9c2ceae 100644 --- a/.github/workflows/Spack.yml +++ b/.github/workflows/Spack.yml @@ -33,7 +33,7 @@ jobs: uses: NOAA-EMC/ci-test-spack-package@develop with: package-name: ip - package-variants: ${{ matrix.variants }} ${{ matrix.variants == '+openmp +shared +pic precision=d' && 'grib-util@develop +tests' || '' }} + package-variants: ${{ matrix.variants }} ${{ matrix.variants == '+openmp +shared +pic precision=d' && 'grib-util@develop +tests ^g2c@develop +utils +build_v2_api' || '' }} custom-recipe: spack/package.py spack-compiler: gcc spack-externals: gmake cmake openblas From 4f79022cc2326eea239928f2d7c0f676cc3d7099 Mon Sep 17 00:00:00 2001 From: Alex Richert Date: Wed, 22 May 2024 15:28:57 -0700 Subject: [PATCH 14/14] --parallel 2 for MacOS.yml --- .github/workflows/MacOS.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/MacOS.yml b/.github/workflows/MacOS.yml index eeb23c9f..1fffd233 100644 --- a/.github/workflows/MacOS.yml +++ b/.github/workflows/MacOS.yml @@ -39,4 +39,4 @@ jobs: ls -l ~/install/lib - name: test - run: ctest --test-dir ip/build --verbose --output-on-failure --rerun-failed + run: ctest --test-dir ip/build --parallel 2 --verbose --output-on-failure --rerun-failed