X-Git-Url: http://git.bitcoin.ninja/index.cgi?a=blobdiff_plain;f=.github%2Fworkflows%2Fbuild.yml;h=0b5ce9d236eaceb71d9fe85a313abb964a115478;hb=8e15fc9deea65c321d7adaf8382bc0fe660f5ffd;hp=5bad5ef8b19234f9f956f45882aeb22f23cc5f18;hpb=a03df6d0b6fe9ac98099b45061d354635f8b5477;p=ldk-java diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 5bad5ef8..0b5ce9d2 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -17,7 +17,7 @@ jobs: run: | apt-get update apt-get -y dist-upgrade - apt-get -y install cargo libstd-rust-dev-wasm32 lld git g++ clang curl node-typescript npm python3 + apt-get -y install cargo libstd-rust-dev-wasm32 lld git g++ clang curl node-typescript npm python3 wasi-libc echo "int main() {}" > genbindings_wasm_test_file.c clang -nostdlib -o /dev/null --target=wasm32-wasi -Wl,--no-entry genbindings_wasm_test_file.c rm genbindings_wasm_test_file.c @@ -26,7 +26,12 @@ jobs: with: fetch-depth: 0 - name: Install cbindgen - run: cargo install --version 0.20.0 cbindgen + run: | + git clone https://github.com/eqrion/cbindgen + cd cbindgen/ + git checkout v0.20.0 + cargo update -p indexmap --precise "1.6.2" --verbose + cargo install --locked --path . - name: Checkout Rust-Lightning and LDK-C-Bindings git run: | git config --global user.email "ldk-ci@example.com" @@ -34,11 +39,11 @@ jobs: # Note this is a different endpoint, as we need one non-upstream commit! git clone https://git.bitcoin.ninja/rust-lightning cd rust-lightning - git checkout origin/2021-03-java-bindings-base + git checkout origin/2022-06-108-java-bindings cd .. git clone https://github.com/lightningdevkit/ldk-c-bindings cd ldk-c-bindings - git checkout 0.0.106 + git checkout 0.0.108 - name: Rebuild C bindings without STD run: | cd ldk-c-bindings @@ -61,7 +66,7 @@ jobs: export HOME=/root/ # Github actions is apparently broken export PATH=$(pwd)/$(echo node-*/bin):$PATH # npx playwright install-deps is broken so we do it manually, see https://github.com/microsoft/playwright/issues/11165 - apt-get install -y --no-install-recommends fonts-liberation libenchant-2-2 libicu67 libjpeg62-turbo libasound2 libatk-bridge2.0-0 libatk1.0-0 libatspi2.0-0 libcairo2 libcups2 libdbus-1-3 libdrm2 libegl1 libgbm1 libglib2.0-0 libgtk-3-0 libnspr4 libnss3 libpango-1.0-0 libx11-6 libx11-xcb1 libxcb1 libxcomposite1 libxdamage1 libxext6 libxfixes3 libxrandr2 libxshmfence1 xvfb fonts-noto-color-emoji fonts-unifont libfontconfig libfreetype6 xfonts-scalable fonts-ipafont-gothic fonts-wqy-zenhei fonts-tlwg-loma-otf ffmpeg libcairo-gobject2 libdbus-glib-1-2 libfontconfig1 libgdk-pixbuf2.0-0 libpangocairo-1.0-0 libpangoft2-1.0-0 libxcb-shm0 libxcursor1 libxi6 libxrender1 libxt6 gstreamer1.0-libav gstreamer1.0-plugins-bad gstreamer1.0-plugins-base gstreamer1.0-plugins-good libepoxy0 libevdev2 libgl1 libgles2 libgstreamer-gl1.0-0 libgstreamer1.0-0 libharfbuzz-icu0 libharfbuzz0b libhyphen0 libnotify4 libopenjp2-7 libopus0 libpng16-16 libsecret-1-0 libsoup2.4-1 libwayland-client0 libwayland-egl1 libwayland-server0 libwebp7 libwebpdemux2 libwoff1 libxkbcommon0 libxml2 libxslt1.1 + apt-get install -y --no-install-recommends fonts-liberation libenchant-2-2 libicu71 libjpeg62-turbo libasound2 libatk-bridge2.0-0 libatk1.0-0 libatspi2.0-0 libcairo2 libcups2 libdbus-1-3 libdrm2 libegl1 libgbm1 libglib2.0-0 libgtk-3-0 libnspr4 libnss3 libpango-1.0-0 libx11-6 libx11-xcb1 libxcb1 libxcomposite1 libxdamage1 libxext6 libxfixes3 libxrandr2 libxshmfence1 xvfb fonts-noto-color-emoji fonts-unifont libfontconfig libfreetype6 xfonts-scalable fonts-ipafont-gothic fonts-wqy-zenhei fonts-tlwg-loma-otf ffmpeg libcairo-gobject2 libdbus-glib-1-2 libfontconfig1 libgdk-pixbuf2.0-0 libpangocairo-1.0-0 libpangoft2-1.0-0 libxcb-shm0 libxcursor1 libxi6 libxrender1 libxt6 gstreamer1.0-libav gstreamer1.0-plugins-bad gstreamer1.0-plugins-base gstreamer1.0-plugins-good libepoxy0 libevdev2 libgl1 libgles2 libgstreamer-gl1.0-0 libgstreamer1.0-0 libharfbuzz-icu0 libharfbuzz0b libhyphen0 libnotify4 libopenjp2-7 libopus0 libpng16-16 libsecret-1-0 libsoup2.4-1 libwayland-client0 libwayland-egl1 libwayland-server0 libwebp7 libwebpdemux2 libwoff1 libxkbcommon0 libxml2 libxslt1.1 mkdir -p $HOME/.cache/ms-playwright # `playwright install` is too dumb to create this for us chmod -R 777 $HOME/ npm i -D playwright @@ -90,6 +95,7 @@ jobs: kill $SERVER_PID - name: Check latest TS files are in git run: | + git checkout ts/package.json git diff --exit-code java_bindings: @@ -110,7 +116,12 @@ jobs: with: fetch-depth: 0 - name: Install cbindgen - run: cargo install --version 0.20.0 cbindgen + run: | + git clone https://github.com/eqrion/cbindgen + cd cbindgen/ + git checkout v0.20.0 + cargo update -p indexmap --precise "1.6.2" --verbose + cargo install --locked --path . - name: Checkout Rust-Lightning and LDK-C-Bindings git run: | git config --global user.email "ldk-ci@example.com" @@ -118,11 +129,11 @@ jobs: # Note this is a different endpoint, as we need one non-upstream commit! git clone https://git.bitcoin.ninja/rust-lightning cd rust-lightning - git checkout origin/2021-03-java-bindings-base + git checkout origin/2022-06-108-java-bindings cd .. git clone https://github.com/lightningdevkit/ldk-c-bindings cd ldk-c-bindings - git checkout 0.0.106 + git checkout 0.0.108 - name: Rebuild C bindings, and check the sample app builds + links run: | cd ldk-c-bindings @@ -160,7 +171,12 @@ jobs: with: fetch-depth: 0 - name: Install cbindgen - run: cargo install --version 0.20.0 cbindgen + run: | + git clone https://github.com/eqrion/cbindgen + cd cbindgen/ + git checkout v0.20.0 + cargo update -p indexmap --precise "1.6.2" --verbose + cargo install --locked --path . - name: Checkout Rust-Lightning and LDK-C-Bindings git run: | git config --global user.email "ldk-ci@example.com" @@ -168,11 +184,11 @@ jobs: # Note this is a different endpoint, as we need one non-upstream commit! git clone https://git.bitcoin.ninja/rust-lightning cd rust-lightning - git checkout origin/2021-03-java-bindings-base + git checkout origin/2022-06-108-java-bindings cd .. git clone https://github.com/lightningdevkit/ldk-c-bindings cd ldk-c-bindings - git checkout 0.0.106 + git checkout 0.0.108 - name: Rebuild C bindings, and check the sample app builds + links run: | cd ldk-c-bindings @@ -263,7 +279,7 @@ jobs: - name: Install cbindgen run: | . $HOME/.cargo/env - cargo install --version 0.20.0 cbindgen + cargo install cbindgen - name: Checkout Rust-Lightning and LDK-C-Bindings git run: | git config --global user.email "ldk-ci@example.com" @@ -271,11 +287,11 @@ jobs: # Note this is a different endpoint, as we need one non-upstream commit! git clone https://git.bitcoin.ninja/rust-lightning cd rust-lightning - git checkout origin/2021-03-java-bindings-base + git checkout origin/2022-06-108-java-bindings cd .. git clone https://github.com/lightningdevkit/ldk-c-bindings cd ldk-c-bindings - git checkout 0.0.106 + git checkout 0.0.108 - name: Checkout Android AAR binaries and artifacts run: | # Gitweb only allows snapshots of folders by providing the object hash, which we have to extract: @@ -330,20 +346,20 @@ jobs: run: rustup target install aarch64-apple-darwin - name: Fetch upstream LLVM/clang snapshot run: | - wget -O clang+llvm-14.0.1-x86_64-apple-darwin.tar.xz https://github.com/llvm/llvm-project/releases/download/llvmorg-14.0.1/clang+llvm-14.0.1-x86_64-apple-darwin.tar.xz - if [ "$(shasum -a 256 clang+llvm-14.0.1-x86_64-apple-darwin.tar.xz | awk '{ print $1 }')" != "43149390e95b1cdbf1d4ef2e9d214bbb6d35858ceb2df27245868e06bc4fc44c" ]; then + wget -O clang+llvm-14.0.5-x86_64-apple-darwin.tar.xz https://github.com/llvm/llvm-project/releases/download/llvmorg-14.0.5/clang+llvm-14.0.5-x86_64-apple-darwin.tar.xz + if [ "$(shasum -a 256 clang+llvm-14.0.5-x86_64-apple-darwin.tar.xz | awk '{ print $1 }')" != "66cf1b8e00289a567b2f5f740f068b7682e27ccf048647b836d3624376a64705" ]; then echo "Bad hash" exit 1 fi - name: Unpack upstream LLVM+clang and use it by default run: | - tar xvvf clang+llvm-14.0.1-x86_64-apple-darwin.tar.xz + tar xvvf clang+llvm-14.0.5-x86_64-apple-darwin.tar.xz - name: Checkout source code uses: actions/checkout@v2 with: fetch-depth: 0 - name: Install cbindgen - run: cargo install --version 0.20.0 cbindgen + run: cargo install cbindgen - name: Checkout Rust-Lightning and LDK-C-Bindings git run: | git config --global user.email "ldk-ci@example.com" @@ -351,14 +367,14 @@ jobs: # Note this is a different endpoint, as we need one non-upstream commit! git clone https://git.bitcoin.ninja/rust-lightning cd rust-lightning - git checkout origin/2021-03-java-bindings-base + git checkout origin/2022-06-108-java-bindings cd .. git clone https://github.com/lightningdevkit/ldk-c-bindings cd ldk-c-bindings - git checkout 0.0.106 + git checkout 0.0.108 - name: Rebuild C bindings with upstream clang, and check the sample app builds + links run: | - export PATH=`pwd`/clang+llvm-14.0.1-x86_64-apple-darwin/bin:$PATH + export PATH=`pwd`/clang+llvm-14.0.5-x86_64-apple-darwin/bin:$PATH cd ldk-c-bindings CC=clang ./genbindings.sh ../rust-lightning true - name: Fetch OpenJDK 18 @@ -397,7 +413,7 @@ jobs: export LDK_GARBAGECOLLECTED_GIT_OVERRIDE="$(git describe --tag HEAD)" export JAVA_HOME=`pwd`/jdk-18.0.1.1.jdk/Contents/Home export PATH=$JAVA_HOME/bin:$PATH - export PATH=`pwd`/clang+llvm-14.0.1-x86_64-apple-darwin/bin:$PATH + export PATH=`pwd`/clang+llvm-14.0.5-x86_64-apple-darwin/bin:$PATH ./genbindings.sh ./ldk-c-bindings/ "-I$JAVA_HOME/include/ -I$JAVA_HOME/include/darwin -isysroot$(xcrun --show-sdk-path)" false false if [ "${{ matrix.platform }}" = "macos-11" ]; then