@@ -142,6 +142,7 @@ jobs:
142142 git config --global url."ssh://[email protected] /platformatic/http-handler.git".insteadOf "ssh://[email protected] /platformatic/http-handler.git" 143143 git config --global url."ssh://[email protected] /platformatic/http-rewriter.git".insteadOf "ssh://[email protected] /platformatic/http-rewriter.git" 144144
145+ npm run build:wasm
145146 ${{ matrix.settings.build }}
146147 - name : Build
147148 run : ${{ matrix.settings.build }}
@@ -155,6 +156,8 @@ jobs:
155156 ${{ env.APP_NAME }}.*.node
156157 index.d.ts
157158 index.js
159+ fix-python-soname.wasm
160+ fix-python-soname.js
158161 if-no-files-found : error
159162
160163 test-macOS-windows-binding :
@@ -332,79 +335,9 @@ jobs:
332335 apt-get update -y
333336 apt-get install -y python3 python3-dev patchelf
334337
335- echo "=== Starting test setup ==="
336- echo "Current directory: $(pwd)"
337- echo "Python version: $(python3 --version)"
338- echo "Patchelf version: $(patchelf --version)"
339- echo "Using combined approach: SONAME patching + programmatic RTLD_GLOBAL"
340- echo "CI environment: CI=$CI, GITHUB_ACTIONS=$GITHUB_ACTIONS"
341-
342- # Check what .node files exist
343- echo "=== Available .node files ==="
344- ls -la *.node || echo "No .node files found"
345-
346- # Check what .node files exist and patch Python dependencies
347- echo "=== Checking .node file Python dependencies ==="
348- for file in *.node; do
349- if [ -f "$file" ]; then
350- case "$file" in
351- *linux*)
352- echo "Checking $file..."
353- echo "Python dependencies before patching:"
354- ldd "$file" 2>/dev/null | grep python || echo "No Python dependencies found"
355-
356- # Check if we need to patch SONAME
357- current_python_lib=$(ldd "$file" 2>/dev/null | grep "libpython" | head -1 | awk '{print $1}')
358- if [ -n "$current_python_lib" ]; then
359- echo "Current Python library: $current_python_lib"
360-
361- # Find the actual Python library on the system
362- system_python_lib=$(find /usr/lib* -name "libpython3*.so.*" -type f 2>/dev/null | head -1)
363- if [ -n "$system_python_lib" ]; then
364- system_python_soname=$(basename "$system_python_lib")
365- echo "System Python library: $system_python_soname"
366-
367- # Only patch if they're different
368- if [ "$current_python_lib" != "$system_python_soname" ]; then
369- echo "Patching SONAME from $current_python_lib to $system_python_soname"
370- patchelf --replace-needed "$current_python_lib" "$system_python_soname" "$file"
371- echo "SONAME patching completed"
372- else
373- echo "SONAME already matches system Python"
374- fi
375- else
376- echo "Warning: Could not find system Python library"
377- fi
378- else
379- echo "No Python library dependency found"
380- fi
381-
382- echo "Python dependencies after patching:"
383- ldd "$file" 2>/dev/null | grep python || echo "No Python dependencies found"
384- echo "---"
385- ;;
386- *)
387- echo "Skipping non-Linux file: $file"
388- ;;
389- esac
390- fi
391- done
392-
393- # Install pnpm and run tests
394- echo "=== Installing pnpm ==="
395338 corepack disable
396339 npm i -gf pnpm
397-
398- echo "=== Running pnpm install ==="
399- # Should be non-interactive in CI environment
400340 pnpm install --prefer-offline
401-
402- echo "=== Setting up Python library path ==="
403- export LD_LIBRARY_PATH=/usr/lib/x86_64-linux-gnu:$LD_LIBRARY_PATH
404- echo "LD_LIBRARY_PATH: $LD_LIBRARY_PATH"
405-
406-
407- echo "=== Running tests ==="
408341 pnpm test
409342
410343 publish :
@@ -430,6 +363,27 @@ jobs:
430363 path : artifacts
431364 - name : Move artifacts
432365 run : pnpm artifacts
366+ - name : Copy fix-python-soname files to Linux packages
367+ run : |
368+ # Find the WASM and JS files from Linux artifacts
369+ WASM_FILE=$(find artifacts -name "fix-python-soname.wasm" | head -n 1)
370+ JS_FILE=$(find artifacts -name "fix-python-soname.js" | head -n 1)
371+
372+ if [ -n "$WASM_FILE" ] && [ -n "$JS_FILE" ]; then
373+ echo "Found WASM file: $WASM_FILE"
374+ echo "Found JS file: $JS_FILE"
375+
376+ # Copy to all Linux npm directories
377+ for dir in npm/*/; do
378+ if [[ "$dir" == *"linux"* ]]; then
379+ echo "Copying files to $dir"
380+ cp "$WASM_FILE" "$dir"
381+ cp "$JS_FILE" "$dir"
382+ fi
383+ done
384+ else
385+ echo "Warning: fix-python-soname files not found in artifacts"
386+ fi
433387 - name : List packages
434388 run : ls -R ./npm
435389 shell : bash
0 commit comments