Skip to content
This repository has been archived by the owner on Oct 22, 2021. It is now read-only.

Commit

Permalink
fix(ci): correctly build arm64v8 and armv7l/arm32v7 binaries using QE…
Browse files Browse the repository at this point in the history
…MU machine emulation - close #1051 (#1090)

* test: build armv7l and arm64v8 binaries using QEMU emulation #1051

* fix: use a 3-opts matrix for qemu emul buils, fix typo

* chore: remove leftover -qemu ci jobs

* fix: ci linux qemu cross-build: prevent unexpected crossbuilds

* feat: ci: disable fail-fast

* test: ci: specify electron-builder opts right in workflow file

* test: use arm64 ubuntu container on Actions

* test

* test2

* test2

* test2

* test2

* test3

* test4

* refactor: move arm64 builds to separate job

* fix typo

* fix: docker image name cannot be set with matrix otps

* fix missing rsync binary in arm64 node image

* fix missing rsync binary in arm64 node image

* fix missing rsync binary in arm64 node image

* perf: speed up arm64 qemu builds

* remove broken arm32v7 pipeline

* fix npm permissions errors on arm64

* do not restore incorrect caches

* rename linux-arm64 artifact to prevent conflicts

* test: re-enable qemu arm7 platform support

* fix ci job name typo

* cleanup workflow file

* disable broken apple silicon builds
  • Loading branch information
GitSquared authored Mar 17, 2021
1 parent 076a788 commit 6934283
Show file tree
Hide file tree
Showing 2 changed files with 106 additions and 68 deletions.
157 changes: 103 additions & 54 deletions .github/workflows/build-binaries.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -5,11 +5,8 @@ on: [push, pull_request, create]
jobs:
build-linux:
runs-on: ubuntu-latest
strategy:
matrix:
node-version: [14.x]
steps:
- uses: actions/checkout@v1
- uses: actions/checkout@v2
- name: Cache node modules
uses: actions/cache@v2
env:
Expand All @@ -18,10 +15,6 @@ jobs:
# npm cache files are stored in `~/.npm` on Linux/macOS
path: ~/.npm
key: ${{ runner.os }}-build-${{ env.cache-name }}-${{ hashFiles('**/package-lock.json') }}
restore-keys: |
${{ runner.os }}-build-${{ env.cache-name }}-
${{ runner.os }}-build-
${{ runner.os }}-
- name: Cache Electron binaries
uses: actions/cache@v2
env:
Expand All @@ -31,24 +24,22 @@ jobs:
# /~https://github.com/electron/get#how-it-works
path: ~/.cache/electron
key: ${{ runner.os }}-build-${{ env.cache-name }}-${{ hashFiles('**/package-lock.json') }}
restore-keys: |
${{ runner.os }}-build-${{ env.cache-name }}-
${{ runner.os }}-build-
${{ runner.os }}-
- name: Install system dependencies
- name: Install system dependencies for x64->x32 cross-build
run: |
sudo apt update
sudo apt install libc6-dev-i386 gcc-multilib g++-multilib
- name: Use Node.js ${{ matrix.node-version }}
- name: Setup Node.js
uses: actions/setup-node@v1
with:
node-version: ${{ matrix.node-version }}
- name: set up env
run: |
npm install
- name: npm build
run: |
npm run build-linux
node-version: 14
- name: Setup npm
run: sudo npm i -g npm@7
- name: Install build deps
run: npm install
- name: Run prebuild script
run: npm run prebuild-linux
- name: Build for x64 / ia32
run: ./node_modules/.bin/electron-builder build -l --x64 --ia32
env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- uses: actions/upload-artifact@v2
Expand All @@ -57,11 +48,86 @@ jobs:
path: dist/*.AppImage
if-no-files-found: error

build-linux-arm32:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- name: Setup QEMU
uses: docker/setup-qemu-action@v1
with:
platforms: arm
- name: Cache node modules
uses: actions/cache@v2
env:
cache-name: cache-node-modules
with:
# npm cache files are stored in `~/.npm` on Linux/macOS
path: ~/.npm
key: ${{ runner.os }}-build-${{ env.cache-name }}-${{ hashFiles('**/package-lock.json') }}
- name: Cache Electron binaries
uses: actions/cache@v2
env:
cache-name: cache-electron-bins
with:
# cache location is described here:
# /~https://github.com/electron/get#how-it-works
path: ~/.cache/electron
key: ${{ runner.os }}-build-${{ env.cache-name }}-${{ hashFiles('**/package-lock.json') }}
- name: Run prebuild outside of QEMU emulator
run: sudo npm i -g npm@7 && npm install && rsync -a --info=progress2 src/ prebuild-src --exclude node_modules && node prebuild-minify.js && rm -rf node_modules
- name: Build for arm32v7 (aka armv7l)
uses: docker://arm32v7/node:14-buster
with:
args: bash -c "npm i -g npm@7 && npm install && ./node_modules/.bin/electron-builder build -l --armv7l"
env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- uses: actions/upload-artifact@v2
with:
name: Linux-arm32-AppImage
path: dist/*.AppImage
if-no-files-found: error

build-linux-arm64:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- name: Setup QEMU
uses: docker/setup-qemu-action@v1
with:
platforms: arm64
- name: Cache node modules
uses: actions/cache@v2
env:
cache-name: cache-node-modules
with:
# npm cache files are stored in `~/.npm` on Linux/macOS
path: ~/.npm
key: ${{ runner.os }}-build-${{ env.cache-name }}-${{ hashFiles('**/package-lock.json') }}
- name: Cache Electron binaries
uses: actions/cache@v2
env:
cache-name: cache-electron-bins
with:
# cache location is described here:
# /~https://github.com/electron/get#how-it-works
path: ~/.cache/electron
key: ${{ runner.os }}-build-${{ env.cache-name }}-${{ hashFiles('**/package-lock.json') }}
- name: Run prebuild outside of QEMU emulator
run: sudo npm i -g npm@7 && npm install && rsync -a --info=progress2 src/ prebuild-src --exclude node_modules && node prebuild-minify.js && rm -rf node_modules
- name: Build for arm64 (aka arm64v8)
uses: docker://arm64v8/node:14-buster
with:
args: bash -c "npm i -g npm@7 && npm install && ./node_modules/.bin/electron-builder build -l --arm64"
env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- uses: actions/upload-artifact@v2
with:
name: Linux-arm64-AppImage
path: dist/*.AppImage
if-no-files-found: error

build-windows:
runs-on: windows-latest
strategy:
matrix:
node-version: [14.x]
steps:
- uses: actions/checkout@v1
- name: Get npm cache directory
Expand All @@ -72,8 +138,6 @@ jobs:
with:
path: ${{ steps.npm-cache.outputs.dir }}
key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }}
restore-keys: |
${{ runner.os }}-node-
- name: Cache Electron binaries
uses: actions/cache@v2
env:
Expand All @@ -83,20 +147,16 @@ jobs:
# /~https://github.com/electron/get#how-it-works
path: ~/AppData/Local/electron/Cache
key: ${{ runner.os }}-build-${{ env.cache-name }}-${{ hashFiles('**/package-lock.json') }}
restore-keys: |
${{ runner.os }}-build-${{ env.cache-name }}-
${{ runner.os }}-build-
${{ runner.os }}-
- name: Use Node.js ${{ matrix.node-version }}
- name: Setup Node.js
uses: actions/setup-node@v1
with:
node-version: ${{ matrix.node-version }}
node-version: 14
- name: Setup npm
run: npm i -g npm@7
- name: npm install
run: |
npm install
run: npm install
- name: npm build
run: |
npm run build-windows
run: npm run build-windows
env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- uses: actions/upload-artifact@v2
Expand All @@ -107,9 +167,6 @@ jobs:

build-darwin:
runs-on: macos-latest
strategy:
matrix:
node-version: [14.x]
steps:
- uses: actions/checkout@v1
- name: Cache node modules
Expand All @@ -120,10 +177,6 @@ jobs:
# npm cache files are stored in `~/.npm` on Linux/macOS
path: ~/.npm
key: ${{ runner.os }}-build-${{ env.cache-name }}-${{ hashFiles('**/package-lock.json') }}
restore-keys: |
${{ runner.os }}-build-${{ env.cache-name }}-
${{ runner.os }}-build-
${{ runner.os }}-
- name: Cache Electron binaries
uses: actions/cache@v2
env:
Expand All @@ -133,20 +186,16 @@ jobs:
# /~https://github.com/electron/get#how-it-works
path: ~/Library/Caches/electron
key: ${{ runner.os }}-build-${{ env.cache-name }}-${{ hashFiles('**/package-lock.json') }}
restore-keys: |
${{ runner.os }}-build-${{ env.cache-name }}-
${{ runner.os }}-build-
${{ runner.os }}-
- name: Use Node.js ${{ matrix.node-version }}
- name: Setup Node.js
uses: actions/setup-node@v1
with:
node-version: ${{ matrix.node-version }}
- name: set up env
run: |
npm install
node-version: 14
- name: Setup npm
run: sudo npm i -g npm@7
- name: npm install
run: npm install
- name: npm build
run: |
npm run build-darwin
run: npm run build-darwin
env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- uses: actions/upload-artifact@v2
Expand Down
17 changes: 3 additions & 14 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@
"prebuild-linux": "rsync -a --info=progress2 src/ prebuild-src --exclude node_modules && node prebuild-minify.js && cd prebuild-src && npm install",
"prebuild-darwin": "rsync -a src/ prebuild-src --exclude node_modules && node prebuild-minify.js && cd prebuild-src && npm install",
"prebuild-windows": "mkdir prebuild-src && xcopy src\\* prebuild-src\\ /E /C /Q /Y && node prebuild-minify.js && cd prebuild-src && npm install",
"build-linux": "./node_modules/.bin/electron-builder build -l",
"build-linux": "./node_modules/.bin/electron-builder build -l --x64 --ia32 --arm64 --armv7l",
"build-darwin": "./node_modules/.bin/electron-builder build -m",
"build-windows": "node_modules\\.bin\\electron-builder build -w",
"postbuild-linux": "rm -R prebuild-src",
Expand Down Expand Up @@ -55,17 +55,7 @@
"npmRebuild": true,
"artifactName": "eDEX-UI-${os}-${arch}.${ext}",
"linux": {
"target": [
{
"target": "AppImage",
"arch": [
"x64",
"ia32",
"arm64",
"armv7l"
]
}
],
"target": ["AppImage"],
"category": "System",
"icon": "media/linuxIcons"
},
Expand All @@ -77,8 +67,7 @@
{
"target": "dmg",
"arch": [
"x64",
"arm64"
"x64"
]
}
],
Expand Down

0 comments on commit 6934283

Please sign in to comment.