Build MSI and Portable packages for windows (#150)
This commit is contained in:
parent
d66845b79f
commit
d87072ab17
|
|
@ -24,9 +24,11 @@ jobs:
|
||||||
echo "LENS_VERSION=$LENS_VERSION" >> $GITHUB_ENV
|
echo "LENS_VERSION=$LENS_VERSION" >> $GITHUB_ENV
|
||||||
echo "BUILD_NUMBER=${{ github.run_number }}" >> $GITHUB_ENV
|
echo "BUILD_NUMBER=${{ github.run_number }}" >> $GITHUB_ENV
|
||||||
shell: bash
|
shell: bash
|
||||||
|
|
||||||
- uses: actions/setup-node@v3
|
- uses: actions/setup-node@v3
|
||||||
with:
|
with:
|
||||||
node-version: "16.x"
|
node-version: "16.x"
|
||||||
|
|
||||||
- name: Checkout Upstream Lens
|
- name: Checkout Upstream Lens
|
||||||
uses: actions/checkout@v3
|
uses: actions/checkout@v3
|
||||||
with:
|
with:
|
||||||
|
|
@ -34,37 +36,30 @@ jobs:
|
||||||
path: lens
|
path: lens
|
||||||
ref: v${{ env.LENS_VERSION }}
|
ref: v${{ env.LENS_VERSION }}
|
||||||
fetch-depth: 1
|
fetch-depth: 1
|
||||||
|
|
||||||
- name: Patch Upstream Lens
|
- name: Patch Upstream Lens
|
||||||
run: |
|
run: |
|
||||||
node update.js
|
node update.js
|
||||||
|
|
||||||
- name: Build Lens
|
- name: Build Lens
|
||||||
run: |
|
run: |
|
||||||
if [ "$RUNNER_OS" == "Windows" ]; then
|
|
||||||
choco install visualstudio2019buildtools visualstudio2019-workload-vctools
|
|
||||||
fi
|
|
||||||
|
|
||||||
npm run all:install
|
npm run all:install
|
||||||
# Avoid npm install from electron-builder
|
# Avoid npm install from electron-builder
|
||||||
# ref: https://github.com/electron-userland/electron-builder/blob/80a3ae857b9305aff1774e1b2b932601af50231b/packages/app-builder-lib/src/util/yarn.ts#L11-L16
|
# ref: https://github.com/electron-userland/electron-builder/blob/80a3ae857b9305aff1774e1b2b932601af50231b/packages/app-builder-lib/src/util/yarn.ts#L11-L16
|
||||||
mkdir open-lens/node_modules
|
mkdir open-lens/node_modules
|
||||||
|
|
||||||
if [ "$RUNNER_OS" == "macOS" ]; then
|
if [ "${CSC_LINK}" = "" ] || [ "${CSC_KEY_PASSWORD}" = "" ]; then
|
||||||
if [ "${CSC_LINK}" = "" ]; then
|
unset CSC_LINK
|
||||||
unset CSC_LINK
|
unset CSC_KEY_PASSWORD
|
||||||
fi
|
|
||||||
|
|
||||||
if [ "${CSC_KEY_PASSWORD}" = "" ]; then
|
|
||||||
unset CSC_KEY_PASSWORD
|
|
||||||
fi
|
|
||||||
|
|
||||||
npx nx run open-lens:build:app --x64 --arm64
|
|
||||||
elif [ "$RUNNER_OS" == "Linux" ]; then
|
|
||||||
npx nx run open-lens:build:app --x64 --arm64
|
|
||||||
else
|
|
||||||
unset DOWNLOAD_ALL_ARCHITECTURES
|
|
||||||
npx nx run open-lens:build:app
|
|
||||||
cp open-lens/dist/OpenLens*.exe open-lens/dist/OpenLens-${{ env.LENS_VERSION }}.${{ env.BUILD_NUMBER }}.exe
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if [ "$RUNNER_OS" == "Windows" ]; then
|
||||||
|
npx nx run open-lens:build:app --win nsis msi portable
|
||||||
|
else
|
||||||
|
npx nx run open-lens:build:app --x64 --arm64
|
||||||
|
fi
|
||||||
|
|
||||||
|
rm -f open-lens/dist/*blockmap{,*}
|
||||||
shell: bash
|
shell: bash
|
||||||
working-directory: lens
|
working-directory: lens
|
||||||
env:
|
env:
|
||||||
|
|
@ -72,21 +67,22 @@ jobs:
|
||||||
APPLEID: ${{ secrets.APPLEID }}
|
APPLEID: ${{ secrets.APPLEID }}
|
||||||
APPLEIDPASS: ${{ secrets.APPLEIDPASS }}
|
APPLEIDPASS: ${{ secrets.APPLEIDPASS }}
|
||||||
CSC_LINK: ${{ runner.os == 'macos' && secrets.CSC_LINK || secrets.CSC_LINK_WIN }}
|
CSC_LINK: ${{ runner.os == 'macos' && secrets.CSC_LINK || secrets.CSC_LINK_WIN }}
|
||||||
CSC_KEY_PASSWORD: ${{ runner.os == 'macos' && secrets.CSC_KEY_PASSWORD || secrets.CSC_KEY_PASSWORD_WIN}}
|
CSC_KEY_PASSWORD: ${{ runner.os == 'macos' && secrets.CSC_KEY_PASSWORD || secrets.CSC_KEY_PASSWORD_WIN }}
|
||||||
CSC_LINK_WIN: ${{ secrets.CSC_LINK_WIN }}
|
CSC_LINK_WIN: ${{ secrets.CSC_LINK_WIN }}
|
||||||
CSC_KEY_PASSWORD_WIN: ${{ secrets.CSC_KEY_PASSWORD_WIN }}
|
CSC_KEY_PASSWORD_WIN: ${{ secrets.CSC_KEY_PASSWORD_WIN }}
|
||||||
WIN_CSC_LINK: ${{ secrets.CSC_LINK_WIN }}
|
WIN_CSC_LINK: ${{ secrets.CSC_LINK_WIN }}
|
||||||
WIN_CSC_KEY_PASSWORD: ${{ secrets.CSC_KEY_PASSWORD_WIN }}
|
WIN_CSC_KEY_PASSWORD: ${{ secrets.CSC_KEY_PASSWORD_WIN }}
|
||||||
CSC_FOR_PULL_REQUEST: true
|
CSC_FOR_PULL_REQUEST: true
|
||||||
DOWNLOAD_ALL_ARCHITECTURES: true
|
DOWNLOAD_ALL_ARCHITECTURES: ${{ runner.os != 'Windows' }}
|
||||||
|
|
||||||
- name: Calculate SHA256 checksum
|
- name: Calculate SHA256 checksum
|
||||||
run: |
|
run: |-
|
||||||
if [ "$RUNNER_OS" == "Windows" ]; then
|
if command -v shasum 2>/dev/null 1>&2; then
|
||||||
certutil -hashfile OpenLens-${{ env.LENS_VERSION }}.${{ env.BUILD_NUMBER }}.exe SHA256 | tee OpenLens-${{ env.LENS_VERSION }}.${{ env.BUILD_NUMBER }}.exe.sha256
|
for filename in OpenLens*; do shasum -a 256 "${filename}" | tee "${filename}.sha256" ; done
|
||||||
else
|
else
|
||||||
for filename in OpenLens-${{ env.LENS_VERSION }}.${{ env.BUILD_NUMBER }}*; do shasum -a 256 ${filename} | tee ${filename}.sha256 ; done
|
for filename in OpenLens*; do certutil -hashfile "${filename}" SHA256 | tee "${filename}.sha256" ; done
|
||||||
fi
|
fi
|
||||||
|
|
||||||
shell: bash
|
shell: bash
|
||||||
working-directory: lens/open-lens/dist
|
working-directory: lens/open-lens/dist
|
||||||
|
|
||||||
|
|
@ -95,41 +91,24 @@ jobs:
|
||||||
with:
|
with:
|
||||||
name: OpenLens-${{ matrix.os }}
|
name: OpenLens-${{ matrix.os }}
|
||||||
retention-days: 5
|
retention-days: 5
|
||||||
path: |
|
path: lens/open-lens/dist/OpenLens*${{ env.LENS_VERSION }}-${{ env.BUILD_NUMBER }}*.*
|
||||||
lens/open-lens/dist/OpenLens-${{ env.LENS_VERSION }}.${{ env.BUILD_NUMBER }}*.dmg
|
|
||||||
lens/open-lens/dist/OpenLens-${{ env.LENS_VERSION }}.${{ env.BUILD_NUMBER }}*.AppImage
|
|
||||||
lens/open-lens/dist/OpenLens-${{ env.LENS_VERSION }}.${{ env.BUILD_NUMBER }}*.deb
|
|
||||||
lens/open-lens/dist/OpenLens-${{ env.LENS_VERSION }}.${{ env.BUILD_NUMBER }}*.rpm
|
|
||||||
lens/open-lens/dist/OpenLens-${{ env.LENS_VERSION }}.${{ env.BUILD_NUMBER }}*.zip
|
|
||||||
lens/open-lens/dist/OpenLens-${{ env.LENS_VERSION }}.${{ env.BUILD_NUMBER }}.exe
|
|
||||||
lens/open-lens/dist/OpenLens-${{ env.LENS_VERSION }}.${{ env.BUILD_NUMBER }}*.sha256
|
|
||||||
|
|
||||||
- name: Generate Changelog
|
- name: Generate Changelog
|
||||||
run: curl -s https://api.github.com/repos/lensapp/lens/releases/latest | jq -r 'select(.prerelease == false) | .body[0:]' > ${{ github.workspace }}-CHANGELOG.txt
|
run: curl -s https://api.github.com/repos/lensapp/lens/releases/latest | jq -r 'select(.prerelease == false) | .body[0:]' > ${{ github.workspace }}-CHANGELOG.txt
|
||||||
|
|
||||||
- name: Release
|
- name: Release
|
||||||
uses: softprops/action-gh-release@v0.1.15
|
uses: softprops/action-gh-release@v0.1.15
|
||||||
if: github.ref == 'refs/heads/main'
|
if: github.ref == 'refs/heads/main'
|
||||||
with:
|
with:
|
||||||
tag_name: v${{ env.LENS_VERSION }}.${{ env.BUILD_NUMBER }}
|
tag_name: v${{ env.LENS_VERSION }}-${{ env.BUILD_NUMBER }}
|
||||||
body_path: ${{ github.workspace }}-CHANGELOG.txt
|
body_path: ${{ github.workspace }}-CHANGELOG.txt
|
||||||
files: |
|
files: lens/open-lens/dist/OpenLens*${{ env.LENS_VERSION }}-${{ env.BUILD_NUMBER }}*.*
|
||||||
lens/open-lens/dist/OpenLens-${{ env.LENS_VERSION }}.${{ env.BUILD_NUMBER }}*.dmg
|
|
||||||
lens/open-lens/dist/OpenLens-${{ env.LENS_VERSION }}.${{ env.BUILD_NUMBER }}*.AppImage
|
|
||||||
lens/open-lens/dist/OpenLens-${{ env.LENS_VERSION }}.${{ env.BUILD_NUMBER }}*.deb
|
|
||||||
lens/open-lens/dist/OpenLens-${{ env.LENS_VERSION }}.${{ env.BUILD_NUMBER }}*.rpm
|
|
||||||
lens/open-lens/dist/OpenLens-${{ env.LENS_VERSION }}.${{ env.BUILD_NUMBER }}*.zip
|
|
||||||
lens/open-lens/dist/OpenLens-${{ env.LENS_VERSION }}.${{ env.BUILD_NUMBER }}.exe
|
|
||||||
lens/open-lens/dist/OpenLens-${{ env.LENS_VERSION }}.${{ env.BUILD_NUMBER }}*.sha256
|
|
||||||
- name: Latest
|
- name: Latest
|
||||||
uses: softprops/action-gh-release@v0.1.15
|
uses: softprops/action-gh-release@v0.1.15
|
||||||
if: github.ref == 'refs/heads/main'
|
if: github.ref == 'refs/heads/main'
|
||||||
with:
|
with:
|
||||||
tag_name: Latest
|
tag_name: Latest
|
||||||
files: |
|
files: |
|
||||||
lens/open-lens/dist/OpenLens-${{ env.LENS_VERSION }}.${{ env.BUILD_NUMBER }}*.dmg
|
lens/open-lens/dist/OpenLens*${{ env.LENS_VERSION }}-${{ env.BUILD_NUMBER }}*.*
|
||||||
lens/open-lens/dist/OpenLens-${{ env.LENS_VERSION }}.${{ env.BUILD_NUMBER }}*.AppImage
|
|
||||||
lens/open-lens/dist/OpenLens-${{ env.LENS_VERSION }}.${{ env.BUILD_NUMBER }}*.deb
|
|
||||||
lens/open-lens/dist/OpenLens-${{ env.LENS_VERSION }}.${{ env.BUILD_NUMBER }}*.rpm
|
|
||||||
lens/open-lens/dist/OpenLens-${{ env.LENS_VERSION }}.${{ env.BUILD_NUMBER }}*.zip
|
|
||||||
lens/open-lens/dist/OpenLens.Setup.${{ env.LENS_VERSION }}.${{ env.BUILD_NUMBER }}.exe
|
|
||||||
lens/open-lens/dist/lates*.yml
|
lens/open-lens/dist/lates*.yml
|
||||||
|
|
|
||||||
|
|
@ -7,10 +7,7 @@ packageJsonOpenLens.build.publish = [{
|
||||||
provider: "generic"
|
provider: "generic"
|
||||||
}];
|
}];
|
||||||
|
|
||||||
packageJsonOpenLens.version = `${packageJsonOpenLens.version}+${process.env.BUILD_NUMBER}`;
|
packageJsonOpenLens.version = `${packageJsonOpenLens.version}-${process.env.BUILD_NUMBER}`;
|
||||||
packageJsonOpenLens.build.artifactName = "${productName}-${buildVersion}-${arch}-${os}.${ext}";
|
|
||||||
packageJsonOpenLens.build.linux.artifactName = packageJsonOpenLens.build.linux.artifactName.replace("${version}", "${buildVersion}");
|
|
||||||
packageJsonOpenLens.build.win.artifactName = "OpenLens.Setup.${buildVersion}.${ext}";
|
|
||||||
packageJsonOpenLens.build.npmRebuild = true;
|
packageJsonOpenLens.build.npmRebuild = true;
|
||||||
|
|
||||||
console.log(`Set build version: ${packageJsonOpenLens.version}`)
|
console.log(`Set build version: ${packageJsonOpenLens.version}`)
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue