open-vault/ui/scripts/start-vault.js
claire bontempo 30f9bbd9f5
UI/Clarifies error message for exit test process (#12094)
* adds console log to elaborate on error message

* fixes browserstack failure
2021-07-15 12:54:42 -07:00

116 lines
3.2 KiB
JavaScript
Executable file

/* eslint-env node */
/* eslint-disable no-console */
/* eslint-disable no-process-exit */
/* eslint-disable node/no-extraneous-require */
var fs = require('fs');
var path = require('path');
var readline = require('readline');
var execa = require('execa');
var chalk = require('chalk');
function run(command, args = [], shareStd = true) {
console.log(chalk.dim('$ ' + command + ' ' + args.join(' ')));
// cleanup means that execa will handle stopping the vault subprocess
// inherit all of the stdin/out/err so that testem still works as if you were running it directly
if (shareStd) {
return execa(command, args, { cleanup: true, stdin: 'inherit', stdout: 'inherit', stderr: 'inherit' });
}
let p = execa(command, args, { cleanup: true });
p.stdout.pipe(process.stdout);
p.stderr.pipe(process.stderr);
return p;
}
var output = '';
var unseal, root, written, initError;
async function processLines(input, eachLine = () => {}) {
const rl = readline.createInterface({
input,
terminal: true,
});
for await (const line of rl) {
eachLine(line);
}
}
(async function() {
try {
let vault = run(
'vault',
[
'server',
'-dev',
'-dev-ha',
'-dev-transactional',
'-dev-root-token-id=root',
'-dev-listen-address=127.0.0.1:9200',
],
false
);
processLines(vault.stdout, function(line) {
if (written) {
output = null;
return;
}
output = output + line;
var unsealMatch = output.match(/Unseal Key: (.+)$/m);
if (unsealMatch && !unseal) {
unseal = unsealMatch[1];
}
var rootMatch = output.match(/Root Token: (.+)$/m);
if (rootMatch && !root) {
root = rootMatch[1];
}
var errorMatch = output.match(/Error initializing core: (.*)$/m);
if (errorMatch) {
initError = errorMatch[1];
}
if (root && unseal && !written) {
fs.writeFile(
path.join(process.cwd(), 'tests/helpers/vault-keys.js'),
`export default ${JSON.stringify({ unseal, root }, null, 2)}`,
err => {
if (err) throw err;
}
);
written = true;
console.log('VAULT SERVER READY');
} else if (initError) {
console.log('VAULT SERVER START FAILED');
console.log(
'If this is happening, run `export VAULT_LICENSE_PATH=/Users/username/license.hclic` to your valid local vault license filepath, or use OSS Vault'
);
process.exit(1);
}
});
try {
if (process.argv[2] === '--browserstack') {
await run('ember', ['browserstack:connect']);
try {
await run('ember', ['test', '-f=secrets/secret/create', '-c', 'testem.browserstack.js']);
console.log('success');
process.exit(0);
} finally {
if (process.env.CI === 'true') {
await run('ember', ['browserstack:results']);
}
await run('ember', ['browserstack:disconnect']);
}
} else {
await run('ember', ['test', ...process.argv.slice(2)]);
}
} catch (error) {
console.log(error);
process.exit(1);
} finally {
process.exit(0);
}
} catch (error) {
console.log(error);
process.exit(1);
}
})();