Merge pull request #1272 from dgreatwood/fallbackHttplibMacOSAndLinux #89
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
# SPDX-FileCopyrightText: 2022 Andrea Pappacoda | |
# | |
# SPDX-License-Identifier: Apache-2.0 | |
# See: | |
# https://docs.github.com/en/actions/writing-workflows/choosing-where-your-workflow-runs/choosing-the-runner-for-a-job | |
# https://github.com/actions/runner-images/blob/main/images/macos/macos-14-Readme.md | |
name: macOS libevent | |
on: | |
push: | |
branches: | |
- master | |
pull_request: | |
branches: | |
- master | |
defaults: | |
run: | |
shell: sh | |
concurrency: | |
group: ${{ github.workflow }}-${{ github.ref }} | |
cancel-in-progress: true | |
jobs: | |
macos: | |
name: macOS with Libevent | |
strategy: | |
fail-fast: false | |
matrix: | |
os: [ 'macos-13', 'macos-14', 'macos-15' ] | |
compiler: [ 'gcc', 'clang' ] | |
sanitizer: [ 'address', 'undefined', 'none' ] | |
tls: [ 'true', 'false' ] | |
def_debug: [ 'true', 'false' ] | |
exclude: | |
# GCC on macOS doesn't seem to have library asan or ubsan | |
- compiler: gcc | |
sanitizer: address | |
- compiler: gcc | |
sanitizer: undefined | |
runs-on: ${{ matrix.os }} | |
steps: | |
- name: Install dependencies (macOS) | |
if: contains(matrix.os, 'macos') | |
run: | | |
# Avoid doing "brew update" - the brew formulas that are | |
# preinstalled on the github runner image are likely | |
# consistent with the pre-installed software on the image. If | |
# we do "brew update", and then install something new with | |
# brew, and the "something new" depends on pre-installed | |
# software on the image, and there are new versions of the | |
# pre-installed software revealed by doing "brew update", then | |
# when we install the "something new" brew may try and also | |
# install a new version of the pre-installed software on which | |
# the "something new" depends, but that attempt to install a | |
# new version of the pre-installed software can fail as a | |
# result of being blocked by the software that is already | |
# installed. | |
if ! type "meson" > /dev/null; then brew install meson --overwrite; fi | |
brew install lcov | |
brew install --quiet --cask doxygen | |
if [ ${{ matrix.compiler }} != gcc ]; then | |
brew install googletest | |
fi | |
# brew install openssl # Already installed in base image | |
brew install rapidjson | |
# brew install libevent # Already installed in base image | |
brew install howard-hinnant-date | |
if ! brew list brotli &>/dev/null; then brew install brotli; fi | |
if ! brew list zstd &>/dev/null; then brew install zstd; fi | |
- uses: actions/checkout@v4 | |
with: | |
submodules: true | |
- name: Configure Meson | |
run: | | |
if [ ${{ matrix.compiler }} = gcc ]; then | |
source bldscripts/gccmacsetup.sh -y | |
else | |
export CXX=clang++ | |
export CC=CXX | |
fi | |
echo "Using CXX $CXX, and CC $CC" | |
meson setup build \ | |
-DPISTACHE_BUILD_TESTS=true -DPISTACHE_DEBUG=${{ matrix.def_debug }} -DPISTACHE_USE_SSL=${{ matrix.tls }} -DPISTACHE_BUILD_EXAMPLES=true -DPISTACHE_BUILD_DOCS=false -DPISTACHE_USE_CONTENT_ENCODING_DEFLATE=true -DPISTACHE_USE_CONTENT_ENCODING_BROTLI=true -DPISTACHE_USE_CONTENT_ENCODING_ZSTD=true \ | |
--buildtype=debug -Db_coverage=true -Db_sanitize=${{ matrix.sanitizer }} -Db_lundef=false \ | |
|| (cat build/meson-logs/meson-log.txt ; false) | |
env: | |
CC: ${{ matrix.compiler }} | |
- name: Build | |
run: ninja -C build | |
- name: Test | |
run: meson test -C build --verbose | |
# Use the following to run just a single test (e.g. http_server_test) | |
# run: build/tests/run_http_server_test | |
- name: Coverage | |
if: ${{ !contains(matrix.os, 'macos') }} # Remove this if to do coverage test | |
run: | | |
xcspath=$(xcode-select -p) | |
llvmcovpath=$(find $xcspath -name llvm-cov) | |
llvmcovpathparent=$( dirname "$llvmcovpath" ) | |
echo "For llvm-cov, using path $llvmcovpathparent" | |
export PATH=$PATH:$llvmcovpathparent | |
llvm-cov --version | |
mkdir -p $HOME/.local/bin | |
if [ "${{ matrix.compiler }}" = 'clang' ]; then printf 'llvm-cov gcov "$@"' > $HOME/.local/bin/cov.sh; else printf 'gcov "$@"' > $HOME/.local/bin/cov.sh; fi && chmod +x $HOME/.local/bin/cov.sh | |
lcov --capture --ignore-errors unused --ignore-errors inconsistent --ignore-errors unused,unused --ignore-errors inconsistent,inconsistent --ignore-errors usage,usage --ignore-errors gcov,gcov --output-file coverage.info --directory . --gcov-tool $HOME/.local/bin/cov.sh --exclude '/usr/*' --exclude "${HOME}"'/.cache/*' --exclude '*/tests/*' --exclude '*/subprojects/*' | |
# Possible add: --exclude "$xcspath/*" --exclude "$HOMEBREW_PREFIX/*" | |
lcov --list coverage.info | |
brew install gnupg # for gpgv | |
curl https://keybase.io/codecovsecurity/pgp_keys.asc | gpg --no-default-keyring --keyring trustedkeys.gpg --import | |
curl --silent --remote-name https://uploader.codecov.io/latest/macos/codecov | |
curl --silent --remote-name https://uploader.codecov.io/latest/macos/codecov.SHA256SUM | |
curl --silent --remote-name https://uploader.codecov.io/latest/macos/codecov.SHA256SUM.sig | |
gpgv codecov.SHA256SUM.sig codecov.SHA256SUM | |
sha256sum --check codecov.SHA256SUM | |
chmod +x codecov | |
./codecov |