From 63544d09ae3d55933e14ffcd24d5c09a9074d29b Mon Sep 17 00:00:00 2001 From: David Rubin <87927264+Rexicon226@users.noreply.github.com> Date: Thu, 16 Jan 2025 15:07:32 -0800 Subject: [PATCH] feat(ci): ensure building passes on macos (#489) --- .github/workflows/check.yml | 44 +++++++++++++++++++++++++++++-------- build.zig.zon | 4 ++-- 2 files changed, 37 insertions(+), 11 deletions(-) diff --git a/.github/workflows/check.yml b/.github/workflows/check.yml index 0c3812681..5a9245e2e 100644 --- a/.github/workflows/check.yml +++ b/.github/workflows/check.yml @@ -36,6 +36,28 @@ jobs: - name: check style run: python scripts/style.py --check src + build: + runs-on: ubuntu-latest + steps: + - name: checkout + uses: actions/checkout@v3 + + - name: setup-zig + uses: mlugg/setup-zig@v1 + with: + version: 0.13.0 + + # GitHub's CI runners for macos seem to alternate between using a x86 and an ARM machine + # which is annoying to handle and results in them having invalid hardware info configurations + # on the virtual machine. This leads to incorrect feature detection and the CI is flaky. + # + # If we at some point setup a self-hosted MacOS runner, we could work around the issue and + # enable full testing on MacOS! + - name: build + run: | + zig build -Dtarget=x86_64-linux -Dcpu=x86_64_v4 + zig build -Dtarget=aarch64-macos -Dcpu=apple_m3 + test: strategy: matrix: @@ -45,8 +67,6 @@ jobs: steps: - name: checkout uses: actions/checkout@v2 - with: - submodules: recursive - name: setup-zig uses: mlugg/setup-zig@v1 @@ -56,7 +76,7 @@ jobs: - name: test run: | zig build test -Denable-tsan=true - zig build test -Denable-tsan=true -Dblockstore=hashmap -Dfilter=ledger + zig build test -Denable-tsan=true -Dblockstore=hashmap -Dfilter="ledger" kcov_test: strategy: @@ -104,8 +124,7 @@ jobs: steps: - name: checkout uses: actions/checkout@v2 - with: - submodules: recursive + - name: setup-zig uses: mlugg/setup-zig@v1 with: @@ -113,6 +132,7 @@ jobs: - name: build release run: zig build -Doptimize=ReleaseSafe + - name: run gossip run: bash scripts/gossip_test.sh 120 # in seconds @@ -125,14 +145,15 @@ jobs: steps: - name: checkout uses: actions/checkout@v2 - with: - submodules: recursive + - name: setup zig uses: mlugg/setup-zig@v1 with: version: 0.13.0 + - name: build run: zig build -Doptimize=ReleaseSafe -Dno-run fuzz + - name: run run: ./zig-out/bin/fuzz gossip_service 19 10000 @@ -145,14 +166,18 @@ jobs: steps: - name: checkout uses: actions/checkout@v2 + with: submodules: recursive + - name: setup zig uses: mlugg/setup-zig@v1 with: version: 0.13.0 + - name: build run: zig build -Doptimize=ReleaseSafe -Dno-run fuzz + - name: run run: ./zig-out/bin/fuzz gossip_table 19 100000 @@ -165,14 +190,15 @@ jobs: steps: - name: checkout uses: actions/checkout@v2 - with: - submodules: recursive + - name: setup zig uses: mlugg/setup-zig@v1 with: version: 0.13.0 + - name: build run: zig build -Doptimize=ReleaseSafe -Dno-run fuzz + - name: run run: ./zig-out/bin/fuzz allocators 19 10000 diff --git a/build.zig.zon b/build.zig.zon index 262fc9d87..40389fda7 100644 --- a/build.zig.zon +++ b/build.zig.zon @@ -32,8 +32,8 @@ .hash = "12207766d25ba350d6e2f2153fc74a2b3ff204224e1c08adf211cd9e400075033898", }, .lsquic = .{ - .url = "https://github.com/Syndica/lsquic/archive/7c34f2472f390482dffada7a65b8231f6b5b3a3b.tar.gz", - .hash = "1220ff572d14b18d9774a298db0b8aeb046800039ccc8e10646992b074e26ea4c38a", + .url = "https://github.com/Syndica/lsquic/archive/ed6ced0cbc6447f7135a32db491e398debdf8af7.tar.gz", + .hash = "12207247a06ac1e7f4ddd6f0fbca4bcdcdf78655432a07928a96c8ec456bdfca71e3", }, .xev = .{ .url = "https://github.com/mitchellh/libxev/archive/b8d1d93e5c899b27abbaa7df23b496c3e6a178c7.tar.gz",