Nightly Build #218
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
# Nightly build for the main branch across multiple targets. | |
name: Nightly Build | |
on: | |
workflow_dispatch: | |
schedule: | |
- cron: '15 1 * * *' | |
env: | |
docker-registry: ghcr.io | |
docker-config-path: source/ci/docker | |
jobs: | |
# Run our nightly builds. We build a matrix with the various build | |
# targets and their details. Then we build either in a docker container | |
# (Linux) or on the actual hosts (macOS, Windows). | |
build: | |
# Only run scheduled workflows on the main repository; prevents people | |
# from using build minutes on their forks. | |
if: github.repository == 'libgit2/libgit2' | |
strategy: | |
matrix: | |
platform: | |
- name: Linux (Xenial, GCC, OpenSSL) | |
container: | |
name: xenial | |
env: | |
CC: gcc | |
CMAKE_GENERATOR: Ninja | |
CMAKE_OPTIONS: -DUSE_HTTPS=OpenSSL -DREGEX_BACKEND=builtin -DDEPRECATE_HARD=ON -DUSE_LEAK_CHECKER=valgrind -DUSE_GSSAPI=ON -DUSE_SSH=ON | |
os: ubuntu-latest | |
- name: "Linux (Xenial, GCC, mbedTLS)" | |
container: | |
name: xenial | |
env: | |
CC: gcc | |
CMAKE_GENERATOR: Ninja | |
CMAKE_OPTIONS: -DUSE_HTTPS=mbedTLS -DUSE_SHA1=HTTPS -DDEPRECATE_HARD=ON -DUSE_LEAK_CHECKER=valgrind -DUSE_GSSAPI=ON -DUSE_SSH=ON | |
os: ubuntu-latest | |
- name: "Linux (Xenial, Clang, OpenSSL)" | |
container: | |
name: xenial | |
env: | |
CC: clang | |
CMAKE_GENERATOR: Ninja | |
CMAKE_OPTIONS: -DUSE_HTTPS=OpenSSL -DDEPRECATE_HARD=ON -DUSE_LEAK_CHECKER=valgrind -DUSE_GSSAPI=ON -DUSE_SSH=ON | |
os: ubuntu-latest | |
- name: "Linux (Xenial, Clang, mbedTLS)" | |
container: | |
name: xenial | |
env: | |
CC: clang | |
CMAKE_OPTIONS: -DUSE_HTTPS=mbedTLS -DUSE_SHA1=HTTPS -DREGEX_BACKEND=pcre -DDEPRECATE_HARD=ON -DUSE_LEAK_CHECKER=valgrind -DUSE_GSSAPI=ON -DUSE_SSH=ON | |
CMAKE_GENERATOR: Ninja | |
os: ubuntu-latest | |
- name: "Linux (no threads)" | |
container: | |
name: xenial | |
env: | |
CC: gcc | |
CMAKE_OPTIONS: -DTHREADSAFE=OFF -DDEPRECATE_HARD=ON -DUSE_LEAK_CHECKER=valgrind -DUSE_GSSAPI=ON -DUSE_SSH=ON | |
CMAKE_GENERATOR: Ninja | |
os: ubuntu-latest | |
- name: "Linux (dynamically-loaded OpenSSL)" | |
container: | |
name: xenial | |
env: | |
CC: clang | |
CMAKE_OPTIONS: -DUSE_HTTPS=OpenSSL-Dynamic -DDEPRECATE_HARD=ON -DUSE_LEAK_CHECKER=valgrind -DUSE_GSSAPI=ON -DUSE_SSH=ON | |
CMAKE_GENERATOR: Ninja | |
os: ubuntu-latest | |
- name: "Linux (MemorySanitizer)" | |
container: | |
name: focal | |
env: | |
CC: clang-10 | |
CFLAGS: -fsanitize=memory -fsanitize-memory-track-origins=2 -fsanitize-blacklist=/home/libgit2/source/script/sanitizers.supp -fno-optimize-sibling-calls -fno-omit-frame-pointer | |
CMAKE_OPTIONS: -DCMAKE_PREFIX_PATH=/usr/local/msan -DUSE_HTTPS=mbedTLS -DUSE_SHA1=HTTPS -DREGEX_BACKEND=pcre -DDEPRECATE_HARD=ON -DUSE_BUNDLED_ZLIB=ON -DUSE_SSH=ON | |
CMAKE_GENERATOR: Ninja | |
SKIP_SSH_TESTS: true | |
SKIP_NEGOTIATE_TESTS: true | |
ASAN_SYMBOLIZER_PATH: /usr/bin/llvm-symbolizer-10 | |
UBSAN_OPTIONS: print_stacktrace=1 | |
os: ubuntu-latest | |
- name: "Linux (UndefinedBehaviorSanitizer)" | |
container: | |
name: focal | |
env: | |
CC: clang-10 | |
CFLAGS: -fsanitize=undefined,nullability -fno-sanitize-recover=undefined,nullability -fsanitize-blacklist=/home/libgit2/source/script/sanitizers.supp -fno-optimize-sibling-calls -fno-omit-frame-pointer | |
CMAKE_OPTIONS: -DCMAKE_PREFIX_PATH=/usr/local -DUSE_HTTPS=OpenSSL -DUSE_SHA1=HTTPS -DREGEX_BACKEND=pcre -DDEPRECATE_HARD=ON -DUSE_BUNDLED_ZLIB=ON | |
CMAKE_GENERATOR: Ninja | |
SKIP_SSH_TESTS: true | |
SKIP_NEGOTIATE_TESTS: true | |
ASAN_SYMBOLIZER_PATH: /usr/bin/llvm-symbolizer-10 | |
os: ubuntu-latest | |
- name: "Linux (ThreadSanitizer)" | |
container: | |
name: focal | |
env: | |
CC: clang-10 | |
CFLAGS: -fsanitize=thread -fno-optimize-sibling-calls -fno-omit-frame-pointer | |
CMAKE_OPTIONS: -DCMAKE_PREFIX_PATH=/usr/local -DUSE_HTTPS=OpenSSL -DUSE_SHA1=HTTPS -DREGEX_BACKEND=pcre -DDEPRECATE_HARD=ON -DUSE_BUNDLED_ZLIB=ON | |
CMAKE_GENERATOR: Ninja | |
SKIP_SSH_TESTS: true | |
SKIP_NEGOTIATE_TESTS: true | |
ASAN_SYMBOLIZER_PATH: /usr/bin/llvm-symbolizer-10 | |
TSAN_OPTIONS: suppressions=/home/libgit2/source/script/thread-sanitizer.supp second_deadlock_stack=1 | |
os: ubuntu-latest | |
- name: "Linux (no mmap)" | |
container: | |
name: focal | |
env: | |
CC: clang-10 | |
CFLAGS: -DNO_MMAP | |
CMAKE_OPTIONS: -DCMAKE_PREFIX_PATH=/usr/local | |
CMAKE_GENERATOR: Ninja | |
SKIP_SSH_TESTS: true | |
SKIP_NEGOTIATE_TESTS: true | |
os: ubuntu-latest | |
- name: "Linux (CentOS 7)" | |
container: | |
name: centos7 | |
env: | |
CMAKE_OPTIONS: -DDEPRECATE_HARD=ON -DUSE_LEAK_CHECKER=valgrind -DUSE_GSSAPI=ON -DUSE_SSH=ON | |
PKG_CONFIG_PATH: /usr/local/lib/pkgconfig | |
SKIP_NEGOTIATE_TESTS: true | |
os: ubuntu-latest | |
- name: "Linux (CentOS 7, dynamically-loaded OpenSSL)" | |
container: | |
name: centos7 | |
env: | |
CMAKE_OPTIONS: -DUSE_HTTPS=OpenSSL-Dynamic -DDEPRECATE_HARD=ON -DUSE_LEAK_CHECKER=valgrind -DUSE_GSSAPI=ON -DUSE_SSH=ON | |
PKG_CONFIG_PATH: /usr/local/lib/pkgconfig | |
SKIP_NEGOTIATE_TESTS: true | |
os: ubuntu-latest | |
- name: "Linux (CentOS 8)" | |
container: | |
name: centos8 | |
env: | |
CMAKE_OPTIONS: -DDEPRECATE_HARD=ON -DUSE_LEAK_CHECKER=valgrind -DUSE_GSSAPI=ON | |
PKG_CONFIG_PATH: /usr/local/lib/pkgconfig | |
SKIP_NEGOTIATE_TESTS: true | |
SKIP_SSH_TESTS: true | |
os: ubuntu-latest | |
- name: "Linux (CentOS 8, dynamically-loaded OpenSSL)" | |
container: | |
name: centos8 | |
env: | |
CMAKE_OPTIONS: -DUSE_HTTPS=OpenSSL-Dynamic -DDEPRECATE_HARD=ON -DUSE_LEAK_CHECKER=valgrind -DUSE_GSSAPI=ON | |
PKG_CONFIG_PATH: /usr/local/lib/pkgconfig | |
SKIP_NEGOTIATE_TESTS: true | |
SKIP_SSH_TESTS: true | |
os: ubuntu-latest | |
- name: "macOS" | |
os: macos-12 | |
env: | |
CC: clang | |
CMAKE_OPTIONS: -DREGEX_BACKEND=regcomp_l -DDEPRECATE_HARD=ON -DUSE_LEAK_CHECKER=leaks -DUSE_GSSAPI=ON | |
PKG_CONFIG_PATH: /usr/local/opt/openssl/lib/pkgconfig | |
SKIP_SSH_TESTS: true | |
SKIP_NEGOTIATE_TESTS: true | |
setup-script: osx | |
- name: "Windows (amd64, Visual Studio, WinHTTP)" | |
os: windows-2019 | |
env: | |
ARCH: amd64 | |
CMAKE_GENERATOR: Visual Studio 16 2019 | |
CMAKE_OPTIONS: -A x64 -DWIN32_LEAKCHECK=ON -DDEPRECATE_HARD=ON -DUSE_HTTPS=WinHTTP | |
SKIP_SSH_TESTS: true | |
SKIP_NEGOTIATE_TESTS: true | |
- name: "Windows (x86, Visual Studio, WinHTTP)" | |
os: windows-2019 | |
env: | |
ARCH: x86 | |
CMAKE_GENERATOR: Visual Studio 16 2019 | |
CMAKE_OPTIONS: -A Win32 -DWIN32_LEAKCHECK=ON -DDEPRECATE_HARD=ON -DUSE_HTTPS=WinHTTP -DUSE_SHA1=HTTPS -DUSE_BUNDLED_ZLIB=ON | |
SKIP_SSH_TESTS: true | |
SKIP_NEGOTIATE_TESTS: true | |
- name: "Windows (amd64, Visual Studio, Schannel)" | |
os: windows-2019 | |
env: | |
ARCH: amd64 | |
CMAKE_GENERATOR: Visual Studio 16 2019 | |
CMAKE_OPTIONS: -A x64 -DWIN32_LEAKCHECK=ON -DDEPRECATE_HARD=ON -DUSE_HTTPS=Schannel | |
SKIP_SSH_TESTS: true | |
SKIP_NEGOTIATE_TESTS: true | |
- name: "Windows (x86, Visual Studio, Schannel)" | |
os: windows-2019 | |
env: | |
ARCH: x86 | |
CMAKE_GENERATOR: Visual Studio 16 2019 | |
CMAKE_OPTIONS: -A Win32 -DWIN32_LEAKCHECK=ON -DDEPRECATE_HARD=ON -DUSE_HTTPS=Schannel -DUSE_BUNDLED_ZLIB=ON | |
SKIP_SSH_TESTS: true | |
SKIP_NEGOTIATE_TESTS: true | |
- name: "Windows (amd64, mingw, WinHTTP)" | |
os: windows-2019 | |
setup-script: mingw | |
env: | |
ARCH: amd64 | |
CMAKE_GENERATOR: MinGW Makefiles | |
CMAKE_OPTIONS: -DDEPRECATE_HARD=ON | |
BUILD_TEMP: D:\Temp | |
BUILD_PATH: D:\Temp\mingw64\bin;C:\Windows\system32;C:\Windows;C:\Windows\System32\Wbem;C:\Program Files (x86)\CMake\bin | |
SKIP_SSH_TESTS: true | |
SKIP_NEGOTIATE_TESTS: true | |
- name: "Windows (x86, mingw, Schannel)" | |
os: windows-2019 | |
setup-script: mingw | |
env: | |
ARCH: x86 | |
CMAKE_GENERATOR: MinGW Makefiles | |
CMAKE_OPTIONS: -DDEPRECATE_HARD=ON -DUSE_HTTPS=Schannel | |
BUILD_TEMP: D:\Temp | |
BUILD_PATH: D:\Temp\mingw32\bin;C:\Windows\system32;C:\Windows;C:\Windows\System32\Wbem;C:\Program Files (x86)\CMake\bin | |
SKIP_SSH_TESTS: true | |
SKIP_NEGOTIATE_TESTS: true | |
- name: "Windows (no mmap)" | |
os: windows-2019 | |
env: | |
ARCH: amd64 | |
CMAKE_GENERATOR: Visual Studio 16 2019 | |
CFLAGS: -DNO_MMAP | |
CMAKE_OPTIONS: -A x64 -DDEPRECATE_HARD=ON | |
SKIP_SSH_TESTS: true | |
SKIP_NEGOTIATE_TESTS: true | |
- name: "Linux (Bionic, GCC, dynamically-loaded OpenSSL)" | |
container: | |
name: bionic | |
dockerfile: bionic | |
env: | |
CC: gcc | |
CMAKE_GENERATOR: Ninja | |
CMAKE_OPTIONS: -DUSE_HTTPS=OpenSSL-Dynamic -DDEPRECATE_HARD=ON -DUSE_LEAK_CHECKER=valgrind -DUSE_GSSAPI=ON -DUSE_SSH=ON | |
RUN_INVASIVE_TESTS: true | |
os: ubuntu-latest | |
- name: "Linux (x86, Bionic, Clang, OpenSSL)" | |
container: | |
name: bionic-x86 | |
dockerfile: bionic | |
qemu: true | |
env: | |
CC: clang | |
CMAKE_GENERATOR: Ninja | |
CMAKE_OPTIONS: -DUSE_HTTPS=OpenSSL -DDEPRECATE_HARD=ON -DUSE_LEAK_CHECKER=valgrind -DUSE_GSSAPI=ON -DUSE_SSH=ON | |
RUN_INVASIVE_TESTS: true | |
os: ubuntu-latest | |
- name: "Linux (x86, Bionic, GCC, OpenSSL)" | |
container: | |
name: bionic-x86 | |
dockerfile: bionic | |
env: | |
CC: gcc | |
CMAKE_GENERATOR: Ninja | |
CMAKE_OPTIONS: -DUSE_HTTPS=OpenSSL -DDEPRECATE_HARD=ON -DUSE_LEAK_CHECKER=valgrind -DUSE_GSSAPI=ON -DUSE_SSH=ON | |
RUN_INVASIVE_TESTS: true | |
os: ubuntu-latest | |
- name: "Linux (arm32, Bionic, GCC, OpenSSL)" | |
container: | |
name: bionic-arm32 | |
dockerfile: bionic | |
qemu: true | |
env: | |
CC: gcc | |
CMAKE_GENERATOR: Ninja | |
CMAKE_OPTIONS: -DUSE_HTTPS=OpenSSL -DDEPRECATE_HARD=ON -DUSE_GSSAPI=ON -DUSE_SSH=ON | |
RUN_INVASIVE_TESTS: true | |
SKIP_PROXY_TESTS: true | |
GITTEST_FLAKY_STAT: true | |
os: ubuntu-latest | |
- name: "Linux (arm64, Bionic, GCC, OpenSSL)" | |
container: | |
name: bionic-arm64 | |
dockerfile: bionic | |
qemu: true | |
env: | |
CC: gcc | |
CMAKE_GENERATOR: Ninja | |
CMAKE_OPTIONS: -DUSE_HTTPS=OpenSSL -DDEPRECATE_HARD=ON -DUSE_GSSAPI=ON -DUSE_SSH=ON | |
RUN_INVASIVE_TESTS: true | |
SKIP_PROXY_TESTS: true | |
os: ubuntu-latest | |
# Experimental: SHA256 support | |
- name: "Linux (SHA256, Xenial, Clang, OpenSSL)" | |
id: xenial-clang-openssl | |
container: | |
name: xenial | |
env: | |
CC: clang | |
CMAKE_GENERATOR: Ninja | |
CMAKE_OPTIONS: -DUSE_HTTPS=OpenSSL -DDEPRECATE_HARD=ON -DUSE_LEAK_CHECKER=valgrind -DUSE_GSSAPI=ON -DUSE_SSH=ON | |
os: ubuntu-latest | |
- name: "macOS (SHA256)" | |
id: macos | |
os: macos-12 | |
env: | |
CC: clang | |
CMAKE_OPTIONS: -DREGEX_BACKEND=regcomp_l -DDEPRECATE_HARD=ON -DUSE_LEAK_CHECKER=leaks -DUSE_GSSAPI=ON -DEXPERIMENTAL_SHA256=ON | |
PKG_CONFIG_PATH: /usr/local/opt/openssl/lib/pkgconfig | |
SKIP_SSH_TESTS: true | |
SKIP_NEGOTIATE_TESTS: true | |
setup-script: osx | |
- name: "Windows (SHA256, amd64, Visual Studio)" | |
id: windows-amd64-vs | |
os: windows-2019 | |
env: | |
ARCH: amd64 | |
CMAKE_GENERATOR: Visual Studio 16 2019 | |
CMAKE_OPTIONS: -A x64 -DWIN32_LEAKCHECK=ON -DDEPRECATE_HARD=ON -DEXPERIMENTAL_SHA256=ON | |
SKIP_SSH_TESTS: true | |
SKIP_NEGOTIATE_TESTS: true | |
fail-fast: false | |
env: ${{ matrix.platform.env }} | |
runs-on: ${{ matrix.platform.os }} | |
name: "Build ${{ matrix.platform.name }}" | |
steps: | |
- name: Check out repository | |
uses: actions/checkout@v3 | |
with: | |
path: source | |
fetch-depth: 0 | |
- name: Set up build environment | |
run: source/ci/setup-${{ matrix.platform.setup-script }}-build.sh | |
shell: bash | |
if: matrix.platform.setup-script != '' | |
- name: Setup QEMU | |
run: docker run --rm --privileged multiarch/qemu-user-static:register --reset | |
if: matrix.platform.container.qemu == true | |
- name: Download container | |
run: | | |
"${{ github.workspace }}/source/ci/getcontainer.sh" "${{ matrix.platform.container.name }}" "${{ matrix.platform.container.dockerfile }}" | |
env: | |
DOCKER_REGISTRY: ${{ env.docker-registry }} | |
GITHUB_TOKEN: ${{ secrets.github_token }} | |
working-directory: ${{ env.docker-config-path }} | |
if: matrix.platform.container.name != '' | |
- name: Create container | |
run: docker build -t ${{ env.docker-registry-container-sha }} -f ${{ env.dockerfile }} . | |
working-directory: ${{ env.docker-config-path }} | |
if: matrix.platform.container.name != '' && env.docker-container-exists != 'true' | |
- name: Prepare build | |
run: mkdir build | |
- name: Build | |
uses: ./source/.github/actions/run-build | |
with: | |
command: cd build && ../source/ci/build.sh | |
container: ${{ matrix.platform.container.name }} | |
container-version: ${{ env.docker-registry-container-sha }} | |
- name: Test | |
uses: ./source/.github/actions/run-build | |
with: | |
command: cd build && ../source/ci/test.sh | |
container: ${{ matrix.platform.container.name }} | |
container-version: ${{ env.docker-registry-container-sha }} | |
coverity: | |
# Only run scheduled workflows on the main repository; prevents people | |
# from using build minutes on their forks. | |
if: github.repository == 'libgit2/libgit2' | |
name: Coverity | |
runs-on: ubuntu-latest | |
steps: | |
- name: Check out repository | |
uses: actions/checkout@v3 | |
with: | |
path: source | |
fetch-depth: 0 | |
- name: Download container | |
run: | | |
"${{ github.workspace }}/source/ci/getcontainer.sh" xenial | |
env: | |
DOCKER_REGISTRY: ${{ env.docker-registry }} | |
GITHUB_TOKEN: ${{ secrets.github_token }} | |
working-directory: ${{ env.docker-config-path }} | |
- name: Run Coverity | |
run: source/ci/coverity.sh | |
env: | |
COVERITY_TOKEN: ${{ secrets.coverity_token }} | |
codeql: | |
# Only run scheduled workflows on the main repository; prevents people | |
# from using build minutes on their forks. | |
if: github.repository == 'libgit2/libgit2' | |
name: CodeQL | |
runs-on: ubuntu-latest | |
steps: | |
- name: Check out repository | |
uses: actions/checkout@v3 | |
with: | |
fetch-depth: 0 | |
# Initializes the CodeQL tools for scanning. | |
- name: Initialize CodeQL | |
uses: github/codeql-action/init@v2 | |
with: | |
languages: 'cpp' | |
- name: Build | |
run: | | |
mkdir build | |
cd build | |
cmake .. -DREGEX_BACKEND=pcre -DDEPRECATE_HARD=ON -DUSE_BUNDLED_ZLIB=ON | |
cmake --build . | |
- name: Perform CodeQL Analysis | |
uses: github/codeql-action/analyze@v2 |