2022-10-09 16:16:42 +03:00
|
|
|
import path from 'node:path'
|
|
|
|
|
|
|
|
import { prompt } from 'inquirer'
|
|
|
|
import { command } from 'execa'
|
|
|
|
|
2023-04-30 18:39:39 +03:00
|
|
|
import {
|
|
|
|
NODEJS_BRIDGE_SRC_PATH,
|
|
|
|
PYTHON_BRIDGE_SRC_PATH,
|
|
|
|
TCP_SERVER_SRC_PATH
|
|
|
|
} from '@/constants'
|
2022-10-09 16:16:42 +03:00
|
|
|
import { LogHelper } from '@/helpers/log-helper'
|
|
|
|
import { LoaderHelper } from '@/helpers/loader-helper'
|
|
|
|
|
|
|
|
/**
|
2022-10-09 16:27:12 +03:00
|
|
|
* Pre-release binaries via GitHub Actions
|
2022-10-09 16:16:42 +03:00
|
|
|
* 1. Ask for confirmation whether the binary version has been bumped
|
2022-10-09 16:27:12 +03:00
|
|
|
* 2. Trigger GitHub workflow to pre-release binaries
|
2022-10-09 16:16:42 +03:00
|
|
|
*/
|
|
|
|
|
|
|
|
const BUILD_TARGETS = new Map()
|
|
|
|
|
2023-04-30 18:39:39 +03:00
|
|
|
BUILD_TARGETS.set('nodejs-bridge', {
|
|
|
|
workflowFileName: 'pre-release-nodejs-bridge.yml',
|
|
|
|
versionFilePath: path.join(NODEJS_BRIDGE_SRC_PATH, 'version.ts')
|
|
|
|
})
|
2022-10-09 16:16:42 +03:00
|
|
|
BUILD_TARGETS.set('python-bridge', {
|
2022-10-09 18:39:22 +03:00
|
|
|
workflowFileName: 'pre-release-python-bridge.yml',
|
2023-04-26 17:33:10 +03:00
|
|
|
versionFilePath: path.join(PYTHON_BRIDGE_SRC_PATH, 'version.py')
|
2022-10-09 16:16:42 +03:00
|
|
|
})
|
|
|
|
BUILD_TARGETS.set('tcp-server', {
|
2022-10-09 18:39:22 +03:00
|
|
|
workflowFileName: 'pre-release-tcp-server.yml',
|
2023-04-26 17:33:10 +03:00
|
|
|
versionFilePath: path.join(TCP_SERVER_SRC_PATH, 'version.py')
|
2022-10-09 16:16:42 +03:00
|
|
|
})
|
|
|
|
;(async () => {
|
|
|
|
LoaderHelper.start()
|
|
|
|
|
|
|
|
const { argv } = process
|
|
|
|
const givenReleaseTarget = argv[2].toLowerCase()
|
2022-10-09 18:53:40 +03:00
|
|
|
const givenBranch = argv[3]?.toLowerCase()
|
2023-04-26 17:33:10 +03:00
|
|
|
const { workflowFileName, versionFilePath } =
|
2022-10-09 16:16:42 +03:00
|
|
|
BUILD_TARGETS.get(givenReleaseTarget)
|
|
|
|
|
|
|
|
LoaderHelper.stop()
|
|
|
|
const answer = await prompt({
|
|
|
|
type: 'confirm',
|
|
|
|
name: 'binary.bumped',
|
2023-04-26 17:33:10 +03:00
|
|
|
message: `Have you bumped the version number of the binary from the "${versionFilePath}" file?`,
|
2022-10-09 16:16:42 +03:00
|
|
|
default: false
|
|
|
|
})
|
|
|
|
LoaderHelper.start()
|
|
|
|
|
|
|
|
if (!answer.binary.bumped) {
|
|
|
|
LogHelper.info(
|
2023-04-26 17:34:47 +03:00
|
|
|
'Please bump the version number of the binary from the version file before continuing'
|
2022-10-09 16:16:42 +03:00
|
|
|
)
|
|
|
|
process.exit(0)
|
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
|
|
|
LogHelper.info('Triggering the GitHub workflow...')
|
|
|
|
|
2022-10-09 18:53:40 +03:00
|
|
|
const runWorkflowCommand = !givenBranch
|
|
|
|
? `gh workflow run ${workflowFileName}`
|
|
|
|
: `gh workflow run ${workflowFileName} --ref ${givenBranch}`
|
|
|
|
|
|
|
|
await command(runWorkflowCommand, {
|
2022-10-09 16:16:42 +03:00
|
|
|
shell: true,
|
|
|
|
stdout: 'inherit'
|
|
|
|
})
|
|
|
|
|
2022-10-09 16:27:12 +03:00
|
|
|
LogHelper.success(
|
|
|
|
'GitHub workflow triggered. The pre-release is on its way!'
|
|
|
|
)
|
|
|
|
LogHelper.success(
|
|
|
|
'Once the pre-release is done, go to the GitHub releases to double-check information and hit release'
|
|
|
|
)
|
2022-10-09 18:58:59 +03:00
|
|
|
|
|
|
|
process.exit(0)
|
2022-10-09 16:16:42 +03:00
|
|
|
} catch (e) {
|
|
|
|
LogHelper.error(
|
|
|
|
`An error occurred while triggering the GitHub workflow: ${e}`
|
|
|
|
)
|
|
|
|
process.exit(1)
|
|
|
|
}
|
|
|
|
})()
|