mirror of
https://github.com/balena-io/balena-cli.git
synced 2024-12-24 07:46:39 +00:00
09d004423c
Change-type: patch
108 lines
3.3 KiB
TypeScript
108 lines
3.3 KiB
TypeScript
/**
|
|
* @license
|
|
* Copyright 2019 Balena Ltd.
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
import * as _ from 'lodash';
|
|
|
|
import {
|
|
buildOclifInstaller,
|
|
buildStandaloneZip,
|
|
catchUncommitted,
|
|
testShrinkwrap,
|
|
} from './build-bin';
|
|
import {
|
|
release,
|
|
updateDescriptionOfReleasesAffectedByIssue1359,
|
|
} from './deploy-bin';
|
|
|
|
// DEBUG set to falsy for negative values else is truthy
|
|
process.env.DEBUG = ['0', 'no', 'false', '', undefined].includes(
|
|
process.env.DEBUG?.toLowerCase(),
|
|
)
|
|
? ''
|
|
: '1';
|
|
|
|
/**
|
|
* Trivial command-line parser. Check whether the command-line argument is one
|
|
* of the following strings, then call the appropriate functions:
|
|
* 'build:installer' (to build a native oclif installer)
|
|
* 'build:standalone' (to build a standalone pkg package)
|
|
* 'release' (to create/update a GitHub release)
|
|
*
|
|
* @param args Arguments to parse (default is process.argv.slice(2))
|
|
*/
|
|
async function parse(args?: string[]) {
|
|
args = args || process.argv.slice(2);
|
|
console.error(`[debug] automation/run.ts process.argv=[${process.argv}]`);
|
|
console.error(`[debug] automation/run.ts args=[${args}]`);
|
|
if (_.isEmpty(args)) {
|
|
throw new Error('missing command-line arguments');
|
|
}
|
|
const commands: { [cmd: string]: () => void | Promise<void> } = {
|
|
'build:installer': buildOclifInstaller,
|
|
'build:standalone': buildStandaloneZip,
|
|
'catch-uncommitted': catchUncommitted,
|
|
'test-shrinkwrap': testShrinkwrap,
|
|
fix1359: updateDescriptionOfReleasesAffectedByIssue1359,
|
|
release,
|
|
};
|
|
for (const arg of args) {
|
|
if (!commands.hasOwnProperty(arg)) {
|
|
throw new Error(`command unknown: ${arg}`);
|
|
}
|
|
}
|
|
|
|
// The BUILD_TMP env var is used as an alternative location for oclif
|
|
// (patched) to copy/extract the CLI files, run npm install and then
|
|
// create the NSIS executable installer for Windows. This was necessary
|
|
// to avoid issues with a 260-char limit on Windows paths (possibly a
|
|
// limitation of some library used by NSIS), as the "current working dir"
|
|
// provided by balena CI is a rather long path to start with.
|
|
if (process.platform === 'win32' && !process.env.BUILD_TMP) {
|
|
const randID = (await import('crypto'))
|
|
.randomBytes(6)
|
|
.toString('base64')
|
|
.replace(/\+/g, '-')
|
|
.replace(/\//g, '_'); // base64url (RFC 4648)
|
|
process.env.BUILD_TMP = `C:\\tmp\\${randID}`;
|
|
}
|
|
|
|
for (const arg of args) {
|
|
try {
|
|
const cmdFunc = commands[arg];
|
|
await cmdFunc();
|
|
} catch (err) {
|
|
if (typeof err === 'object') {
|
|
err.message = `"${arg}": ${err.message}`;
|
|
}
|
|
throw err;
|
|
}
|
|
}
|
|
}
|
|
|
|
/** See jsdoc for parse() function above */
|
|
export async function run(args?: string[]) {
|
|
try {
|
|
await parse(args);
|
|
} catch (e) {
|
|
console.error(e.message ? `Error: ${e.message}` : e);
|
|
process.exitCode = 1;
|
|
}
|
|
}
|
|
|
|
// tslint:disable-next-line:no-floating-promises
|
|
run();
|