From fc395fed6302fe9531943f545bde6f2a75bcbbf9 Mon Sep 17 00:00:00 2001 From: "github-actions[bot]" <41898282+github-actions[bot]@users.noreply.github.com> Date: Mon, 16 Dec 2024 19:18:23 -0500 Subject: [PATCH] [c++] Add ASAN run of CI to weekly CI job (#3434) (#3452) * Update Makefile and dev docs for sanitizer builds * Add weekly workflow for ASAN CI * Run workflow for PRs that modify workflow Co-authored-by: Julia Dark <24235303+jp-dark@users.noreply.github.com> --- .github/workflows/libtiledbsoma-asan-ci.yml | 37 +++++++++++++++++++++ Makefile | 3 +- libtiledbsoma/README.md | 6 ++-- scripts/bld | 2 +- scripts/update-tiledb-version.py | 5 +++ 5 files changed, 47 insertions(+), 6 deletions(-) create mode 100644 .github/workflows/libtiledbsoma-asan-ci.yml diff --git a/.github/workflows/libtiledbsoma-asan-ci.yml b/.github/workflows/libtiledbsoma-asan-ci.yml new file mode 100644 index 0000000000..b6c5f16bfa --- /dev/null +++ b/.github/workflows/libtiledbsoma-asan-ci.yml @@ -0,0 +1,37 @@ +name: libtiledbsoma ASAN + +on: + pull_request: + paths: + - '.github/workflows/libtiledbsoma-asan-ci.yml' + schedule: + - cron: 20 8 * * 0 + workflow_dispatch: + +jobs: + asan: + runs-on: ubuntu-24.04 + steps: + - name: Checkout TileDB-SOMA + uses: actions/checkout@v4 + - name: Install pre-built libtiledb + run: | + mkdir -p external + # Please do not edit manually -- let scripts/update-tiledb-version.py update this + wget --quiet https://github.com/TileDB-Inc/TileDB/releases/download/2.27.0/tiledb-linux-x86_64-2.27.0-2862c30.tar.gz + tar -C external -xzf tiledb-*.tar.gz + ls external/lib/ + - name: Build and install libtiledbsoma + run: | + cmake -S libtiledbsoma -B build \ + -D CMAKE_BUILD_TYPE=ASAN \ + -D CMAKE_PREFIX_PATH=$(pwd)/external/ \ + -D CMAKE_INSTALL_PREFIX:PATH=$(pwd)/external/ \ + -D OVERRIDE_INSTALL_PREFIX=OFF \ + -D DOWNLOAD_TILEDB_PREBUILT=OFF \ + -D TILEDB_REMOVE_DEPRECATIONS=ON \ + -D FORCE_BUILD_TILEDB=OFF + cmake --build build -j 2 + ls external/lib/ + - name: Run C++ unittests + run: ctest --test-dir build/libtiledbsoma -C ASAN --verbose --rerun-failed --output-on-failure diff --git a/Makefile b/Makefile index 91663933a7..34e1167efa 100644 --- a/Makefile +++ b/Makefile @@ -90,7 +90,7 @@ Rules: clean Remove build artifacts Options: - build=BUILD_TYPE Cmake build type = Release|Debug|RelWithDebInfo|Coverage [Release] + build=BUILD_TYPE Cmake build type = Release|Debug|RelWithDebInfo|ASAN|TSAN|LSAN|UBSAN|MSAN|Coverage [Release] prefix=PREFIX Install location [${PWD}/dist] tiledb=TILEDB_DIST Absolute path to custom TileDB build @@ -118,4 +118,3 @@ export HELP .PHONY: help help: @printf "$${HELP}" - diff --git a/libtiledbsoma/README.md b/libtiledbsoma/README.md index 648a1f623f..63088ddab2 100644 --- a/libtiledbsoma/README.md +++ b/libtiledbsoma/README.md @@ -46,7 +46,7 @@ This approach leverages the build-system defined in [pyproject.toml](../apis/pyt ## Python and C++ Development -Developers who plan to modify the C++ code must use these build commands: +Developers who plan to modify the C++ code must use these build commands: ``` # clean, build, and install @@ -77,9 +77,9 @@ Rules: clean Remove build artifacts Options: - build=BUILD_TYPE Cmake build type = Release|Debug|RelWithDebInfo|Coverage [Release] + build=BUILD_TYPE Cmake build type = Release|Debug|RelWithDebInfo|ASAN|TSAN|LSAN|UBSAN|MSAN|Coverage [Release] prefix=PREFIX Install location [dist] - tiledb=TILEDB_DIST Absolute path to custom TileDB build + tiledb=TILEDB_DIST Absolute path to custom TileDB build Examples: Install Release build diff --git a/scripts/bld b/scripts/bld index a1355b302d..3d6bc9e0d1 100755 --- a/scripts/bld +++ b/scripts/bld @@ -38,7 +38,7 @@ fi # set extra cmake options # ------------------------------------------------------------------- extra_opts="" -if [ "${build}" == "Debug" ] && [ -z "${tiledb}" ]; then +if [ "${build}" != "Release" ] && [ -z "${tiledb}" ]; then # Debug build of TileDB from source extra_opts+=" -DDOWNLOAD_TILEDB_PREBUILT=OFF" fi diff --git a/scripts/update-tiledb-version.py b/scripts/update-tiledb-version.py index ddc6b641b4..cb74090533 100755 --- a/scripts/update-tiledb-version.py +++ b/scripts/update-tiledb-version.py @@ -121,6 +121,11 @@ def main(args): ) update_version(filepath, new_version, new_hash) + filepath = ( + f"{os.path.dirname(__file__)}/../.github/workflows/libtiledbsoma-asan-ci.yml" + ) + update_version(filepath, new_version, new_hash) + if __name__ == "__main__": description = (