mirror of
https://github.com/HDFGroup/hdf5.git
synced 2024-12-27 08:01:04 +08:00
165 lines
7.3 KiB
YAML
165 lines
7.3 KiB
YAML
name: Test HDF5 cache VOL
|
|
|
|
on:
|
|
workflow_call:
|
|
inputs:
|
|
build_mode:
|
|
description: "CMake Build type"
|
|
required: true
|
|
type: string
|
|
|
|
permissions:
|
|
contents: read
|
|
|
|
jobs:
|
|
build_and_test:
|
|
strategy:
|
|
matrix:
|
|
name:
|
|
- "Test HDF5 cache VOL connector"
|
|
- "Test HDF5 cache VOL connector atop async VOL connector"
|
|
async: [false, true]
|
|
exclude:
|
|
- name: "Test HDF5 cache VOL connector"
|
|
async: true
|
|
|
|
- name: "Test HDF5 cache VOL connector atop async VOL connector"
|
|
async: false
|
|
|
|
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- name: Install dependencies
|
|
run: |
|
|
sudo apt-get update
|
|
sudo apt-get install automake autoconf libtool libtool-bin libopenmpi-dev
|
|
|
|
- name: Checkout HDF5
|
|
uses: actions/checkout@v4.1.1
|
|
with:
|
|
repository: HDFGroup/hdf5
|
|
path: hdf5
|
|
|
|
- name: Checkout Argobots
|
|
uses: actions/checkout@v4.1.1
|
|
with:
|
|
repository: pmodels/argobots
|
|
path: abt
|
|
|
|
# Argobots builds and installs fairly quickly,
|
|
# so no caching is currently performed here
|
|
- name: Install Argobots
|
|
working-directory: ${{ github.workspace }}/abt
|
|
run: |
|
|
./autogen.sh
|
|
./configure --prefix=/usr/local
|
|
make -j2
|
|
sudo make -j2 install
|
|
|
|
- name: Set environment variables for configuration (cache VOL only)
|
|
run: |
|
|
echo "HDF5_VOL_CACHE_TEST_NAME=cache_ext config=$GITHUB_WORKSPACE/config1.cfg\;under_vol=0\;under_info={}\;" >> $GITHUB_ENV
|
|
if: ${{ ! matrix.async }}
|
|
|
|
- name: Set environment variables for configuration (cache VOL atop async VOL)
|
|
run: |
|
|
echo "HDF5_VOL_CACHE_TEST_NAME=cache_ext config=$GITHUB_WORKSPACE/config1.cfg\;under_vol=512\;under_info={under_vol=0\;under_info={}}\;" >> $GITHUB_ENV
|
|
if: ${{ matrix.async }}
|
|
|
|
# Define ASYNC_INCLUDE_DIR, ASYNC_INCLUDE_DIRS and ASYNC_LIBRARIES to
|
|
# patch around having the cache VOL find the async VOL when they're built
|
|
# at the same time. Once the Async and Cache VOLs create CMake .config
|
|
# files, this should no longer be needed with CMake 3.24 and newer (see
|
|
# FetchContent's OVERRIDE_FIND_PACKAGE)
|
|
- name: Configure HDF5 with cache VOL connector
|
|
shell: bash
|
|
run: |
|
|
mkdir ${{ github.workspace }}/hdf5/build
|
|
cd ${{ github.workspace }}/hdf5/build
|
|
cmake -DCMAKE_BUILD_TYPE=${{ inputs.build_mode }} \
|
|
-DCMAKE_INSTALL_PREFIX=${{ runner.workspace }}/hdf5_build \
|
|
-DBUILD_STATIC_LIBS=OFF \
|
|
-DHDF5_TEST_API:BOOL=ON \
|
|
-DHDF5_TEST_API_ENABLE_ASYNC:BOOL=ON \
|
|
-DHDF5_ENABLE_PARALLEL:BOOL=ON \
|
|
-DHDF5_ENABLE_THREADSAFE:BOOL=ON \
|
|
-DALLOW_UNSUPPORTED:BOOL=ON \
|
|
-DHDF5_ENABLE_SZIP_SUPPORT:BOOL=OFF \
|
|
-DHDF5_VOL_ALLOW_EXTERNAL:STRING="GIT" \
|
|
-DHDF5_VOL_URL01:STRING="https://github.com/hpc-io/vol-async.git" \
|
|
-DHDF5_VOL_VOL-ASYNC_BRANCH:STRING="develop" \
|
|
-DHDF5_VOL_VOL-ASYNC_NAME:STRING="async under_vol=0\;under_info={}" \
|
|
-DHDF5_VOL_VOL-ASYNC_TEST_PARALLEL:BOOL=ON \
|
|
-DHDF5_VOL_URL02:STRING="https://github.com/HDFGroup/vol-cache.git" \
|
|
-DHDF5_VOL_VOL-CACHE_BRANCH:STRING="develop" \
|
|
-DHDF5_VOL_VOL-CACHE_NAME:STRING="$HDF5_VOL_CACHE_TEST_NAME" \
|
|
-DHDF5_VOL_VOL-CACHE_TEST_PARALLEL:BOOL=ON \
|
|
-DASYNC_INCLUDE_DIR=${{ github.workspace }}/hdf5/build/_deps/vol-async-src/src \
|
|
-DASYNC_INCLUDE_DIRS=${{ github.workspace }}/hdf5/build/_deps/vol-async-src/src \
|
|
-DASYNC_LIBRARIES=${{ github.workspace }}/hdf5/build/bin/libasynchdf5.a\;${{ github.workspace }}/hdf5/build/bin/libh5async.so \
|
|
${{ github.workspace }}/hdf5
|
|
cat src/libhdf5.settings
|
|
|
|
- name: Build HDF5 and cache VOL connector
|
|
shell: bash
|
|
working-directory: ${{ github.workspace }}/hdf5/build
|
|
run: |
|
|
cmake --build . --parallel 3 --config ${{ inputs.build_mode }}
|
|
echo "LD_LIBRARY_PATH=/usr/local/lib:${{ github.workspace }}/hdf5/build/bin" >> $GITHUB_ENV
|
|
|
|
- name: Create cache VOL connector configuration file for testing
|
|
shell: bash
|
|
run: |
|
|
mkdir -p $GITHUB_WORKSPACE/scratch
|
|
touch $GITHUB_WORKSPACE/config1.cfg
|
|
echo "HDF5_CACHE_STORAGE_SCOPE: LOCAL" >> $GITHUB_WORKSPACE/config1.cfg
|
|
echo "HDF5_CACHE_STORAGE_PATH: $GITHUB_WORKSPACE/scratch" >> $GITHUB_WORKSPACE/config1.cfg
|
|
echo "HDF5_CACHE_STORAGE_SIZE: 4294967296" >> $GITHUB_WORKSPACE/config1.cfg
|
|
echo "HDF5_CACHE_STORAGE_TYPE: SSD" >> $GITHUB_WORKSPACE/config1.cfg
|
|
echo "HDF5_CACHE_REPLACEMENT_POLICY: LRU" >> $GITHUB_WORKSPACE/config1.cfg
|
|
|
|
# Workaround for cache VOL CMake issue
|
|
- name: Copy testing files
|
|
working-directory: ${{ github.workspace }}/hdf5/build
|
|
run: |
|
|
cp bin/test_file.exe ./_deps/vol-cache-build/tests
|
|
cp bin/test_group.exe ./_deps/vol-cache-build/tests
|
|
cp bin/test_dataset.exe ./_deps/vol-cache-build/tests
|
|
cp bin/test_dataset_async_api.exe ./_deps/vol-cache-build/tests
|
|
cp bin/test_write_multi.exe ./_deps/vol-cache-build/tests
|
|
cp bin/test_multdset.exe ./_deps/vol-cache-build/tests
|
|
|
|
- name: Set environment variables for external tests (cache VOL only)
|
|
run: |
|
|
echo "HDF5_PLUGIN_PATH=${{ github.workspace }}/hdf5/build/bin/" >> $GITHUB_ENV
|
|
echo "HDF5_VOL_CONNECTOR=cache_ext config=$GITHUB_WORKSPACE/config1.cfg;under_vol=0;under_info={};" >> $GITHUB_ENV
|
|
if: ${{ ! matrix.async }}
|
|
|
|
- name: Set environment variables for external tests (cache VOL atop async VOL)
|
|
run: |
|
|
echo "HDF5_PLUGIN_PATH=${{ github.workspace }}/hdf5/build/bin/" >> $GITHUB_ENV
|
|
echo "HDF5_VOL_CONNECTOR=cache_ext config=$GITHUB_WORKSPACE/config1.cfg;under_vol=512;under_info={under_vol=0;under_info={}};" >> $GITHUB_ENV
|
|
if: ${{ matrix.async }}
|
|
|
|
# Until cache VOL tests are namespaced properly, run them directly
|
|
- name: Test HDF5 cache VOL connector with external tests
|
|
working-directory: ${{ github.workspace }}/hdf5/build
|
|
run: |
|
|
ctest --build-config ${{ inputs.build_mode }} -VV -R "^test_file$" .
|
|
ctest --build-config ${{ inputs.build_mode }} -VV -R "^test_group$" .
|
|
ctest --build-config ${{ inputs.build_mode }} -VV -R "^test_dataset$" .
|
|
ctest --build-config ${{ inputs.build_mode }} -VV -R "^test_dataset_async_api$" .
|
|
ctest --build-config ${{ inputs.build_mode }} -VV -R "^test_write_multi$" .
|
|
ctest --build-config ${{ inputs.build_mode }} -VV -R "^test_multdset$" .
|
|
|
|
- name: Test HDF5 cache VOL connector with HDF5 API tests
|
|
working-directory: ${{ github.workspace }}/hdf5/build
|
|
# Don't test the Cache VOL connector with the HDF5 API tests yet
|
|
# when it's stacked on top of the Async connector, as it doesn't
|
|
# currently pass all the tests due to the Async connector not passing
|
|
# all the tests. Leave the step in, but skip it to leave an indication
|
|
# that this should be re-enabled in the future.
|
|
if: ${{ ! matrix.async }}
|
|
run: |
|
|
ctest --build-config ${{ inputs.build_mode }} -VV -R "HDF5_VOL_vol-cache" .
|