Skip to content

Commit

Permalink
gggg
Browse files Browse the repository at this point in the history
  • Loading branch information
dfunckt committed Nov 21, 2023
1 parent e145aa7 commit d727caa
Show file tree
Hide file tree
Showing 6 changed files with 79 additions and 49 deletions.
53 changes: 29 additions & 24 deletions .github/actions/publish/action.yml
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@ runs:

- name: Extract custom source artifact
if: runner.os != 'Windows'
shell: pwsh
shell: bash
working-directory: .
run: tar -xf ${{ runner.temp }}/custom.tgz

Expand All @@ -47,11 +47,8 @@ runs:

- name: Install host dependencies
if: runner.os == 'Linux'
shell: bash --noprofile --norc -eo pipefail -x {0}
run: |
set -ea
sudo apt-get update
sudo apt-get install -y --no-install-recommends fakeroot dpkg rpm
shell: bash
run: sudo apt-get install -y --no-install-recommends fakeroot dpkg rpm

- name: Install host dependencies
if: runner.os == 'macOS'
Expand All @@ -66,7 +63,7 @@ runs:
# https://dev.to/rwwagner90/signing-electron-apps-with-github-actions-4cof
- name: Import Apple code signing certificate
if: runner.os == 'macOS'
shell: bash --noprofile --norc -eo pipefail -x {0}
shell: bash
run: |
KEY_CHAIN=build.keychain
CERTIFICATE_P12=certificate.p12
Expand Down Expand Up @@ -102,34 +99,37 @@ runs:
encodedString: ${{ fromJSON(inputs.secrets).WINDOWS_SIGNING }}

- name: Package release
id: package_release
shell: bash --noprofile --norc -eo pipefail -x {0}
shell: bash
# IMPORTANT: before making changes to this step please consult @engineering in balena's chat.
run: |
set -ea
[[ '${{ inputs.VERBOSE }}' =~ on|On|Yes|yes|true|True ]] && set -x
runner_os="$(echo "${RUNNER_OS}" | tr '[:upper:]' '[:lower:]')"
if [[ '${{ inputs.VERBOSE }}' =~ on|On|Yes|yes|true|True ]]; then
export DEBUG='electron-forge:*,electron-packager,electron-rebuild'
fi
APPLICATION_VERSION="$(jq -r '.version' package.json)"
if [[ $runner_os =~ linux ]]; then
BUILD_ARCH=x64
npm run make -- --arch="${BUILD_ARCH}"
if [[ "${RUNNER_OS}" == Linux ]]; then
BUILD_ARCHS="x64"
SHA256SUM_BIN=sha256sum
elif [[ $runner_os =~ darwin|macos|osx ]]; then
BUILD_ARCH=x64,arm64
npm run make -- --arch="${BUILD_ARCH}"
elif [[ "${RUNNER_OS}" == macOS ]]; then
BUILD_ARCHS="x64 arm64"
SHA256SUM_BIN='shasum -a 256'
elif [[ $runner_os =~ windows|win ]]; then
BUILD_ARCH=ia32,x64
npm run make-debug-win -- --arch="${BUILD_ARCH}"
elif [[ "${RUNNER_OS}" == Windows ]]; then
#BUILD_ARCHS="ia32 x64" -- distutils fails to build for ia32
BUILD_ARCHS="x64"
else
echo "ERROR: unexpected runner OS: ${runner_os}"
echo "ERROR: unexpected runner OS: ${RUNNER_OS}"
exit 1
fi
for arch in ${BUILD_ARCHS}; do
echo "Building on $RUNNER_OS for $arch"
npx electron-forge make --arch=${arch}
done
echo "version=${APPLICATION_VERSION}" >> $GITHUB_OUTPUT
# collect all artifacts from subdirectories under a common top-level directory
Expand All @@ -143,6 +143,11 @@ runs:
-iname "*Setup.exe" \
\) -ls -exec cp '{}' dist/ \;
if [[ -n "${SHA256SUM_BIN}" ]]; then
# Compute and save digests.
cd dist/
${SHA256SUM_BIN} *.* >"SHA256SUMS.${RUNNER_OS}.txt"
fi
env:
# ensure we sign the artifacts
NODE_ENV: production
Expand Down
19 changes: 8 additions & 11 deletions .github/actions/test/action.yml
Original file line number Diff line number Diff line change
Expand Up @@ -30,10 +30,8 @@ runs:

- name: Install host dependencies
if: runner.os == 'Linux'
shell: bash --noprofile --norc -eo pipefail -x {0}
shell: bash
run: |
set -ea
sudo apt-get update
sudo apt-get install -y --no-install-recommends xvfb libudev-dev
cat < package.json | jq -r '.hostDependencies[][]' - | \
xargs -L1 echo | sed 's/|//g' | xargs -L1 \
Expand All @@ -48,21 +46,20 @@ runs:
with:
python-version: '3.11'

- name: Install project dependencies
shell: bash
run: npm ci

- name: Test release
shell: bash --noprofile --norc -eo pipefail -x {0}
run: |
set -ea
runner_os="$(echo "${RUNNER_OS}" | tr '[:upper:]' '[:lower:]')"
npm ci
npm run package
npm run test-${runner_os}
shell: bash
run: ./build/test-all.sh
env:
# https://www.electronjs.org/docs/latest/api/environment-variables
ELECTRON_NO_ATTACH_CONSOLE: 'true'

- name: Compress custom source
if: runner.os != 'Windows'
shell: pwsh
shell: bash
run: tar -acf ${{ runner.temp }}/custom.tgz .

- name: Compress custom source
Expand Down
3 changes: 3 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -96,6 +96,9 @@ out/

# ---- Do not modify entries above this line ----

# Build artifacts
dist/

# Certificates
*.spc
*.pvk
Expand Down
23 changes: 23 additions & 0 deletions build/test-all.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
#!/usr/bin/env bash

set -ea

if [[ "$VERBOSE" =~ 1|on|On|Yes|yes|true|True ]]; then
set +x
export DEBUG='electron-forge:*,electron-packager,electron-rebuild'
fi

npm run package
npm run lint

case "$(uname -s)" in
"Linux")
xvfb-run --auto-servernum npm run test-gui && xvfb-run --auto-servernum npm run test-shared
;;
"Darwin")
npm run test-gui && npm run test-shared
;;
"Windows"*|"MINGW"*|"MSYS"*)
npm run test-gui && npm run test-shared
;;
esac
4 changes: 3 additions & 1 deletion forge.config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ import { MakerDMG } from '@electron-forge/maker-dmg';
import { MakerAppImage } from '@reforged/maker-appimage';
import { AutoUnpackNativesPlugin } from '@electron-forge/plugin-auto-unpack-natives';
import { WebpackPlugin } from '@electron-forge/plugin-webpack';
import { ResourcePlugin } from 'electron-forge-resource-plugin';
// import { ResourcePlugin } from 'electron-forge-resource-plugin';

import { mainConfig, rendererConfig } from './webpack.config';

Expand Down Expand Up @@ -134,6 +134,7 @@ const config: ForgeConfig = {
],
},
}),
/*
new ResourcePlugin({
env: 'ETCHER_UTIL_BIN_PATH',
path: `out/sidecar/bin/etcher-util${process.platform === 'win32' ? '.exe' : ''}`,
Expand All @@ -142,6 +143,7 @@ const config: ForgeConfig = {
sources: './lib/util/',
},
}),
*/
],
};

Expand Down
26 changes: 13 additions & 13 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -74,15 +74,15 @@
"devDependencies": {
"@babel/register": "^7.22.15",
"@balena/lint": "5.4.2",
"@electron-forge/cli": "^6.4.2",
"@electron-forge/maker-deb": "^6.4.2",
"@electron-forge/maker-dmg": "^6.4.2",
"@electron-forge/maker-rpm": "^6.4.2",
"@electron-forge/maker-squirrel": "^6.4.2",
"@electron-forge/maker-zip": "^6.4.2",
"@electron-forge/plugin-auto-unpack-natives": "^6.4.2",
"@electron-forge/plugin-webpack": "^6.4.2",
"@reforged/maker-appimage": "^3.3.1",
"@electron-forge/cli": "6.4.2",
"@electron-forge/maker-deb": "6.4.2",
"@electron-forge/maker-dmg": "6.4.2",
"@electron-forge/maker-rpm": "6.4.2",
"@electron-forge/maker-squirrel": "6.4.2",
"@electron-forge/maker-zip": "6.4.2",
"@electron-forge/plugin-auto-unpack-natives": "6.4.2",
"@electron-forge/plugin-webpack": "6.4.2",
"@reforged/maker-appimage": "3.3.1",
"@svgr/webpack": "5.5.0",
"@types/chai": "4.3.4",
"@types/copy-webpack-plugin": "6.4.3",
Expand All @@ -96,14 +96,14 @@
"@types/semver": "7.3.13",
"@types/sinon": "9.0.11",
"@types/tmp": "0.2.3",
"@vercel/webpack-asset-relocator-loader": "^1.7.3",
"@vercel/webpack-asset-relocator-loader": "1.7.3",
"chai": "4.3.7",
"css-loader": "5.2.7",
"electron": "^25.8.2",
"electron-forge-resource-plugin": "^1.0.0-alpha.6",
"electron": "25.8.2",
"electron-forge-resource-plugin": "1.0.0-alpha.6",
"electron-mocha": "^11.0.2",
"electron-notarize": "1.2.2",
"electron-rebuild": "^3.2.9",
"electron-rebuild": "3.2.9",
"file-loader": "6.2.0",
"husky": "4.3.8",
"lint-staged": "10.5.4",
Expand Down

0 comments on commit d727caa

Please sign in to comment.