From 1bcdc26a73810b06129cf853e7cdfcb333c49146 Mon Sep 17 00:00:00 2001 From: Ira Hopkinson Date: Tue, 26 Sep 2023 13:54:33 +1300 Subject: [PATCH] Publish on main --- .github/workflows/publish-main.yml | 162 +++++++++++++++++++++++++++++ .github/workflows/publish.yml | 2 +- .github/workflows/test.yml | 2 +- electron-builder.json5 | 4 +- release/app/package-lock.json | 4 +- release/app/package.json | 4 +- 6 files changed, 170 insertions(+), 8 deletions(-) create mode 100644 .github/workflows/publish-main.yml diff --git a/.github/workflows/publish-main.yml b/.github/workflows/publish-main.yml new file mode 100644 index 0000000000..5afa9405fa --- /dev/null +++ b/.github/workflows/publish-main.yml @@ -0,0 +1,162 @@ +name: Publish + +on: + push: + branches: [main] + # DEBUG testing-only - remove this before merge + pull_request: + branches: [main] + workflow_dispatch: + inputs: + debug_enabled: + type: boolean + description: 'Run the build with tmate debugging enabled (https://github.com/marketplace/actions/debugging-with-tmate)' + required: false + default: false + +jobs: + publish: + name: Main on ${{ matrix.os }}, .Net ${{ matrix.dotnet_version }}, node ${{ matrix.node_version }} + + runs-on: ${{ matrix.os }} + + strategy: + matrix: + os: [macos-latest, ubuntu-latest] + dotnet_version: [7.0.x] + node_version: [18.x] + + steps: + - name: Checkout git repo + uses: actions/checkout@v3 + + - name: Install .NET + uses: actions/setup-dotnet@v3 + with: + dotnet-version: ${{matrix.dotnet_version}} + + - name: Install Node and NPM + uses: actions/setup-node@v3 + with: + node-version: ${{ matrix.node_version }} + cache: npm + + - name: Install and build + run: | + npm install + npm run build + + - name: Download previous build artifacts + uses: actions/download-artifact@v3 + with: + name: previous-build + + - name: Set build number + # Retrieve the current build number from a file (if it exists) + id: set_build_number + # Only increment on Linux so all OS's have the same build number + env: + CAN_INCREMENT: ${{ matrix.os != 'macos-latest' }} + run: | + if [[ -f build_number.txt ]]; then + BUILD_NUMBER=$(cat build_number.txt) + else + BUILD_NUMBER=0 + fi + if [[ CAN_INCREMENT ]]; then + BUILD_NUMBER=$((BUILD_NUMBER + 1)) + fi + echo $BUILD_NUMBER > build_number.txt + echo "build_number=$BUILD_NUMBER" >> $GITHUB_OUTPUT + + - name: Update release version + env: + BUILD_NUMBER: ${{ steps.set_build_number.outputs.build_number }} + run: | + if [[ -f current_version.txt ]]; then + PREVIOUS_VERSION=$(cat current_version.txt) + else + PREVIOUS_VERSION=0 + fi + cd ./release/app + CURRENT_VERSION=$(node -pe "require('./package.json').version") + echo $CURRENT_VERSION > ../../current_version.txt + if [[ CURRENT_VERSION == PREVIOUS_VERSION ]]; then + BUILD_NUMBER=0 + fi + NEW_VERSION="${CURRENT_VERSION}-${BUILD_NUMBER}" + echo "Updating version from ${CURRENT_VERSION} to ${NEW_VERSION}" + npm version $NEW_VERSION + + - name: Upload previous build artifacts + uses: actions/upload-artifact@v3 + with: + name: previous-build + path: | + build_number.txt + current_version.txt + + - name: Install DMG license + if: ${{ matrix.os == 'macos-latest' }} + run: npm install dmg-license + + - name: dotnet build - MacOS and Windows + if: ${{ matrix.os == 'macos-latest' }} + run: | + npm run build:data-release:windows + npm run build:data-release:macos + + - name: dotnet build - Linux + if: ${{ matrix.os == 'ubuntu-latest' }} + run: npm run build:data-release:linux + + - name: Publish releases - Windows and MacOS + if: ${{ matrix.os == 'macos-latest' }} + # env: + # # These values are used for auto updates signing + # APPLE_ID: ${{ secrets.APPLE_ID }} + # APPLE_ID_PASS: ${{ secrets.APPLE_ID_PASS }} + # CSC_LINK: ${{ secrets.CSC_LINK }} + # CSC_KEY_PASSWORD: ${{ secrets.CSC_KEY_PASSWORD }} + run: | + npm exec electron-builder -- build --publish never --win --mac + + - name: Publish releases - Linux + if: ${{ matrix.os == 'ubuntu-latest' }} + env: + # no hardlinks so dependencies are copied + USE_HARD_LINKS: false + run: | + npm exec electron-builder -- build --publish never --linux + + - name: Upload macOS artifacts + if: ${{ matrix.os == 'macos-latest' }} + uses: actions/upload-artifact@v3 + with: + name: app-macos + path: | + ./release/build/*.dmg + + - name: Upload Windows artifacts + if: ${{ matrix.os == 'macos-latest' }} + uses: actions/upload-artifact@v3 + with: + name: app-windows + path: | + ./release/build/*.exe + !./release/build/*Setup*.exe + + - name: Upload Linux artifacts + if: ${{ matrix.os == 'ubuntu-latest' }} + uses: actions/upload-artifact@v3 + with: + name: app-linux + path: | + ./release/build/*.AppImage + + # Enable tmate debugging of manually-triggered workflows if the input option was provided + - name: Setup tmate session + if: ${{ github.event_name == 'workflow_dispatch' && inputs.debug_enabled }} + uses: mxschmitt/action-tmate@v3 + with: + limit-access-to-actor: true diff --git a/.github/workflows/publish.yml b/.github/workflows/publish.yml index 240406ba7b..215afa097f 100644 --- a/.github/workflows/publish.yml +++ b/.github/workflows/publish.yml @@ -13,7 +13,7 @@ on: jobs: publish: - name: Publish on ${{ matrix.os }}, .Net ${{ matrix.dotnet_version }}, and node ${{ matrix.node_version }} + name: Release on ${{ matrix.os }}, .Net ${{ matrix.dotnet_version }}, node ${{ matrix.node_version }} runs-on: ${{ matrix.os }} diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index eac5f78721..073b9140b3 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -16,7 +16,7 @@ on: jobs: test: - name: Test on ${{ matrix.os }}, .Net ${{ matrix.dotnet_version }}, and node ${{ matrix.node_version }} + name: Build on ${{ matrix.os }}, .Net ${{ matrix.dotnet_version }}, node ${{ matrix.node_version }} runs-on: ${{ matrix.os }} diff --git a/electron-builder.json5 b/electron-builder.json5 index 26b2729024..ac6766aef2 100644 --- a/electron-builder.json5 +++ b/electron-builder.json5 @@ -2,8 +2,8 @@ * @see https://www.electron.build/configuration/configuration */ { - productName: 'ParanextCore', - appId: 'org.paranext.ParanextCore', + productName: 'Platform.Bible', + appId: 'org.paranext.PlatformBible', asar: true, asarUnpack: '**\\*.{node,dll}', files: ['dist', 'node_modules', 'package.json'], diff --git a/release/app/package-lock.json b/release/app/package-lock.json index 06e3d2841d..2baa393ec7 100644 --- a/release/app/package-lock.json +++ b/release/app/package-lock.json @@ -1,11 +1,11 @@ { - "name": "Paranext", + "name": "platform.bible", "version": "0.0.2", "lockfileVersion": 2, "requires": true, "packages": { "": { - "name": "Paranext", + "name": "platform.bible", "version": "0.0.2", "hasInstallScript": true, "license": "MIT" diff --git a/release/app/package.json b/release/app/package.json index 512bf7bf6c..0f55e8c25f 100644 --- a/release/app/package.json +++ b/release/app/package.json @@ -1,10 +1,10 @@ { - "name": "Paranext", + "name": "platform.bible", "version": "0.0.2", "description": "Extensible Bible translation software", "license": "MIT", "author": { - "name": "Paranext", + "name": "Platform.Bible", "url": "https://github.com/paranext/" }, "main": "./dist/main/main.js",