X-Git-Url: http://git.bitcoin.ninja/index.cgi?a=blobdiff_plain;f=.github%2Fworkflows%2Fbuild.yml;h=6ce9785a61d15b3101a14e3f433037943cc59ee9;hb=b3fe89e28d8eb4c1d11fcb73ab593603b6dc4b12;hp=139412a74cbd77f253429cfe0c372fd0caa89409;hpb=af6f9949b19c1e8d2daac5c7a94cf14d41175f2b;p=ldk-java diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 139412a7..6ce9785a 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -34,19 +34,21 @@ jobs: cargo install --locked --path . - name: Checkout Rust-Lightning and LDK-C-Bindings git run: | + git config --global safe.directory '*' git config --global user.email "ldk-ci@example.com" git config --global user.name "LDK CI" # 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/2022-07-110-java-bindings + git checkout origin/2023-04-0.0.115-java-bindings cd .. git clone https://github.com/lightningdevkit/ldk-c-bindings cd ldk-c-bindings - git checkout 0.0.110 + git checkout 0.0.115 - name: Rebuild C bindings without STD run: | cd ldk-c-bindings + git config --global safe.directory "*" ./genbindings.sh ../rust-lightning false - name: Build and Test TS Debug Bindings for Node run: | @@ -66,7 +68,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 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 + apt-get install -y --no-install-recommends fonts-liberation libenchant-2-2 libicu72 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 @@ -75,6 +77,7 @@ jobs: run: | export HOME=/root/ # Github actions is apparently broken export PATH=$(pwd)/$(echo node-*/bin):$PATH + git config --global safe.directory "*" ./genbindings.sh ./ldk-c-bindings/ wasm true true cd ts rm liblightningjs.wasm && ln -s $(pwd)/../liblightningjs_debug.wasm ./liblightningjs.wasm @@ -118,6 +121,7 @@ jobs: fetch-depth: 0 - name: Install cbindgen run: | + git config --global safe.directory '*' git clone https://github.com/eqrion/cbindgen cd cbindgen/ git checkout v0.20.0 @@ -130,11 +134,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/2022-07-110-java-bindings + git checkout origin/2023-04-0.0.115-java-bindings cd .. git clone https://github.com/lightningdevkit/ldk-c-bindings cd ldk-c-bindings - git checkout 0.0.110 + git checkout 0.0.115 - name: Rebuild C bindings, and check the sample app builds + links run: | cd ldk-c-bindings @@ -173,6 +177,7 @@ jobs: fetch-depth: 0 - name: Install cbindgen run: | + git config --global safe.directory '*' git clone https://github.com/eqrion/cbindgen cd cbindgen/ git checkout v0.20.0 @@ -185,11 +190,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/2022-07-110-java-bindings + git checkout origin/2023-04-0.0.115-java-bindings cd .. git clone https://github.com/lightningdevkit/ldk-c-bindings cd ldk-c-bindings - git checkout 0.0.110 + git checkout 0.0.115 - name: Rebuild C bindings, and check the sample app builds + links run: | cd ldk-c-bindings @@ -261,6 +266,9 @@ jobs: chmod +x ./rustup.sh ./rustup.sh -y . $HOME/.cargo/env + # Temporarily use 1.67.1 to fix https://github.com/rust-lang/rust/issues/108943 + rustup install 1.67.1 + rustup default 1.67.1 rustup target add armv7-linux-androideabi rustup target add aarch64-linux-android rustup target add i686-linux-android @@ -271,6 +279,7 @@ jobs: fetch-depth: 0 - name: Install android NDK compilers run: | + git config --global safe.directory '*' curl https://dl.google.com/android/repository/android-ndk-r22b-linux-x86_64.zip > android-ndk-r22b-linux-x86_64.zip if [ "$(sha256sum android-ndk-r22b-linux-x86_64.zip | awk '{ print $1 }')" != "ac3a0421e76f71dd330d0cd55f9d99b9ac864c4c034fc67e0d671d022d4e806b" ]; then echo "Bad hash" @@ -288,11 +297,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/2022-07-110-java-bindings + git checkout origin/2023-04-0.0.115-java-bindings cd .. git clone https://github.com/lightningdevkit/ldk-c-bindings cd ldk-c-bindings - git checkout 0.0.110 + git checkout 0.0.115 - name: Checkout Android AAR binaries and artifacts run: | # Gitweb only allows snapshots of folders by providing the object hash, which we have to extract: @@ -345,20 +354,21 @@ jobs: steps: - name: Install other Rust platforms run: rustup target install aarch64-apple-darwin + - name: Checkout source code + uses: actions/checkout@v2 + with: + fetch-depth: 0 - name: Fetch upstream LLVM/clang snapshot run: | - 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 + git config --global safe.directory '*' + wget -O clang+llvm-15.0.7-x86_64-apple-darwin21.0.tar.xz https://github.com/llvm/llvm-project/releases/download/llvmorg-15.0.7/clang+llvm-15.0.7-x86_64-apple-darwin21.0.tar.xz + if [ "$(shasum -a 256 clang+llvm-15.0.7-x86_64-apple-darwin21.0.tar.xz | awk '{ print $1 }')" != "d16b6d536364c5bec6583d12dd7e6cf841b9f508c4430d9ee886726bd9983f1c" ]; then echo "Bad hash" exit 1 fi - name: Unpack upstream LLVM+clang and use it by default run: | - 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 + tar xvvf clang+llvm-15.0.7-x86_64-apple-darwin21.0.tar.xz - name: Install cbindgen run: cargo install cbindgen - name: Checkout Rust-Lightning and LDK-C-Bindings git @@ -368,15 +378,18 @@ 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/2022-07-110-java-bindings + git checkout origin/2023-04-0.0.115-java-bindings cd .. git clone https://github.com/lightningdevkit/ldk-c-bindings cd ldk-c-bindings - git checkout 0.0.110 + git checkout 0.0.115 - name: Rebuild C bindings with upstream clang, and check the sample app builds + links run: | - export PATH=`pwd`/clang+llvm-14.0.5-x86_64-apple-darwin/bin:$PATH + export PATH=`pwd`/clang+llvm-15.0.7-x86_64-apple-darwin21.0/bin:$PATH cd ldk-c-bindings + export CC=clang + export CC_x86_64_apple_darwin=clang + export CC_aarch64_apple_darwin=clang CC=clang ./genbindings.sh ../rust-lightning true - name: Fetch OpenJDK 18 run: | @@ -414,7 +427,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.5-x86_64-apple-darwin/bin:$PATH + export PATH=`pwd`/clang+llvm-15.0.7-x86_64-apple-darwin21.0/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