X-Git-Url: http://git.bitcoin.ninja/index.cgi?a=blobdiff_plain;f=.github%2Fworkflows%2Fbuild.yml;h=0e354b95013a4c2751f5ea38f706bca851ceb3a5;hb=890b1722ace63ce3e6bf89e4260dc7f4b6b41112;hp=c3a4ff8a117781a89f14ba94a833e8acb3df7c59;hpb=fb114ac156d874c489b3fec2a7f2fb9690f93ffa;p=ldk-java diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index c3a4ff8a..0e354b95 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -38,13 +38,15 @@ jobs: 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 + git clone https://github.com/lightningdevkit/rust-lightning cd rust-lightning - git checkout origin/2023-04-0.0.115-java-bindings + git checkout origin/0.0.118-bindings cd .. git clone https://github.com/lightningdevkit/ldk-c-bindings cd ldk-c-bindings - git checkout 0.0.115 + git checkout 0.0.118 + cd lightning-c-bindings + cargo update -p memchr --precise "2.5.0" --verbose - name: Rebuild C bindings without STD run: | cd ldk-c-bindings @@ -71,8 +73,8 @@ jobs: 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 - npx playwright install + npm i -D playwright@1.37.0-alpha-jul-31-2023 + npx playwright@1.37.0-alpha-jul-31-2023 install - name: Build and Test TS Debug Bindings for Web run: | export HOME=/root/ # Github actions is apparently broken @@ -132,13 +134,20 @@ jobs: 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 + git clone https://github.com/lightningdevkit/rust-lightning cd rust-lightning - git checkout origin/2023-04-0.0.115-java-bindings + git checkout origin/0.0.118-bindings cd .. git clone https://github.com/lightningdevkit/ldk-c-bindings cd ldk-c-bindings - git checkout 0.0.115 + git checkout 0.0.118 + cd lightning-c-bindings + cargo update -p memchr --precise "2.5.0" --verbose + - name: Pin proc-macro and quote to meet MSRV + run: | + cd ldk-c-bindings/c-bindings-gen + cargo update -p quote --precise "1.0.30" --verbose + cargo update -p proc-macro2 --precise "1.0.65" --verbose - name: Rebuild C bindings, and check the sample app builds + links run: | cd ldk-c-bindings @@ -188,13 +197,20 @@ jobs: 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 + git clone https://github.com/lightningdevkit/rust-lightning cd rust-lightning - git checkout origin/2023-04-0.0.115-java-bindings + git checkout origin/0.0.118-bindings cd .. git clone https://github.com/lightningdevkit/ldk-c-bindings cd ldk-c-bindings - git checkout 0.0.115 + git checkout 0.0.118 + cd lightning-c-bindings + cargo update -p memchr --precise "2.5.0" --verbose + - name: Pin proc-macro and quote to meet MSRV + run: | + cd ldk-c-bindings/c-bindings-gen + cargo update -p quote --precise "1.0.30" --verbose + cargo update -p proc-macro2 --precise "1.0.65" --verbose - name: Rebuild C bindings, and check the sample app builds + links run: | cd ldk-c-bindings @@ -251,6 +267,7 @@ jobs: cp ldk-java-classes.jar ldk-java-bins/new/ cp ldk-java-javadoc.jar ldk-java-bins/new/ cd ldk-java-bins + rm "${LDK_GARBAGECOLLECTED_GIT_OVERRIDE}/liblightningjs.wasm" # TODO: Test this if ! diff -r "${LDK_GARBAGECOLLECTED_GIT_OVERRIDE}/" new/; then apt-get -y install diffoscope diffoscope new/ldk-java-sources.jar "${LDK_GARBAGECOLLECTED_GIT_OVERRIDE}/ldk-java-sources.jar" || echo @@ -297,13 +314,13 @@ jobs: 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 + git clone https://github.com/lightningdevkit/rust-lightning cd rust-lightning - git checkout origin/2023-04-0.0.115-java-bindings + git checkout origin/0.0.118-bindings cd .. git clone https://github.com/lightningdevkit/ldk-c-bindings cd ldk-c-bindings - git checkout 0.0.115 + git checkout 0.0.118 - name: Fetch MacOS SDK run: | curl -o Xcode-12.2-12B45b-extracted-SDK-with-libcxx-headers.tar.gz https://bitcoincore.org/depends-sources/sdks/Xcode-12.2-12B45b-extracted-SDK-with-libcxx-headers.tar.gz @@ -434,13 +451,16 @@ jobs: 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 + git clone https://github.com/lightningdevkit/rust-lightning cd rust-lightning - git checkout origin/2023-04-0.0.115-java-bindings + git checkout origin/0.0.118-bindings cd .. git clone https://github.com/lightningdevkit/ldk-c-bindings cd ldk-c-bindings - git checkout 0.0.115 + git checkout 0.0.118 + cd lightning-c-bindings + . $HOME/.cargo/env + cargo update -p memchr --precise "2.5.0" --verbose - name: Checkout Android AAR binaries and artifacts run: | # Gitweb only allows snapshots of folders by providing the object hash, which we have to extract: @@ -500,17 +520,6 @@ jobs: uses: actions/checkout@v2 with: fetch-depth: 0 - - name: Fetch upstream LLVM/clang snapshot - run: | - 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-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 @@ -518,20 +527,18 @@ jobs: 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 + git clone https://github.com/rghtningdevkit/ust-lightning cd rust-lightning - git checkout origin/2023-04-0.0.115-java-bindings + git checkout origin/0.0.118-bindings cd .. git clone https://github.com/lightningdevkit/ldk-c-bindings cd ldk-c-bindings - git checkout 0.0.115 - - name: Rebuild C bindings with upstream clang, and check the sample app builds + links + git checkout 0.0.118 + cd lightning-c-bindings + cargo update -p memchr --precise "2.5.0" --verbose + - name: Rebuild C bindings and check the sample app builds + links run: | - 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: | @@ -569,7 +576,6 @@ 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-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 @@ -580,7 +586,6 @@ jobs: cat src/main/resources/liblightningjni_MacOSX-aarch64.nativelib > /dev/null fi - - name: Fetch Maven 3.8.4 run: | # We don't bother using the upstream mirrors as they remove prior