Fix: Improve CI Patch

This commit is contained in:
Youwes09
2026-03-20 22:34:32 -05:00
parent bd972eccf3
commit c13a4eb77a
+6 -36
View File
@@ -78,27 +78,21 @@ jobs:
curl -fsSL \ curl -fsSL \
"https://github.com/Suwayomi/Suwayomi-Server/releases/download/v2.1.1867/Suwayomi-Server-v2.1.1867-windows-x64.zip" \ "https://github.com/Suwayomi/Suwayomi-Server/releases/download/v2.1.1867/Suwayomi-Server-v2.1.1867-windows-x64.zip" \
-o suwayomi-windows.zip -o suwayomi-windows.zip
echo "ab6687d278e0dd0984f67abbc853511a7e764f84b126a35d09bfd9b0307321ff suwayomi-windows.zip" | sha256sum -c - echo "ab6687d278e0dd0984f67abbc853511a7e764f84b126a35d09bfd9b0307321ff suwayomi-windows.zip" | sha256sum -c -
unzip -q suwayomi-windows.zip -d suwayomi-raw unzip -q suwayomi-windows.zip -d suwayomi-raw
- name: Extract Suwayomi bundle - name: Extract Suwayomi bundle
shell: bash shell: bash
run: | run: |
mkdir -p suwayomi-extracted mkdir -p suwayomi-extracted
# Handle both zip layouts: single top-level dir, or files at root
TOP_DIRS=$(find suwayomi-raw -mindepth 1 -maxdepth 1 -type d | wc -l) TOP_DIRS=$(find suwayomi-raw -mindepth 1 -maxdepth 1 -type d | wc -l)
TOP_FILES=$(find suwayomi-raw -mindepth 1 -maxdepth 1 -type f | wc -l) TOP_FILES=$(find suwayomi-raw -mindepth 1 -maxdepth 1 -type f | wc -l)
if [ "$TOP_DIRS" -eq 1 ] && [ "$TOP_FILES" -eq 0 ]; then if [ "$TOP_DIRS" -eq 1 ] && [ "$TOP_FILES" -eq 0 ]; then
INNER=$(find suwayomi-raw -mindepth 1 -maxdepth 1 -type d | head -1) INNER=$(find suwayomi-raw -mindepth 1 -maxdepth 1 -type d | head -1)
cp -r "$INNER"/. suwayomi-extracted/ cp -r "$INNER"/. suwayomi-extracted/
else else
cp -r suwayomi-raw/. suwayomi-extracted/ cp -r suwayomi-raw/. suwayomi-extracted/
fi fi
echo "Extracted bundle contents (top-level):" echo "Extracted bundle contents (top-level):"
ls -la suwayomi-extracted/ ls -la suwayomi-extracted/
@@ -106,63 +100,39 @@ jobs:
shell: bash shell: bash
run: | run: |
mkdir -p src-tauri/binaries mkdir -p src-tauri/binaries
JAVAW=$(find suwayomi-extracted -path "*/jre/bin/javaw.exe" | head -1) JAVAW=$(find suwayomi-extracted -path "*/jre/bin/javaw.exe" | head -1)
JAR=$(find suwayomi-extracted -name "Suwayomi-Launcher.jar" | head -1) JAR=$(find suwayomi-extracted -name "Suwayomi-Launcher.jar" | head -1)
if [ -z "$JAVAW" ]; then if [ -z "$JAVAW" ]; then
echo "ERROR: jre/bin/javaw.exe not found. Bundle contents:" echo "ERROR: jre/bin/javaw.exe not found. Bundle contents:"
find suwayomi-extracted -type f | head -50 find suwayomi-extracted -type f | head -50
exit 1 exit 1
fi fi
if [ -z "$JAR" ]; then if [ -z "$JAR" ]; then
echo "ERROR: Suwayomi-Launcher.jar not found. Bundle contents:" echo "ERROR: Suwayomi-Launcher.jar not found. Bundle contents:"
find suwayomi-extracted -type f | head -50 find suwayomi-extracted -type f | head -50
exit 1 exit 1
fi fi
echo "Found javaw: $JAVAW" echo "Found javaw: $JAVAW"
echo "Found jar: $JAR" echo "Found jar: $JAR"
# Copy full bundle as resources — lib.rs invokes the bundled
# java directly via resource_dir/suwayomi-bundle/jre/bin/javaw.exe.
cp -r suwayomi-extracted src-tauri/binaries/suwayomi-bundle cp -r suwayomi-extracted src-tauri/binaries/suwayomi-bundle
- name: Validate staging - name: Validate staging
shell: bash shell: bash
run: | run: |
echo "--- Validating bundle javaw ---"
find src-tauri/binaries/suwayomi-bundle -path "*/jre/bin/javaw.exe" \ find src-tauri/binaries/suwayomi-bundle -path "*/jre/bin/javaw.exe" \
| grep -q . \ | grep -q . || (echo "ERROR: jre/bin/javaw.exe missing" && exit 1)
|| (echo "ERROR: jre/bin/javaw.exe missing" && exit 1)
echo "--- Validating bundle jar ---"
find src-tauri/binaries/suwayomi-bundle -name "Suwayomi-Launcher.jar" \ find src-tauri/binaries/suwayomi-bundle -name "Suwayomi-Launcher.jar" \
| grep -q . \ | grep -q . || (echo "ERROR: Suwayomi-Launcher.jar missing" && exit 1)
|| (echo "ERROR: Suwayomi-Launcher.jar missing" && exit 1)
echo "Staging OK" echo "Staging OK"
- name: Patch tauri.conf.json for CI - name: Patch tauri.conf.json for CI
shell: bash shell: bash
run: | run: |
# Suppress the frontend rebuild (dist/ already built by frontend job).
sed -i 's/"beforeBuildCommand": "pnpm build"/"beforeBuildCommand": ""/' src-tauri/tauri.conf.json sed -i 's/"beforeBuildCommand": "pnpm build"/"beforeBuildCommand": ""/' src-tauri/tauri.conf.json
jq '.bundle.resources = ["binaries/suwayomi-bundle/**"] | .bundle.externalBin = []' \
# Remove externalBin entirely for Windows — we invoke the bundled src-tauri/tauri.conf.json > tmp.json && mv tmp.json src-tauri/tauri.conf.json
# javaw directly as a raw path, no sidecar registration needed. echo "tauri.conf.json patched:"
# Inject the suwayomi-bundle resource glob. cat src-tauri/tauri.conf.json
python3 - << 'PYEOF'
import json
with open("src-tauri/tauri.conf.json") as f:
conf = json.load(f)
conf["bundle"]["resources"] = ["binaries/suwayomi-bundle/**"]
conf["bundle"]["externalBin"] = []
with open("src-tauri/tauri.conf.json", "w") as f:
json.dump(conf, f, indent=2)
print("tauri.conf.json patched — resources injected, externalBin cleared")
PYEOF
- name: Build Tauri app (Windows x64) - name: Build Tauri app (Windows x64)
uses: tauri-apps/tauri-action@v0 uses: tauri-apps/tauri-action@v0