From cde3eb811141320dbd63c4102f5971c07cb39263 Mon Sep 17 00:00:00 2001 From: "Jay Freeman (saurik)" Date: Mon, 25 Nov 2024 02:27:38 +0000 Subject: [PATCH] testing homebrew --- .github/workflows/main.yml | 415 ++----------------------------------- env/setup-mac.sh | 2 + srv-daemon/source/main.cpp | 17 +- 3 files changed, 27 insertions(+), 407 deletions(-) diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml index f4c09511f..205d6cdde 100644 --- a/.github/workflows/main.yml +++ b/.github/workflows/main.yml @@ -2,405 +2,22 @@ name: CI on: [push] jobs: - - - cache-submodule: - runs-on: ubuntu-latest - - steps: - - uses: actions/checkout@v4 - - run: env/setup.sh - - uses: ./.github/actions/submodule - - - - build-flt-orc: - needs: [cache-submodule] - runs-on: macos-latest - - steps: - - uses: actions/checkout@v4 - - run: env/setup.sh - - uses: ./.github/actions/submodule - - - uses: actions/setup-java@v4 - with: - distribution: 'temurin' - java-version: '11' - - - run: ./app-flutter.sh orchid && cd app-flutter && make - - - - build-ios-app: - needs: [cache-submodule] - runs-on: macos-latest - - steps: - - uses: actions/checkout@v4 - - run: env/setup.sh - - uses: ./.github/actions/submodule - - - run: debug=ldid make -j3 -C app-ios precache='--no-android' - - - build-and-app: - needs: [cache-submodule] - runs-on: ubuntu-latest - - steps: - - run: sudo rm -rf /opt - - - uses: actions/checkout@v4 - - run: env/setup.sh - - uses: ./.github/actions/submodule - - - run: env/setup-ndk.sh - - - run: make -j3 -C app-android precache='--no-ios' - - - uses: actions/upload-artifact@v4 - with: - name: orchid-apk - path: app-android/out-and/Orchid.apk - - - build-and-dkr: - needs: [cache-submodule] - runs-on: ubuntu-latest - - steps: - - run: sudo rm -rf /opt - - - uses: actions/checkout@v4 - - run: env/setup-git.sh - - uses: ./.github/actions/submodule - - - run: cd app-android && env/docker.sh -j3 - - - - build-mac-app: - needs: [cache-submodule] - runs-on: macos-latest - - steps: - - uses: actions/checkout@v4 - - run: env/setup.sh - - uses: ./.github/actions/submodule - - - run: debug=ldid make -j3 -C app-macos precache='--no-android --no-ios --macos' - - - build-mac-snd: - needs: [cache-submodule] - runs-on: macos-latest - - steps: - - uses: actions/checkout@v4 - - run: env/setup.sh - - uses: ./.github/actions/submodule - - - run: make -j3 -C eth-sender - - - uses: actions/upload-artifact@v4 - with: - name: cj-mac - path: eth-sender/out-mac/x86_64/cj - - - build-mac-cli: - needs: [cache-submodule] + homebrew-pkgconf: runs-on: macos-latest steps: - - uses: actions/checkout@v4 - - run: env/setup.sh - - uses: ./.github/actions/submodule - - - run: make -j3 -C cli-shared - - - uses: actions/upload-artifact@v4 - with: - name: orchidcd-mac - path: cli-shared/out-mac/x86_64/orchidcd - - - build-mac-srv: - needs: [cache-submodule] - runs-on: macos-13 - - if: ${{ false }} # XXX: Hypervisor.framework - steps: - - uses: actions/checkout@v4 - - run: env/setup.sh - - uses: ./.github/actions/submodule - - - uses: ./.github/actions/nerdctl - - - run: make -j3 -C srv-daemon - - - uses: actions/upload-artifact@v4 - with: - name: orchidd-mac - path: srv-daemon/out-mac/x86_64/orchidd - - - run: git status - - - - # XXX: ubuntu-latest defaults to r25c NDK - # bumping to ubuntu-24.04 was easiest fix - - - build-win-app: - needs: [cache-submodule] - runs-on: ubuntu-24.04 - - if: ${{ false }} # XXX: Flutter 3.24 --windows - steps: - - uses: actions/checkout@v4 - - run: env/setup.sh - - uses: ./.github/actions/submodule - - - run: DEBIAN_FRONTEND=noninteractive sudo -EH apt-get -y install mingw-w64 - - - run: debug=crossndk make -j3 -C app-windows ./env/dotdot/gui-orchid/.flutter-plugins - - run: debug=crossndk make -j3 -C app-windows target=win precache='--no-android --no-ios --windows -a' - - - uses: actions/upload-artifact@v4 - with: - name: orchid-win - path: app-windows/out-win/package - - - build-win-snd: - needs: [cache-submodule] - runs-on: ubuntu-24.04 - - steps: - - uses: actions/checkout@v4 - - run: env/setup.sh - - uses: ./.github/actions/submodule - - - run: DEBIAN_FRONTEND=noninteractive sudo -EH apt-get -y install mingw-w64 - - - run: make -j3 -C eth-sender target=win - - - uses: actions/upload-artifact@v4 - with: - name: cj-win - path: eth-sender/out-win/x86_64/cj.exe - - - build-win-cli: - needs: [cache-submodule] - runs-on: ubuntu-24.04 - - steps: - - uses: actions/checkout@v4 - - run: env/setup.sh - - uses: ./.github/actions/submodule - - - run: DEBIAN_FRONTEND=noninteractive sudo -EH apt-get -y install mingw-w64 - - - run: make -j3 -C cli-shared target=win - - - uses: actions/upload-artifact@v4 - with: - name: orchidcd-win - path: cli-shared/out-win/x86_64/orchidcd.exe - - - - build-win-srv: - needs: [cache-submodule] - runs-on: macos-13 - - if: ${{ false }} # XXX: use Hyper-V - steps: - - uses: actions/checkout@v4 - - run: env/setup.sh - - uses: ./.github/actions/submodule - - - uses: ./.github/actions/nerdctl - - run: brew install mingw-w64 coreutils - - - run: make -j3 -C srv-daemon target=win - - - uses: actions/upload-artifact@v4 - with: - name: orchidd-w64 - path: srv-daemon/out-win/x86_64/orchidd.exe - - - run: git status - - - - build-lnx-app: - needs: [cache-submodule] - runs-on: ubuntu-latest - - steps: - - uses: actions/checkout@v4 - - run: env/setup.sh - - uses: ./.github/actions/submodule - - - run: debug=crossndk make -j3 -C app-linux ./env/dotdot/gui-orchid/.flutter-plugins - - run: debug=crossndk make -j3 -C app-linux precache='--no-android --no-ios --linux' - - - uses: actions/upload-artifact@v4 - with: - name: orchid-lnx - path: app-linux/out-lnx/package - - - build-lnx-tst: - needs: [cache-submodule] - runs-on: ubuntu-latest - - steps: - - uses: actions/checkout@v4 - - run: env/setup.sh - - uses: ./.github/actions/submodule - - - run: debug=crossndk make -j3 -C tst-network - - - build-lnx-cli: - needs: [cache-submodule] - runs-on: ubuntu-latest - - strategy: - fail-fast: false - matrix: - machine: [x86_64, arm64, armhf] - - steps: - - uses: actions/checkout@v4 - - run: env/setup.sh - - uses: ./.github/actions/submodule - - - run: debug=crossndk make -j3 -C cli-shared machine=${{ matrix.machine }} - - - uses: actions/upload-artifact@v4 - with: - name: orchidcd-lnx-${{ matrix.machine }} - path: cli-shared/out-lnx/${{ matrix.machine }}/orchidcd - - - build-lnx-srv: - needs: [cache-submodule] - runs-on: ubuntu-latest - - strategy: - fail-fast: false - matrix: - # XXX: armhf is missing rcrt1.o - machine: [x86_64, arm64] - - steps: - - run: sudo rm -rf /opt - - - uses: actions/checkout@v4 - - run: env/setup.sh - - uses: ./.github/actions/submodule - - - run: env/setup-ndk.sh - - - run: debug=crossndk make -j3 -C srv-daemon machine=${{ matrix.machine }} - - - uses: actions/upload-artifact@v4 - with: - name: orchidd-lnx-${{ matrix.machine }} - path: srv-daemon/out-lnx/${{ matrix.machine }}/orchidd - if: ${{ matrix.machine != 'x86_64' }} - - - run: git status - - - build-lnx-dkr: - needs: [cache-submodule] - runs-on: ubuntu-latest - - steps: - - run: sudo rm -rf /opt - - - uses: actions/checkout@v4 - - run: env/setup-git.sh - - uses: ./.github/actions/submodule - - - run: cd srv-daemon && env/docker.sh -j3 - - - build-lnx-bld: - needs: [cache-submodule] - runs-on: ubuntu-latest - - steps: - - run: sudo rm -rf /opt - - - uses: actions/checkout@v4 - - - run: docker build --build-arg GIT_REPOSITORY=https://github.com/${{ github.repository }}.git --build-arg GIT_COMMIT=${{ github.sha }} --build-arg GIT_SETUP=env/setup-git.sh -t orchidd:latest srv-docker - - run: docker save -o orchidd.tar orchidd:latest - - - uses: actions/upload-artifact@v4 - with: - name: orchidd-dkr - path: orchidd.tar - - - build-lnx-mac: - needs: [cache-submodule] - runs-on: macos-13 - - steps: - - uses: actions/checkout@v4 - - run: env/setup.sh - - uses: ./.github/actions/submodule - - - uses: ./.github/actions/nerdctl - - run: env/setup-ndk.sh - - - run: gmake -j3 -C srv-daemon target=lnx - - - uses: actions/upload-artifact@v4 - with: - name: orchidd-lnx-amd64 - path: srv-daemon/out-lnx/x86_64/orchidd - - - build-lnx-bad: - needs: [cache-submodule] - runs-on: ubuntu-24.04 - - steps: - - uses: actions/checkout@v4 - - run: env/setup.sh - - uses: ./.github/actions/submodule - - - run: make -j3 -C srv-daemon - - - build-lnx-all: - needs: [build-lnx-mac, build-lnx-bld] - runs-on: ubuntu-latest - - steps: - - uses: actions/download-artifact@v4 - with: - name: orchidd-dkr - - run: tar -xvf orchidd.tar - - run: tar -xvf "$(jq -r '.[0].Layers | .[]' manifest.json | tail -n1)" - - - uses: actions/download-artifact@v4 - with: - name: orchidd-lnx-amd64 - - - run: chmod +x orchidd - - run: diff -u <(./usr/sbin/orchidd --version) <(./orchidd --version) - - run: diff -u <(xxd usr/sbin/orchidd) <(xxd orchidd) - - - + - run: brew unlink pkg-config@0.29.2 || true + - run: brew install pkg-config + - run: brew unlink pkg-config@0.29.2 + + - run: false + - run: brew update + - run: brew update + - run: brew upgrade + - run: brew uninstall openssl@1.1 + - run: brew uninstall ruby@3.0 + - run: brew cleanup + - run: cd /opt/homebrew/Library/Taps/homebrew/homebrew-core && git stash -u && git clean -d -f + - run: brew config + - run: brew doctor + - run: brew update diff --git a/env/setup-mac.sh b/env/setup-mac.sh index a4243014e..9dd32edec 100755 --- a/env/setup-mac.sh +++ b/env/setup-mac.sh @@ -2,6 +2,8 @@ set -e which brew &>/dev/null || /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)" +brew update + # XXX: duplicate linux setup as much as possible brew install \ gnu-sed \ diff --git a/srv-daemon/source/main.cpp b/srv-daemon/source/main.cpp index cfd6a9213..8b7bdbe69 100644 --- a/srv-daemon/source/main.cpp +++ b/srv-daemon/source/main.cpp @@ -79,7 +79,7 @@ namespace po = boost::program_options; int TestWorker(const asio::ip::address &bind, uint16_t port, const std::string &key, const std::string &certificates, const std::string ¶ms); -task Symmetric(const S &base) { +task Check(const S &base) { const auto offer(co_await Description(base, {"stun:stun.l.google.com:19302", "stun:stun.cloudflare.com:3478"})); std::cout << std::endl; std::cout << Filter(false, offer) << std::endl; @@ -103,12 +103,11 @@ task Symmetric(const S &base) { const auto &candidate(ice->candidate()); if (!candidate.is_stun()) continue; - if (!reflexive.emplace(candidate.related_address(), candidate.address()).second) - co_return true; + orc_assert_(reflexive.emplace(candidate.related_address(), candidate.address()).second, "symmetric NAT is not supported"); } } - co_return false; + orc_assert_(!reflexive.empty(), "must have at least a single route"); } int Main(int argc, const char *const argv[]) { @@ -270,7 +269,10 @@ int Main(int argc, const char *const argv[]) { S base(args.count("network") == 0 ? Break() : Break(args["network"].as())); - orc_assert_(!Wait(Symmetric(base)), "server must not use symmetric NAT"); + + Wait([&]() -> task { + co_await Check(base); + }()); auto cashier([&]() -> S { @@ -366,9 +368,8 @@ int Main(int argc, const char *const argv[]) { auto remote(Break>()); Egress::Wire(egress, *remote); remote->Open(); - co_await remote->Resolve("one.one.one.one", "443"); - if (co_await Symmetric(remote)) - Log() << "egress should not use symmetric NAT" << std::endl; + co_await remote->Resolve("one.one", "443"); + co_await Check(remote); }());