2021-04-09 09:54:28 +02:00
name : CI
on : [ 'push' , 'pull_request' ]
jobs :
2021-04-27 04:26:39 +02:00
linux_macos :
name : CI (Linux/macOS)
strategy :
fail-fast : false
matrix :
name : [ "" ]
os :
2023-06-19 18:14:32 +02:00
- macos-11
- macos-12
- macos-13
2021-04-27 04:26:39 +02:00
- ubuntu-20.04
2023-06-19 18:14:32 +02:00
- ubuntu-22.04
2021-04-27 04:26:39 +02:00
compiler :
2022-10-12 05:48:53 +02:00
- cxx : g++-7
cc : gcc-7
macos_cxx : g++-7
macos_cc : gcc-7
homebrew_package : gcc@7
apt_package : g++-7
2021-04-27 04:26:39 +02:00
- cxx : g++-8
cc : gcc-8
macos_cxx : g++-8
macos_cc : gcc-8
homebrew_package : gcc@8
apt_package : g++-8
- cxx : g++-9
cc : gcc-9
macos_cxx : g++-9
macos_cc : gcc-9
apt_package : g++-9
homebrew_package : gcc@9
2022-10-12 20:32:53 +02:00
- cxx : g++-10
cc : gcc-10
macos_cxx : g++-10
macos_cc : gcc-10
apt_package : g++-10
homebrew_package : gcc@10
2023-06-20 17:02:47 +02:00
- cxx : g++-11
cc : gcc-11
macos_cxx : g++-11
macos_cc : gcc-11
apt_package : g++-11
homebrew_package : gcc@11
- cxx : g++-12
cc : gcc-12
macos_cxx : g++-12
macos_cc : gcc-12
apt_package : g++-12
homebrew_package : gcc@12
- cxx : g++-13
cc : gcc-13
macos_cxx : g++-13
macos_cc : gcc-13
apt_package : g++-13
homebrew_package : gcc@13
2021-04-27 04:26:39 +02:00
- cxx : clang++-7
cc : clang-7
macos_cxx : /usr/local/opt/llvm@7/bin/clang++
macos_cc : /usr/local/opt/llvm@7/bin/clang
apt_package : clang-7
homebrew_package : llvm@7
- cxx : clang++-8
cc : clang-8
macos_cxx : /usr/local/opt/llvm@8/bin/clang++
macos_cc : /usr/local/opt/llvm@8/bin/clang
apt_package : clang-8
homebrew_package : llvm@8
- cxx : clang++-9
cc : clang-9
macos_cxx : /usr/local/opt/llvm@9/bin/clang++
macos_cc : /usr/local/opt/llvm@9/bin/clang
apt_package : clang-9
homebrew_package : llvm@9
# TODO Clang-10 on linux? macos homebrew doesn't seem to have it
- cxx : clang++-11
cc : clang-11
macos_cxx : /usr/local/opt/llvm@11/bin/clang++
macos_cc : /usr/local/opt/llvm@11/bin/clang
2023-06-19 18:14:32 +02:00
apt_package : clang-11 libomp5-11 libomp-11-dev
2021-04-27 04:26:39 +02:00
homebrew_package : llvm@11
# Apple Clang
# - cxx: clang++
# cc: clang
# homebrew_package: ""
build_type :
- Debug
- Release
- RelWithDebInfo
extra_cmake_flags : [ "" ]
extra_cxxflags : [ "" ]
extra_env_vars_for_test : [ "" ]
install_dependencies_manually : [ false ]
run_build : [ true ]
run_tests : [ true ]
run_clang_tidy : [ false ]
2022-10-12 05:48:53 +02:00
exclude :
2023-06-19 18:14:32 +02:00
# MacOS CI doesn't have Clang 7, 8, 9 or GCC 7, 8 anymore
- os : macos-11
2022-10-12 06:03:10 +02:00
compiler : {cxx: clang++-7, cc: clang-7, macos_cxx: /usr/local/opt/llvm@7/bin/clang++, macos_cc: /usr/local/opt/llvm@7/bin/clang, apt_package: clang-7, homebrew_package : llvm@7}
2023-06-19 18:14:32 +02:00
- os : macos-11
compiler : {cxx: clang++-8, cc: clang-8, macos_cxx: /usr/local/opt/llvm@8/bin/clang++, macos_cc: /usr/local/opt/llvm@8/bin/clang, apt_package: clang-8, homebrew_package : llvm@8}
- os : macos-11
compiler : {cxx: clang++-9, cc: clang-9, macos_cxx: /usr/local/opt/llvm@9/bin/clang++, macos_cc: /usr/local/opt/llvm@9/bin/clang, apt_package: clang-9, homebrew_package : llvm@9}
- os : macos-11
compiler : {cxx: g++-7, cc: gcc-7, macos_cxx: g++-7, macos_cc: gcc-7, homebrew_package: gcc@7, apt_package : g++-7}
- os : macos-11
compiler : {cxx: g++-8, cc: gcc-8, macos_cxx: g++-8, macos_cc: gcc-8, homebrew_package: gcc@8, apt_package : g++-8}
- os : macos-12
compiler : {cxx: clang++-7, cc: clang-7, macos_cxx: /usr/local/opt/llvm@7/bin/clang++, macos_cc: /usr/local/opt/llvm@7/bin/clang, apt_package: clang-7, homebrew_package : llvm@7}
- os : macos-12
compiler : {cxx: clang++-8, cc: clang-8, macos_cxx: /usr/local/opt/llvm@8/bin/clang++, macos_cc: /usr/local/opt/llvm@8/bin/clang, apt_package: clang-8, homebrew_package : llvm@8}
- os : macos-12
compiler : {cxx: clang++-9, cc: clang-9, macos_cxx: /usr/local/opt/llvm@9/bin/clang++, macos_cc: /usr/local/opt/llvm@9/bin/clang, apt_package: clang-9, homebrew_package : llvm@9}
- os : macos-12
compiler : {cxx: g++-7, cc: gcc-7, macos_cxx: g++-7, macos_cc: gcc-7, homebrew_package: gcc@7, apt_package : g++-7}
- os : macos-12
compiler : {cxx: g++-8, cc: gcc-8, macos_cxx: g++-8, macos_cc: gcc-8, homebrew_package: gcc@8, apt_package : g++-8}
- os : macos-12
compiler : {cxx: g++-9, cc: gcc-9, macos_cxx: g++-9, macos_cc: gcc-9, homebrew_package: gcc@9, apt_package : g++-9}
- os : macos-13
compiler : {cxx: clang++-7, cc: clang-7, macos_cxx: /usr/local/opt/llvm@7/bin/clang++, macos_cc: /usr/local/opt/llvm@7/bin/clang, apt_package: clang-7, homebrew_package : llvm@7}
2023-06-20 17:02:47 +02:00
# Ubuntu 20.04 doesn't have GCC 12, 13 yet
- os : ubuntu-20.04
compiler : {cxx: g++-12, cc: gcc-12, macos_cxx: g++-12, macos_cc: gcc-12, homebrew_package: gcc@12, apt_package : g++-12}
- os : ubuntu-20.04
compiler : {cxx: g++-13, cc: gcc-13, macos_cxx: g++-13, macos_cc: gcc-13, homebrew_package: gcc@13, apt_package : g++-13}
2023-06-19 18:14:32 +02:00
# Ubuntu 22.04 doesn't have gcc 7, 8 or clang 7, 8, 9, 10 anymore
- os : ubuntu-22.04
compiler : {cxx: g++-7, cc: gcc-7, macos_cxx: g++-7, macos_cc: gcc-7, homebrew_package: gcc@7, apt_package : g++-7}
- os : ubuntu-22.04
compiler : {cxx: g++-8, cc: gcc-8, macos_cxx: g++-8, macos_cc: gcc-8, homebrew_package: gcc@8, apt_package : g++-8}
- os : ubuntu-22.04
compiler : {cxx: clang++-7, cc: clang-7, macos_cxx: /usr/local/opt/llvm@7/bin/clang++, macos_cc: /usr/local/opt/llvm@7/bin/clang, apt_package: clang-7, homebrew_package : llvm@7}
- os : ubuntu-22.04
compiler : {cxx: clang++-8, cc: clang-8, macos_cxx: /usr/local/opt/llvm@8/bin/clang++, macos_cc: /usr/local/opt/llvm@8/bin/clang, apt_package: clang-8, homebrew_package : llvm@8}
- os : ubuntu-22.04
compiler : {cxx: clang++-9, cc: clang-9, macos_cxx: /usr/local/opt/llvm@9/bin/clang++, macos_cc: /usr/local/opt/llvm@9/bin/clang, apt_package: clang-9, homebrew_package : llvm@9}
- os : ubuntu-22.04
compiler : {cxx: clang++-10, cc: clang-10, macos_cxx: /usr/local/opt/llvm@10/bin/clang++, macos_cc: /usr/local/opt/llvm@10/bin/clang, apt_package: clang-10, homebrew_package : llvm@10}
2021-04-27 04:26:39 +02:00
include :
- name : Local dependencies
2023-06-19 18:14:32 +02:00
os : ubuntu-22.04
2021-04-27 04:26:39 +02:00
compiler :
cxx : clang++-11
cc : clang-11
2023-06-19 18:14:32 +02:00
apt_package : clang-11 libomp5-11 libomp-11-dev
2021-04-27 04:26:39 +02:00
build_type : RelWithDebInfo
extra_cmake_flags : -DDEPENDENCY_CONFIG=../cmake-utils/DependenciesFromLocalSystem.cmake
extra_cxxflags : ""
extra_env_vars_for_test : ""
install_dependencies_manually : true
run_build : true
run_tests : true
- name : Local dependencies
2023-06-19 18:14:32 +02:00
os : ubuntu-22.04
2021-04-27 04:26:39 +02:00
compiler :
cxx : clang++-11
cc : clang-11
2023-06-19 18:14:32 +02:00
apt_package : clang-11 libomp5-11 libomp-11-dev
2021-04-27 04:26:39 +02:00
build_type : RelWithDebInfo
extra_cmake_flags : -DDEPENDENCY_CONFIG=../cmake-utils/DependenciesFromLocalSystem.cmake
extra_cxxflags : ""
extra_env_vars_for_test : ""
install_dependencies_manually : true
run_build : true
run_tests : true
- name : Werror gcc
2023-06-19 18:14:32 +02:00
os : ubuntu-22.04
2021-04-27 04:26:39 +02:00
compiler :
cxx : g++-9
cc : gcc-9
apt_package : g++-9
build_type : RelWithDebInfo
extra_cmake_flags : -DUSE_WERROR=on
extra_cxxflags : ""
install_dependencies_manually : false
run_build : true
run_tests : false
- name : Werror clang
2023-06-19 18:14:32 +02:00
os : ubuntu-22.04
2021-04-27 04:26:39 +02:00
compiler :
cxx : clang++-11
cc : clang-11
2023-06-19 18:14:32 +02:00
apt_package : clang-11 libomp5-11 libomp-11-dev
2021-04-27 04:26:39 +02:00
build_type : RelWithDebInfo
extra_cmake_flags : -DUSE_WERROR=on
extra_cxxflags : ""
install_dependencies_manually : false
run_build : true
run_tests : false
- name : No compatibility
2023-06-19 18:14:32 +02:00
os : ubuntu-22.04
2021-04-27 04:26:39 +02:00
compiler :
cxx : clang++-11
cc : clang-11
2023-06-19 18:14:32 +02:00
apt_package : clang-11 libomp5-11 libomp-11-dev
2021-04-27 04:26:39 +02:00
build_type : RelWithDebInfo
extra_cmake_flags : ""
extra_cxxflags : "-DCRYFS_NO_COMPATIBILITY"
extra_env_vars_for_test : ""
install_dependencies_manually : false
run_build : true
run_tests : true
- name : ASAN
2023-06-19 18:14:32 +02:00
# TODO Update to ubuntu-22.04
2021-04-27 04:26:39 +02:00
os : ubuntu-20.04
compiler :
cxx : clang++-11
cc : clang-11
2023-06-19 18:14:32 +02:00
apt_package : clang-11 libomp5-11 libomp-11-dev
2021-04-27 04:26:39 +02:00
build_type : Debug
# OpenMP crashes under asan. Disable OpenMP.
# TODO is it enough to replace this with omp_num_threads: 1 ?
extra_cmake_flags : "-DDISABLE_OPENMP=ON"
extra_cxxflags : "-O1 -fsanitize=address -fno-omit-frame-pointer -fno-optimize-sibling-calls -fno-common -fsanitize-address-use-after-scope"
extra_env_vars_for_test : ASAN_OPTIONS="detect_leaks=1 check_initialization_order=1 detect_stack_use_after_return=1 detect_invalid_pointer_pairs=1 atexit=1"
install_dependencies_manually : false
run_build : true
run_tests : true
- name : UBSAN
2023-06-19 18:14:32 +02:00
# TODO Update to ubuntu-22.04
2021-04-27 04:26:39 +02:00
os : ubuntu-20.04
compiler :
cxx : clang++-11
cc : clang-11
2023-06-19 18:14:32 +02:00
apt_package : clang-11 libomp5-11 libomp-11-dev
2021-04-27 04:26:39 +02:00
build_type : Debug
# OpenMP crashes under ubsan. Disable OpenMP.
# TODO is it enough to replace this with omp_num_threads: 1 ?
extra_cmake_flags : "-DDISABLE_OPENMP=ON"
extra_cxxflags : "-O1 -fno-sanitize-recover=undefined,nullability,implicit-conversion,unsigned-integer-overflow,local-bounds,float-divide-by-zero -fno-omit-frame-pointer -fno-optimize-sibling-calls -fno-common"
extra_env_vars_for_test : UBSAN_OPTIONS="print_stacktrace=1"
install_dependencies_manually : false
run_build : true
run_tests : true
- name : TSAN
2023-06-19 18:14:32 +02:00
# TODO Update to ubuntu-22.04
2021-04-27 04:26:39 +02:00
os : ubuntu-20.04
compiler :
cxx : clang++-11
cc : clang-11
2023-06-19 18:14:32 +02:00
apt_package : clang-11 libomp5-11 libomp-11-dev
2021-04-27 04:26:39 +02:00
build_type : Debug
extra_cmake_flags : ""
extra_cxxflags : "-O2 -fsanitize=thread -fno-omit-frame-pointer -fno-omit-frame-pointer -fno-optimize-sibling-calls -fno-common"
install_dependencies_manually : false
run_build : true
run_tests : true
2021-12-13 15:15:16 +01:00
gtest_args : "--gtest_filter=-LoggingTest.LoggingAlsoWorksAfterFork:AssertTest_*:BacktraceTest.*:SubprocessTest.*:SignalCatcherTest.*_thenDies:SignalHandlerTest.*_thenDies:SignalHandlerTest.givenMultipleSigIntHandlers_whenRaising_thenCatchesCorrectSignal:CliTest_Setup.*:CliTest_IntegrityCheck.*:*/CliTest_WrongEnvironment.*:CliTest_Unmount.*:CliTest.WorksWithCommasInBasedir"
2021-04-27 04:26:39 +02:00
extra_env_vars_for_test : OMP_NUM_THREADS=1
- name : clang-tidy
2023-06-19 18:14:32 +02:00
os : ubuntu-22.04
2021-04-27 04:26:39 +02:00
compiler :
cxx : clang++-11
cc : clang-11
2023-06-19 18:14:32 +02:00
apt_package : clang-11 clang-tidy-11 libomp5-11 libomp-11-dev
2021-04-27 04:26:39 +02:00
build_type : RelWithDebInfo
extra_cmake_flags : ""
extra_cxxflags : ""
install_dependencies_manually : false
run_build : false
run_tests : false
extra_env_vars_for_test : ""
run_clang_tidy : true
runs-on : ${{matrix.os}}
env :
# Setting conan cache dir to a location where our Github Cache Action can find it
CONAN_USER_HOME : "${{ github.workspace }}/conan-cache/"
steps :
- name : Checkout
uses : actions/checkout@v1
#TODO Ideally, all the setup actions would be in their own subaction, but Github doesn't support using third party actions (e.g. cache) from nested actions yet, see https://github.com/actions/runner/issues/862
- name : Setup MacOS
if : ${{ runner.os == 'macOS' }}
uses : ./.github/workflows/actions/setup_macos
with :
extra_homebrew_packages : ${{ matrix.compiler.homebrew_package }}
- name : Setup Linux
if : ${{ runner.os == 'Linux' }}
uses : ./.github/workflows/actions/setup_linux
with :
os : ${{ matrix.os }}
extra_apt_packages : ${{ matrix.compiler.apt_package }}
- name : Install local dependencies
if : ${{ matrix.install_dependencies_manually }}
uses : ./.github/workflows/actions/install_local_dependencies
- name : Find pip cache location
id : pip_cache_dir
run : |
# We need at least pip 20.1 to get the "pip cache dir" command. Ubuntu doesn't have pip 20.1 by default yet, let's upgrade it
python3 -m pip install -U pip
python3 -m pip --version
echo "::set-output name=pip_cache_dir::$(python3 -m pip cache dir)"
shell : bash
- name : Retrieve pip cache
# Many jobs access the cache in parallel an we might observe an incomplete state that isn't valid. This would fail with a checksum error. Let's not fail the CI job but continue it, later on this job will upload a new new cache as part of the regular job run.
continue-on-error : true
# We're using an S3 based cache because the standard GitHub Action cache (actions/cache) only gives us 5GB of storage and we need more
uses : leroy-merlin-br/action-s3-cache@8d75079437b388688b9ea9c7d73dff4ef975c5fa # v1.0.5
with :
action : get
# note: this access key has read-only access to the cache. It's public so it runs on PRs.
aws-access-key-id : AKIAV5S2KH4F5OUZXV5E
aws-secret-access-key : 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
aws-region : eu-west-1
bucket : ci-cache.cryfs
key : v0-${{ runner.os }}-${{ matrix.os }}-setup-pip
- name : Install Conan
shell : bash
run : |
# Using "python3 -m pip" instead of "pip3" to make sure we get the same pip that we queried the cache dir for the Github Cache action
2023-06-19 18:11:16 +02:00
python3 -m pip install conan==1.60.1
2021-04-27 04:26:39 +02:00
- name : Save pip cache
# note: this access key has write access to the cache. This can't run on PRs.
if : ${{github.event_name == 'push' }}
2021-08-22 17:43:46 +02:00
# Cache things sometimes indeterministically fail (roughly 1% of times this is run), let's not fail the job for it
continue-on-error : true
2021-04-27 04:26:39 +02:00
uses : leroy-merlin-br/action-s3-cache@8d75079437b388688b9ea9c7d73dff4ef975c5fa # v1.0.5
with :
action : put
aws-access-key-id : ${{ secrets.CACHE_AWS_ACCESS_KEY_ID }}
aws-secret-access-key : ${{ secrets.CACHE_AWS_SECRET_ACCESS_KEY }}
aws-region : eu-west-1
bucket : ci-cache.cryfs
key : v0-${{ runner.os }}-${{ matrix.os }}-setup-pip
artifacts : ${{ steps.pip_cache_dir.outputs.pip_cache_dir }}
#TODO Ideally, the Setup ccache step would be part of the build action, but Github doesn't support nested actions yet, see https://github.com/actions/runner/issues/862
- name : Configure ccache
shell : bash
run : |
set -v
ccache --set-config=compiler_check=content
ccache --set-config=max_size=500M
ccache --set-config=cache_dir=${{github.workspace}}/.ccache
ccache --set-config=compression=true
ccache --set-config=sloppiness=include_file_mtime,include_file_ctime
echo CCache config :
ccache -p
echo Clearing ccache statistics
ccache -z
- name : Hash flags
id : hash_flags
run : |
# Write it into file first so we fail if the command fails. Errors inside $() are ignored by bash unfortunately.
echo __${{matrix.extra_cmake_flags}}__${{matrix.extra_cxxflags}}__ | md5sum > /tmp/hash_flags
echo "::set-output name=hash_flags::$(cat /tmp/hash_flags)"
rm /tmp/hash_flags
shell : bash
- name : Retrieve ccache cache
# Many jobs access the cache in parallel an we might observe an incomplete state that isn't valid. This would fail with a checksum error. Let's not fail the CI job but continue it, later on this job will upload a new new cache as part of the regular job run.
continue-on-error : true
# We're using an S3 based cache because the standard GitHub Action cache (actions/cache) only gives us 5GB of storage and we need more
uses : leroy-merlin-br/action-s3-cache@8d75079437b388688b9ea9c7d73dff4ef975c5fa # v1.0.5
with :
action : get
# note: this access key has read-only access to the cache. It's public so it runs on PRs.
aws-access-key-id : AKIAV5S2KH4F5OUZXV5E
aws-secret-access-key : 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
aws-region : eu-west-1
bucket : ci-cache.cryfs
key : v0-${{ runner.os }}-${{ matrix.os }}-ccache__${{matrix.compiler.cxx}}__${{matrix.compiler.cc}}__${{matrix.build_type}}__${{matrix.run_build}}__${{matrix.run_clang_tidy}}__${{steps.hash_flags.outputs.hash_flags}}__
- name : Show ccache statistics
shell : bash
run : |
set -v
ccache -s
# TODO Ideally, the Setup conan cache step would be part of the build action, but Github doesn't support nested actions yet, see https://github.com/actions/runner/issues/862
- name : Retrieve conan cache
# Many jobs access the cache in parallel an we might observe an incomplete state that isn't valid. This would fail with a checksum error. Let's not fail the CI job but continue it, later on this job will upload a new new cache as part of the regular job run.
continue-on-error : true
# We're using an S3 based cache because the standard GitHub Action cache (actions/cache) only gives us 5GB of storage and we need more
uses : leroy-merlin-br/action-s3-cache@8d75079437b388688b9ea9c7d73dff4ef975c5fa # v1.0.5
with :
action : get
# note: this access key has read-only access to the cache. It's public so it runs on PRs.
aws-access-key-id : AKIAV5S2KH4F5OUZXV5E
aws-secret-access-key : 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
aws-region : eu-west-1
bucket : ci-cache.cryfs
2021-12-09 12:10:23 +01:00
key : v1-${{ runner.os }}-${{ matrix.os }}-conancache__${{matrix.compiler.cxx}}__${{matrix.compiler.cc}}__${{matrix.build_type}}__
2021-04-27 04:26:39 +02:00
- name : Build (macOS)
if : ${{ matrix.run_build && runner.os == 'macOS' }}
uses : ./.github/workflows/actions/run_build
with :
cxx : ${{ matrix.compiler.macos_cxx }}
cc : ${{ matrix.compiler.macos_cc }}
build_type : ${{ matrix.build_type }}
- name : Build (Linux)
if : ${{ matrix.run_build && runner.os == 'Linux' }}
uses : ./.github/workflows/actions/run_build
with :
cxx : ${{ matrix.compiler.cxx }}
cc : ${{ matrix.compiler.cc }}
build_type : ${{ matrix.build_type }}
extra_cmake_flags : ${{ matrix.extra_cmake_flags }}
extra_cxxflags : ${{ matrix.extra_cxxflags }}
- name : Run clang-tidy
id : clang_tidy
if : ${{ matrix.run_clang_tidy }}
shell : bash
run : |
set -v
mkdir cmake
cd cmake
if ! ../run-clang-tidy.sh -fix ; then
git diff > /tmp/clang-tidy-fixes
echo Found clang tidy fixes :
cat /tmp/clang-tidy-fixes
exit 1
else
echo Did not find any clang-tidy fixes
fi
- name : Upload fixes as artifact
if : ${{ always() && matrix.run_clang_tidy }}
uses : actions/upload-artifact@v2
with :
name : clang-tidy-fixes
path : /tmp/clang-tidy-fixes
- name : Show ccache statistics
shell : bash
run : |
set -v
ccache -s
- name : Reduce ccache size
if : ${{ runner.os == 'macOS' }}
shell : bash
run : |
set -v
ccache --evict-older-than 7d
ccache -s
- name : Save ccache cache
# note: this access key has write access to the cache. This can't run on PRs.
if : ${{ github.event_name == 'push' }}
2021-08-22 17:43:46 +02:00
# Cache things sometimes indeterministically fail (roughly 1% of times this is run), let's not fail the job for it
continue-on-error : true
2021-04-27 04:26:39 +02:00
uses : leroy-merlin-br/action-s3-cache@8d75079437b388688b9ea9c7d73dff4ef975c5fa # v1.0.5
with :
action : put
aws-access-key-id : ${{ secrets.CACHE_AWS_ACCESS_KEY_ID }}
aws-secret-access-key : ${{ secrets.CACHE_AWS_SECRET_ACCESS_KEY }}
aws-region : eu-west-1
bucket : ci-cache.cryfs
key : v0-${{ runner.os }}-${{ matrix.os }}-ccache__${{matrix.compiler.cxx}}__${{matrix.compiler.cc}}__${{matrix.build_type}}__${{matrix.run_build}}__${{matrix.run_clang_tidy}}__${{steps.hash_flags.outputs.hash_flags}}__
artifacts : ${{ github.workspace }}/.ccache
- name : Save conan cache
# note: this access key has write access to the cache. This can't run on PRs.
if : ${{ github.event_name == 'push' }}
2021-08-22 17:43:46 +02:00
# Cache things sometimes indeterministically fail (roughly 1% of times this is run), let's not fail the job for it
continue-on-error : true
2021-04-27 04:26:39 +02:00
uses : leroy-merlin-br/action-s3-cache@8d75079437b388688b9ea9c7d73dff4ef975c5fa # v1.0.5
with :
action : put
aws-access-key-id : ${{ secrets.CACHE_AWS_ACCESS_KEY_ID }}
aws-secret-access-key : ${{ secrets.CACHE_AWS_SECRET_ACCESS_KEY }}
aws-region : eu-west-1
bucket : ci-cache.cryfs
2021-12-09 12:10:23 +01:00
key : v1-${{ runner.os }}-${{ matrix.os }}-conancache__${{matrix.compiler.cxx}}__${{matrix.compiler.cc}}__${{matrix.build_type}}__
2021-04-27 04:26:39 +02:00
artifacts : ${{ env.CONAN_USER_HOME }}
- name : Test
if : ${{ matrix.run_tests }}
uses : ./.github/workflows/actions/run_tests
with :
gtest_args : ${{matrix.gtest_args}}
extra_env_vars : ${{matrix.extra_env_vars_for_test}}
2021-09-02 03:44:21 +02:00
2021-04-20 01:45:11 +02:00
windows :
name : CI (Windows)
2021-04-09 09:54:28 +02:00
strategy :
2021-04-09 10:03:43 +02:00
fail-fast : false
2021-04-09 09:54:28 +02:00
matrix :
2021-04-19 03:32:55 +02:00
name : [ "" ]
2021-04-09 09:54:28 +02:00
os :
2021-04-20 01:45:11 +02:00
- windows-2019
arch :
- Win32
- x64
2021-04-09 09:54:28 +02:00
build_type :
- Debug
- Release
- RelWithDebInfo
runs-on : ${{matrix.os}}
env :
# Setting conan cache dir to a location where our Github Cache Action can find it
2021-04-20 01:45:11 +02:00
CONAN_USER_HOME : "D:/.conan/f/"
CONAN_USER_HOME_SHORT : "D:/.conan/s/"
2021-04-09 09:54:28 +02:00
steps :
- name : Checkout
uses : actions/checkout@v1
2021-04-17 18:31:10 +02:00
#TODO Ideally, all the setup actions would be in their own subaction, but Github doesn't support using third party actions (e.g. cache) from nested actions yet, see https://github.com/actions/runner/issues/862
2021-04-20 01:45:11 +02:00
- name : Setup Windows
uses : ./.github/workflows/actions/setup_windows
2021-04-18 00:57:32 +02:00
- name : Find pip cache location
id : pip_cache_dir
run : |
# We need at least pip 20.1 to get the "pip cache dir" command. Ubuntu doesn't have pip 20.1 by default yet, let's upgrade it
python3 -m pip install -U pip
python3 -m pip --version
echo "::set-output name=pip_cache_dir::$(python3 -m pip cache dir)"
shell : bash
- name : Retrieve pip cache
2021-04-25 22:20:05 +02:00
# Many jobs access the cache in parallel an we might observe an incomplete state that isn't valid. This would fail with a checksum error. Let's not fail the CI job but continue it, later on this job will upload a new new cache as part of the regular job run.
2021-04-25 22:01:43 +02:00
continue-on-error : true
2021-04-18 00:57:32 +02:00
# We're using an S3 based cache because the standard GitHub Action cache (actions/cache) only gives us 5GB of storage and we need more
uses : leroy-merlin-br/action-s3-cache@8d75079437b388688b9ea9c7d73dff4ef975c5fa # v1.0.5
with :
action : get
2021-04-25 21:46:56 +02:00
# note: this access key has read-only access to the cache. It's public so it runs on PRs.
aws-access-key-id : AKIAV5S2KH4F5OUZXV5E
aws-secret-access-key : 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
aws-region : eu-west-1
bucket : ci-cache.cryfs
2021-04-18 00:57:32 +02:00
key : v0-${{ runner.os }}-${{ matrix.os }}-setup-pip
2021-04-17 18:31:10 +02:00
- name : Install Conan
shell : bash
run : |
# Using "python3 -m pip" instead of "pip3" to make sure we get the same pip that we queried the cache dir for the Github Cache action
2023-06-19 18:11:16 +02:00
python3 -m pip install conan==1.60.1
2021-04-18 00:57:32 +02:00
- name : Save pip cache
2021-04-25 21:46:56 +02:00
# note: this access key has write access to the cache. This can't run on PRs.
if : ${{github.event_name == 'push' }}
2021-08-22 17:43:46 +02:00
# Cache things sometimes indeterministically fail (roughly 1% of times this is run), let's not fail the job for it
continue-on-error : true
2021-04-18 00:57:32 +02:00
uses : leroy-merlin-br/action-s3-cache@8d75079437b388688b9ea9c7d73dff4ef975c5fa # v1.0.5
with :
action : put
aws-access-key-id : ${{ secrets.CACHE_AWS_ACCESS_KEY_ID }}
aws-secret-access-key : ${{ secrets.CACHE_AWS_SECRET_ACCESS_KEY }}
2021-04-25 21:46:56 +02:00
aws-region : eu-west-1
bucket : ci-cache.cryfs
2021-04-18 00:57:32 +02:00
key : v0-${{ runner.os }}-${{ matrix.os }}-setup-pip
artifacts : ${{ steps.pip_cache_dir.outputs.pip_cache_dir }}
2021-04-18 09:47:44 +02:00
#TODO Ideally, the Setup ccache step would be part of the build action, but Github doesn't support nested actions yet, see https://github.com/actions/runner/issues/862
2021-04-20 01:45:11 +02:00
# - name: Configure ccache
# shell: bash
# run: |
# set -v
# ccache --set-config=compiler_check=content
# ccache --set-config=max_size=500M
# ccache --set-config=cache_dir=${{github.workspace}}/.ccache
# ccache --set-config=compression=true
# ccache --set-config=sloppiness=include_file_mtime,include_file_ctime
# echo CCache config:
# ccache -p
# echo Clearing ccache statistics
# ccache -z
# - name: Hash flags
# id: hash_flags
# run: |
# # Write it into file first so we fail if the command fails. Errors inside $() are ignored by bash unfortunately.
# echo __${{matrix.extra_cmake_flags}}__${{matrix.extra_cxxflags}}__ | md5sum > /tmp/hash_flags
# echo "::set-output name=hash_flags::$(cat /tmp/hash_flags)"
# rm /tmp/hash_flags
# shell: bash
# - name: Retrieve ccache cache
# # Many jobs access the cache in parallel an we might observe an incomplete state that isn't valid. This would fail with a checksum error. Let's not fail the CI job but continue it, later on this job will upload a new new cache as part of the regular job run.
# continue-on-error: true
# # We're using an S3 based cache because the standard GitHub Action cache (actions/cache) only gives us 5GB of storage and we need more
# uses: leroy-merlin-br/action-s3-cache@8d75079437b388688b9ea9c7d73dff4ef975c5fa # v1.0.5
# with:
# action: get
# # note: this access key has read-only access to the cache. It's public so it runs on PRs.
# aws-access-key-id: AKIAV5S2KH4F5OUZXV5E
# aws-secret-access-key: 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
# aws-region: eu-west-1
# bucket: ci-cache.cryfs
# key: v0-${{ runner.os }}-${{ matrix.os }}-ccache__${{matrix.compiler.cxx}}__${{matrix.compiler.cc}}__${{matrix.build_type}}__${{matrix.run_build}}__${{matrix.run_clang_tidy}}__${{steps.hash_flags.outputs.hash_flags}}__
# - name: Show ccache statistics
# shell: bash
# run: |
# set -v
# ccache -s
2021-04-09 09:54:28 +02:00
# TODO Ideally, the Setup conan cache step would be part of the build action, but Github doesn't support nested actions yet, see https://github.com/actions/runner/issues/862
2021-04-18 00:57:32 +02:00
- name : Retrieve conan cache
2021-04-25 22:20:05 +02:00
# Many jobs access the cache in parallel an we might observe an incomplete state that isn't valid. This would fail with a checksum error. Let's not fail the CI job but continue it, later on this job will upload a new new cache as part of the regular job run.
2021-04-25 22:01:43 +02:00
continue-on-error : true
2021-04-18 00:57:32 +02:00
# We're using an S3 based cache because the standard GitHub Action cache (actions/cache) only gives us 5GB of storage and we need more
uses : leroy-merlin-br/action-s3-cache@8d75079437b388688b9ea9c7d73dff4ef975c5fa # v1.0.5
2021-04-09 09:54:28 +02:00
with :
2021-04-18 00:57:32 +02:00
action : get
2021-04-25 21:46:56 +02:00
# note: this access key has read-only access to the cache. It's public so it runs on PRs.
aws-access-key-id : AKIAV5S2KH4F5OUZXV5E
aws-secret-access-key : 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
aws-region : eu-west-1
bucket : ci-cache.cryfs
2022-10-13 03:16:35 +02:00
key : v3-${{ runner.os }}-${{ matrix.os }}-conancache__${{matrix.compiler.cxx}}__${{matrix.compiler.cc}}__${{matrix.build_type}}__
2021-04-20 01:45:11 +02:00
- name : Build
2021-04-19 04:48:03 +02:00
shell : bash
run : |
set -v
2021-04-20 01:45:11 +02:00
# note: The cmake+ninja workflow requires us to set build type in both cmake commands ('cmake' and 'cmake --build'), otherwise the cryfs.exe will depend on debug versions of the visual studio c++ runtime (i.e. msvcp140d.dll)
# note: The CMAKE_SYSTEM_VERSION variable is set to 10.0.18362.0 because as of this writing, appveyor uses 10.0.17763.0 and that has a bug, see https://developercommunity.visualstudio.com/content/problem/343296/sdk-and-experimentalpreprocessor.html
# TODO CMAKE_SYSTEM_VERSION is probably not needed anymore
mkdir build
cd build
2021-08-16 05:16:59 +02:00
cmake .. -G "Visual Studio 16 2019" -DCMAKE_BUILD_TYPE=${{matrix.build_type}} -DBUILD_TESTING=on -DDOKAN_PATH="C:/Program Files/Dokan/DokanLibrary-1.3.0" -A ${{matrix.arch}} -DCMAKE_SYSTEM_VERSION="10.0.18362.0"
2021-04-20 01:45:11 +02:00
cmake --build . --config ${{matrix.build_type}}
# - name: Show ccache statistics
# shell: bash
# run: |
# set -v
# ccache -s
# - name: Reduce ccache size
# if: ${{ runner.os == 'macOS' }}
# shell: bash
# run: |
# set -v
# ccache --evict-older-than 7d
# ccache -s
# - name: Save ccache cache
# # note: this access key has write access to the cache. This can't run on PRs.
# if: ${{ github.event_name == 'push' }}
2021-08-22 17:43:46 +02:00
# # Cache things sometimes indeterministically fail (roughly 1% of times this is run), let's not fail the job for it
2021-08-22 17:51:48 +02:00
# continue-on-error: true
2021-04-20 01:45:11 +02:00
# uses: leroy-merlin-br/action-s3-cache@8d75079437b388688b9ea9c7d73dff4ef975c5fa # v1.0.5
# with:
# action: put
# aws-access-key-id: ${{ secrets.CACHE_AWS_ACCESS_KEY_ID }}
# aws-secret-access-key: ${{ secrets.CACHE_AWS_SECRET_ACCESS_KEY }}
# aws-region: eu-west-1
# bucket: ci-cache.cryfs
# key: v0-${{ runner.os }}-${{ matrix.os }}-ccache__${{matrix.compiler.cxx}}__${{matrix.compiler.cc}}__${{matrix.build_type}}__${{matrix.run_build}}__${{matrix.run_clang_tidy}}__${{steps.hash_flags.outputs.hash_flags}}__
# artifacts: ${{ github.workspace }}/.ccache
2021-04-18 00:57:32 +02:00
- name : Save conan cache
2021-04-25 21:46:56 +02:00
# note: this access key has write access to the cache. This can't run on PRs.
if : ${{ github.event_name == 'push' }}
2021-08-22 17:43:46 +02:00
# Cache things sometimes indeterministically fail (roughly 1% of times this is run), let's not fail the job for it
continue-on-error : true
2021-04-18 00:57:32 +02:00
uses : leroy-merlin-br/action-s3-cache@8d75079437b388688b9ea9c7d73dff4ef975c5fa # v1.0.5
with :
action : put
aws-access-key-id : ${{ secrets.CACHE_AWS_ACCESS_KEY_ID }}
aws-secret-access-key : ${{ secrets.CACHE_AWS_SECRET_ACCESS_KEY }}
2021-04-25 21:46:56 +02:00
aws-region : eu-west-1
bucket : ci-cache.cryfs
2022-10-13 03:16:35 +02:00
key : v3-${{ runner.os }}-${{ matrix.os }}-conancache__${{matrix.compiler.cxx}}__${{matrix.compiler.cc}}__${{matrix.build_type}}__
2021-04-20 01:45:11 +02:00
artifacts : |
${{ env.CONAN_USER_HOME }}
${{ env.CONAN_USER_HOME_SHORT }}
2021-04-18 00:57:32 +02:00
- name : Test
2021-04-20 01:45:11 +02:00
shell : bash
run : |
set -v
cd build
./test/gitversion/${{matrix.build_type}}/gitversion-test.exe
./test/cpp-utils/${{matrix.build_type}}/cpp-utils-test.exe
# ./test/fspp/${{matrix.build_type}}/fspp-test.exe
./test/parallelaccessstore/${{matrix.build_type}}/parallelaccessstore-test.exe
./test/blockstore/${{matrix.build_type}}/blockstore-test.exe
./test/blobstore/${{matrix.build_type}}/blobstore-test.exe
./test/cryfs/${{matrix.build_type}}/cryfs-test.exe
# TODO Enable cryfs-cli-test on Windows
# ./test/cryfs-cli/${{matrix.build_type}}/cryfs-cli-test.exe
- name : CPack
shell : bash
run : |
set -v
cd build
cpack -C ${{matrix.build_type}} --verbose -G WIX
- name : Upload installers as artifact
uses : actions/upload-artifact@v2
2021-04-19 03:49:59 +02:00
with :
2021-04-20 01:45:11 +02:00
name : cryfs-${{matrix.arch}}-${{matrix.build_type}}.msi
path : build/cryfs-*.msi