mirror of
https://github.com/libgit2/libgit2.git
synced 2026-01-25 02:56:17 +00:00
Some minor refactoring for iOS: - Roll back clar changes; these should be a bit more measured, and occur in clar upstream. - Move iOS to nightly builds
497 lines
19 KiB
YAML
497 lines
19 KiB
YAML
# 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: ci/docker
|
|
|
|
permissions:
|
|
contents: read
|
|
packages: write
|
|
|
|
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:
|
|
# All builds: core platforms
|
|
- name: "Linux (Noble, GCC, OpenSSL, libssh2)"
|
|
id: noble-gcc-openssl
|
|
os: ubuntu-latest
|
|
container:
|
|
name: noble
|
|
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=libssh2 -DDEBUG_STRICT_ALLOC=ON -DDEBUG_STRICT_OPEN=ON
|
|
- name: "Linux (Noble, Clang, mbedTLS, OpenSSH)"
|
|
id: noble-clang-mbedtls
|
|
os: ubuntu-latest
|
|
container:
|
|
name: noble
|
|
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=exec
|
|
CMAKE_GENERATOR: Ninja
|
|
- name: "Linux (Xenial, GCC, OpenSSL, OpenSSH)"
|
|
id: xenial-gcc-openssl
|
|
os: ubuntu-latest
|
|
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=exec -DDEBUG_STRICT_ALLOC=ON -DDEBUG_STRICT_OPEN=ON
|
|
- name: "Linux (Xenial, Clang, mbedTLS, libssh2)"
|
|
id: xenial-gcc-mbedtls
|
|
os: ubuntu-latest
|
|
container:
|
|
name: xenial
|
|
env:
|
|
CC: clang
|
|
CMAKE_GENERATOR: Ninja
|
|
CMAKE_OPTIONS: -DUSE_HTTPS=mbedTLS -DUSE_SHA1=HTTPS -DDEPRECATE_HARD=ON -DUSE_LEAK_CHECKER=valgrind -DUSE_GSSAPI=ON -DUSE_SSH=libssh2
|
|
- name: "macOS"
|
|
id: macos
|
|
os: macos-12
|
|
setup-script: osx
|
|
env:
|
|
CC: clang
|
|
CMAKE_OPTIONS: -DREGEX_BACKEND=regcomp_l -DDEPRECATE_HARD=ON -DUSE_LEAK_CHECKER=leaks -DUSE_GSSAPI=ON
|
|
CMAKE_GENERATOR: Ninja
|
|
PKG_CONFIG_PATH: /usr/local/opt/openssl/lib/pkgconfig
|
|
SKIP_SSH_TESTS: true
|
|
SKIP_NEGOTIATE_TESTS: true
|
|
- name: "iOS"
|
|
id: ios
|
|
os: macos-12
|
|
setup-script: ios
|
|
env:
|
|
CC: clang
|
|
CMAKE_OPTIONS: -DBUILD_TESTS=OFF -DDEPRECATE_HARD=ON -DUSE_LEAK_CHECKER=leaks -DUSE_GSSAPI=ON -DCMAKE_TOOLCHAIN_FILE=../ios.toolchain.cmake -DCMAKE_SYSTEM_NAME=iOS -DPLATFORM=OS64
|
|
CMAKE_GENERATOR: Ninja
|
|
PKG_CONFIG_PATH: /usr/local/opt/openssl/lib/pkgconfig
|
|
SKIP_TESTS: true # Cannot exec iOS app on macOS
|
|
- name: "Windows (amd64, Visual Studio, Schannel)"
|
|
id: windows-amd64-vs
|
|
os: windows-2019
|
|
setup-script: win32
|
|
env:
|
|
ARCH: amd64
|
|
CMAKE_GENERATOR: Visual Studio 16 2019
|
|
CMAKE_OPTIONS: -A x64 -DWIN32_LEAKCHECK=ON -DDEPRECATE_HARD=ON -DUSE_HTTPS=Schannel -DUSE_SSH=ON -DCMAKE_PREFIX_PATH=D:\Temp\libssh2
|
|
BUILD_PATH: C:\Windows\system32;C:\Windows;C:\Windows\System32\Wbem;C:\Program Files (x86)\CMake\bin;D:\Temp\libssh2\bin
|
|
BUILD_TEMP: D:\Temp
|
|
SKIP_SSH_TESTS: true
|
|
SKIP_NEGOTIATE_TESTS: true
|
|
- name: "Windows (x86, Visual Studio, WinHTTP)"
|
|
id: windows-x86-vs
|
|
os: windows-2019
|
|
setup-script: win32
|
|
env:
|
|
ARCH: x86
|
|
CMAKE_GENERATOR: Visual Studio 16 2019
|
|
CMAKE_OPTIONS: -A Win32 -DWIN32_LEAKCHECK=ON -DDEPRECATE_HARD=ON -DUSE_SHA1=HTTPS -DUSE_BUNDLED_ZLIB=ON -DUSE_SSH=ON -DCMAKE_PREFIX_PATH=D:\Temp\libssh2
|
|
BUILD_PATH: C:\Windows\system32;C:\Windows;C:\Windows\System32\Wbem;C:\Program Files (x86)\CMake\bin;D:\Temp\libssh2\bin
|
|
BUILD_TEMP: D:\Temp
|
|
SKIP_SSH_TESTS: true
|
|
SKIP_NEGOTIATE_TESTS: true
|
|
- name: "Windows (amd64, mingw, WinHTTP)"
|
|
id: windows-amd64-mingw
|
|
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)"
|
|
id: windows-x86-mingw
|
|
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
|
|
|
|
# All builds: sanitizers
|
|
- name: "Sanitizer (Memory)"
|
|
id: memorysanitizer
|
|
os: ubuntu-latest
|
|
setup-script: sanitizer
|
|
container:
|
|
name: noble
|
|
env:
|
|
CC: clang-17
|
|
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
|
|
- name: "Sanitizer (UndefinedBehavior)"
|
|
id: ubsanitizer
|
|
os: ubuntu-latest
|
|
setup-script: sanitizer
|
|
container:
|
|
name: noble
|
|
env:
|
|
CC: clang-17
|
|
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 -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
|
|
- name: "Sanitizer (Thread)"
|
|
id: threadsanitizer
|
|
os: ubuntu-latest
|
|
setup-script: sanitizer
|
|
container:
|
|
name: noble
|
|
env:
|
|
CC: clang-17
|
|
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 -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
|
|
TSAN_OPTIONS: suppressions=/home/libgit2/source/script/thread-sanitizer.supp second_deadlock_stack=1
|
|
|
|
# Nightly builds: extended platforms
|
|
- name: "Linux (CentOS 7, OpenSSL)"
|
|
id: centos7-openssl
|
|
os: ubuntu-latest
|
|
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
|
|
SKIP_PUSHOPTIONS_TESTS: true
|
|
- name: "Linux (CentOS 7, dynamically-loaded OpenSSL)"
|
|
id: centos7-dynamicopenssl
|
|
os: ubuntu-latest
|
|
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
|
|
SKIP_PUSHOPTIONS_TESTS: true
|
|
- name: "Linux (CentOS 8, OpenSSL)"
|
|
id: centos8-openssl
|
|
os: ubuntu-latest
|
|
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
|
|
- name: "Linux (CentOS 8, dynamically-loaded OpenSSL)"
|
|
id: centos8-dynamicopenssl
|
|
os: ubuntu-latest
|
|
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
|
|
ARCH: x86
|
|
- name: "Linux (Fedora, llhttp)"
|
|
id: fedora
|
|
os: ubuntu-latest
|
|
container:
|
|
name: fedora
|
|
env:
|
|
CC: gcc
|
|
CMAKE_GENERATOR: Ninja
|
|
CMAKE_OPTIONS: -DUSE_HTTPS=OpenSSL -DREGEX_BACKEND=pcre2 -DDEPRECATE_HARD=ON -DUSE_LEAK_CHECKER=valgrind -DUSE_GSSAPI=ON -DUSE_SSH=libssh2 -DUSE_HTTP_PARSER=llhttp
|
|
- name: "Linux (Bionic, GCC, dynamically-loaded OpenSSL)"
|
|
id: bionic-gcc-dynamicopenssl
|
|
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
|
|
SKIP_PUSHOPTIONS_TESTS: true
|
|
os: ubuntu-latest
|
|
- name: "Linux (x86, Bionic, Clang, OpenSSL)"
|
|
id: bionic-x86-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
|
|
SKIP_PUSHOPTIONS_TESTS: true
|
|
os: ubuntu-latest
|
|
- name: "Linux (x86, Bionic, GCC, OpenSSL)"
|
|
id: bionic-x86-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
|
|
SKIP_PUSHOPTIONS_TESTS: true
|
|
os: ubuntu-latest
|
|
- name: "Linux (arm32, Bionic, GCC, OpenSSL)"
|
|
id: bionic-arm32-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
|
|
SKIP_PUSHOPTIONS_TESTS: true
|
|
GITTEST_FLAKY_STAT: true
|
|
os: ubuntu-latest
|
|
- name: "Linux (arm64, Bionic, GCC, OpenSSL)"
|
|
id: bionic-arm64-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
|
|
SKIP_PUSHOPTIONS_TESTS: true
|
|
os: ubuntu-latest
|
|
|
|
# Nightly builds: ensure we fallback when missing core functionality
|
|
- name: "Linux (no threads)"
|
|
id: xenial-nothreads
|
|
os: ubuntu-latest
|
|
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
|
|
SKIP_PUSHOPTIONS_TESTS: true
|
|
- name: "Linux (no mmap)"
|
|
id: noble-nommap
|
|
os: ubuntu-latest
|
|
container:
|
|
name: noble
|
|
env:
|
|
CC: gcc
|
|
CFLAGS: -DNO_MMAP
|
|
CMAKE_OPTIONS: -DCMAKE_PREFIX_PATH=/usr/local
|
|
CMAKE_GENERATOR: Ninja
|
|
SKIP_SSH_TESTS: true
|
|
SKIP_NEGOTIATE_TESTS: true
|
|
- name: "Windows (no mmap)"
|
|
id: windows-nommap
|
|
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
|
|
|
|
# Nightly builds: extended SSL support
|
|
- name: "Linux (dynamically-loaded OpenSSL)"
|
|
id: xenial-dynamicopenssl
|
|
os: ubuntu-latest
|
|
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
|
|
|
|
# All builds: experimental SHA256 support
|
|
- name: "Linux (SHA256, Xenial, Clang, OpenSSL)"
|
|
id: linux-sha256
|
|
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-sha256
|
|
os: macos-12
|
|
setup-script: osx
|
|
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
|
|
- name: "Windows (SHA256, amd64, Visual Studio)"
|
|
id: windows-sha256
|
|
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@v4
|
|
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: Set up container
|
|
uses: ./source/.github/actions/download-or-build-container
|
|
with:
|
|
registry: ${{ env.docker-registry }}
|
|
config-path: ${{ env.docker-config-path }}
|
|
container: ${{ matrix.platform.container.name }}
|
|
github_token: ${{ secrets.github_token }}
|
|
dockerfile: ${{ matrix.platform.container.dockerfile }}
|
|
if: matrix.platform.container.name != ''
|
|
- name: Prepare build
|
|
run: mkdir build
|
|
- name: Build
|
|
uses: ./source/.github/actions/run-build
|
|
with:
|
|
command: cd ${BUILD_WORKSPACE:-.}/build && ../source/ci/build.sh
|
|
container: ${{ matrix.platform.container.name }}
|
|
container-version: ${{ env.docker-registry-container-sha }}
|
|
shell: ${{ matrix.platform.shell }}
|
|
- name: Test
|
|
uses: ./source/.github/actions/run-build
|
|
with:
|
|
command: cd ${BUILD_WORKSPACE:-.}/build && ../source/ci/test.sh
|
|
container: ${{ matrix.platform.container.name }}
|
|
container-version: ${{ env.docker-registry-container-sha }}
|
|
shell: ${{ matrix.platform.shell }}
|
|
- name: Upload test results
|
|
uses: actions/upload-artifact@v4
|
|
if: success() || failure()
|
|
with:
|
|
name: test-results-${{ matrix.platform.id }}
|
|
path: build/results_*.xml
|
|
|
|
test_results:
|
|
name: Test results
|
|
needs: [ build ]
|
|
if: ${{ always() && github.repository == 'libgit2/libgit2' }}
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- name: Download test results
|
|
uses: actions/download-artifact@v3
|
|
- name: Generate test summary
|
|
uses: test-summary/action@v2
|
|
with:
|
|
paths: 'test-results-*/*.xml'
|
|
|
|
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@v4
|
|
with:
|
|
path: source
|
|
fetch-depth: 0
|
|
- name: Set up container
|
|
uses: ./source/.github/actions/download-or-build-container
|
|
with:
|
|
registry: ${{ env.docker-registry }}
|
|
config-path: ${{ env.docker-config-path }}
|
|
container: xenial
|
|
github_token: ${{ secrets.github_token }}
|
|
if: matrix.platform.container.name != ''
|
|
- 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'
|
|
|
|
permissions:
|
|
actions: read
|
|
contents: read
|
|
security-events: write
|
|
|
|
name: CodeQL
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- name: Check out repository
|
|
uses: actions/checkout@v4
|
|
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
|