152 lines
20 KiB
JavaScript
152 lines
20 KiB
JavaScript
"use strict";
|
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
};
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
const chalk_1 = __importDefault(require("chalk"));
|
|
const runtime_1 = require("../errors/runtime");
|
|
const types_1 = require("../errors/types");
|
|
const argument_parser_1 = __importDefault(require("./argument-parser"));
|
|
const termination_handler_1 = __importDefault(require("./termination-handler"));
|
|
const log_1 = __importDefault(require("./log"));
|
|
const remotes_wizard_1 = __importDefault(require("./remotes-wizard"));
|
|
const correct_browsers_and_sources_1 = __importDefault(require("./correct-browsers-and-sources"));
|
|
const __1 = __importDefault(require("../"));
|
|
const debug_1 = __importDefault(require("debug"));
|
|
const log_entry_1 = __importDefault(require("../utils/log-entry"));
|
|
const dashboard_1 = __importDefault(require("../dashboard"));
|
|
const LOGGER = (0, debug_1.default)('testcafe:cli');
|
|
// NOTE: Load the provider pool lazily to reduce startup time
|
|
const lazyRequire = require('import-lazy')(require);
|
|
const browserProviderPool = lazyRequire('../browser/provider/pool');
|
|
let showMessageOnExit = true;
|
|
let exitMessageShown = false;
|
|
let exiting = false;
|
|
function exitHandler(terminationLevel) {
|
|
if (showMessageOnExit && !exitMessageShown) {
|
|
exitMessageShown = true;
|
|
log_1.default.write('Stopping TestCafe...');
|
|
process.on('exit', () => log_1.default.hideSpinner(true));
|
|
}
|
|
if (exiting || terminationLevel < 2)
|
|
return;
|
|
exiting = true;
|
|
exit(0);
|
|
}
|
|
function exit(code) {
|
|
log_1.default.hideSpinner(true);
|
|
// NOTE: give a process time to flush the output.
|
|
// It's necessary in some environments.
|
|
setTimeout(() => process.exit(code), 0);
|
|
}
|
|
function error(err) {
|
|
log_1.default.hideSpinner();
|
|
let message = null;
|
|
if (err instanceof runtime_1.GeneralError)
|
|
message = err.message;
|
|
else if (err instanceof runtime_1.APIError)
|
|
message = err.coloredStack;
|
|
else
|
|
message = err.stack;
|
|
log_1.default.write(chalk_1.default.red('ERROR ') + message + '\n');
|
|
log_1.default.write(chalk_1.default.gray('Type "testcafe -h" for help.'));
|
|
exit(1);
|
|
}
|
|
async function runTests(argParser) {
|
|
const opts = argParser.opts;
|
|
const port1 = opts.ports && opts.ports[0];
|
|
const port2 = opts.ports && opts.ports[1];
|
|
const proxy = opts.proxy;
|
|
const proxyBypass = opts.proxyBypass;
|
|
const configFile = opts.configFile;
|
|
log_1.default.showSpinner();
|
|
const { hostname, ssl, dev, experimentalDebug, retryTestPages, cache, disableHttp2, v8Flags, experimentalProxyless, disableCrossDomain, experimentalEsm, } = opts;
|
|
const testCafe = await (0, __1.default)({
|
|
developmentMode: dev,
|
|
isCli: true,
|
|
hostname,
|
|
port1,
|
|
port2,
|
|
ssl,
|
|
experimentalDebug,
|
|
retryTestPages,
|
|
cache,
|
|
configFile,
|
|
disableHttp2,
|
|
v8Flags,
|
|
experimentalProxyless,
|
|
disableCrossDomain,
|
|
experimentalEsm,
|
|
});
|
|
const correctedBrowsersAndSources = await (0, correct_browsers_and_sources_1.default)(argParser, testCafe.configuration);
|
|
const automatedBrowsers = correctedBrowsersAndSources.browsers;
|
|
const remoteBrowsers = await (0, remotes_wizard_1.default)(testCafe, argParser.remoteCount, opts.qrCode);
|
|
const browsers = automatedBrowsers.concat(remoteBrowsers);
|
|
const sources = correctedBrowsersAndSources.sources;
|
|
const runner = opts.live ? testCafe.createLiveModeRunner() : testCafe.createRunner();
|
|
let failed = 0;
|
|
runner
|
|
.useProxy(proxy, proxyBypass)
|
|
.src(sources)
|
|
.tsConfigPath(argParser.opts.tsConfigPath)
|
|
.browsers(browsers)
|
|
.reporter(argParser.opts.reporter)
|
|
.concurrency(argParser.opts.concurrency)
|
|
.filter(argParser.opts.filter)
|
|
.video(opts.video, opts.videoOptions, opts.videoEncodingOptions)
|
|
.screenshots(opts.screenshots)
|
|
.startApp(opts.app, opts.appInitDelay)
|
|
.clientScripts(argParser.opts.clientScripts)
|
|
.compilerOptions(argParser.opts.compilerOptions);
|
|
runner.once('done-bootstrapping', () => log_1.default.hideSpinner());
|
|
try {
|
|
const runOpts = argParser.getRunOptions();
|
|
failed = await runner.run(runOpts);
|
|
}
|
|
finally {
|
|
showMessageOnExit = false;
|
|
await testCafe.close();
|
|
}
|
|
exit(failed);
|
|
}
|
|
async function runDashboardIntegration(state) {
|
|
await (0, dashboard_1.default)(state);
|
|
exit(0);
|
|
}
|
|
async function listBrowsers(providerName) {
|
|
const provider = await browserProviderPool.getProvider(providerName);
|
|
if (!provider)
|
|
throw new runtime_1.GeneralError(types_1.RUNTIME_ERRORS.browserProviderNotFound, providerName);
|
|
if (provider.isMultiBrowser) {
|
|
const browserNames = await provider.getBrowserList();
|
|
await browserProviderPool.dispose();
|
|
if (providerName === 'locally-installed')
|
|
console.log(browserNames.join('\n'));
|
|
else
|
|
console.log(browserNames.map(browserName => `"${providerName}:${browserName}"`).join('\n'));
|
|
}
|
|
else
|
|
console.log(`"${providerName}"`);
|
|
exit(0);
|
|
}
|
|
(async function cli() {
|
|
const terminationHandler = new termination_handler_1.default();
|
|
terminationHandler.on(termination_handler_1.default.TERMINATION_LEVEL_INCREASED_EVENT, exitHandler);
|
|
try {
|
|
const argParser = new argument_parser_1.default();
|
|
(0, log_entry_1.default)(LOGGER, process.argv);
|
|
await argParser.parse(process.argv);
|
|
(0, log_entry_1.default)(LOGGER, argParser.opts);
|
|
if (argParser.isDashboardCommand)
|
|
await runDashboardIntegration(argParser.sendReportState);
|
|
else if (argParser.opts.listBrowsers)
|
|
await listBrowsers(argParser.opts.providerName);
|
|
else
|
|
await runTests(argParser);
|
|
}
|
|
catch (err) {
|
|
showMessageOnExit = false;
|
|
error(err);
|
|
}
|
|
})();
|
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cli.js","sourceRoot":"","sources":["../../src/cli/cli.js"],"names":[],"mappings":"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","sourcesContent":["import chalk from 'chalk';\nimport { GeneralError, APIError } from '../errors/runtime';\nimport { RUNTIME_ERRORS } from '../errors/types';\nimport CliArgumentParser from './argument-parser';\nimport TerminationHandler from './termination-handler';\nimport log from './log';\nimport remotesWizard from './remotes-wizard';\nimport correctBrowsersAndSources from './correct-browsers-and-sources';\nimport createTestCafe from '../';\nimport debug from 'debug';\nimport logEntry from '../utils/log-entry';\nimport dashboardIntegration from '../dashboard';\n\nconst LOGGER = debug('testcafe:cli');\n\n// NOTE: Load the provider pool lazily to reduce startup time\nconst lazyRequire         = require('import-lazy')(require);\nconst browserProviderPool = lazyRequire('../browser/provider/pool');\n\nlet showMessageOnExit = true;\nlet exitMessageShown  = false;\nlet exiting           = false;\n\nfunction exitHandler (terminationLevel) {\n    if (showMessageOnExit && !exitMessageShown) {\n        exitMessageShown = true;\n\n        log.write('Stopping TestCafe...');\n\n        process.on('exit', () => log.hideSpinner(true));\n    }\n\n    if (exiting || terminationLevel < 2)\n        return;\n\n    exiting = true;\n\n    exit(0);\n}\n\nfunction exit (code) {\n    log.hideSpinner(true);\n\n    // NOTE: give a process time to flush the output.\n    // It's necessary in some environments.\n    setTimeout(() => process.exit(code), 0);\n}\n\nfunction error (err) {\n    log.hideSpinner();\n\n    let message = null;\n\n    if (err instanceof GeneralError)\n        message = err.message;\n\n    else if (err instanceof APIError)\n        message = err.coloredStack;\n\n    else\n        message = err.stack;\n\n    log.write(chalk.red('ERROR ') + message + '\\n');\n    log.write(chalk.gray('Type \"testcafe -h\" for help.'));\n\n    exit(1);\n}\n\nasync function runTests (argParser) {\n    const opts        = argParser.opts;\n    const port1       = opts.ports && opts.ports[0];\n    const port2       = opts.ports && opts.ports[1];\n    const proxy       = opts.proxy;\n    const proxyBypass = opts.proxyBypass;\n    const configFile  = opts.configFile;\n\n    log.showSpinner();\n\n    const {\n        hostname,\n        ssl,\n        dev,\n        experimentalDebug,\n        retryTestPages,\n        cache,\n        disableHttp2,\n        v8Flags,\n        experimentalProxyless,\n        disableCrossDomain,\n        experimentalEsm,\n    } = opts;\n\n    const testCafe = await createTestCafe({\n        developmentMode: dev,\n        isCli:           true,\n\n        hostname,\n        port1,\n        port2,\n        ssl,\n        experimentalDebug,\n        retryTestPages,\n        cache,\n        configFile,\n        disableHttp2,\n        v8Flags,\n        experimentalProxyless,\n        disableCrossDomain,\n        experimentalEsm,\n    });\n\n    const correctedBrowsersAndSources = await correctBrowsersAndSources(argParser, testCafe.configuration);\n    const automatedBrowsers           = correctedBrowsersAndSources.browsers;\n    const remoteBrowsers              = await remotesWizard(testCafe, argParser.remoteCount, opts.qrCode);\n    const browsers                    = automatedBrowsers.concat(remoteBrowsers);\n    const sources                     = correctedBrowsersAndSources.sources;\n\n    const runner = opts.live ? testCafe.createLiveModeRunner() : testCafe.createRunner();\n\n    let failed = 0;\n\n    runner\n        .useProxy(proxy, proxyBypass)\n        .src(sources)\n        .tsConfigPath(argParser.opts.tsConfigPath)\n        .browsers(browsers)\n        .reporter(argParser.opts.reporter)\n        .concurrency(argParser.opts.concurrency)\n        .filter(argParser.opts.filter)\n        .video(opts.video, opts.videoOptions, opts.videoEncodingOptions)\n        .screenshots(opts.screenshots)\n        .startApp(opts.app, opts.appInitDelay)\n        .clientScripts(argParser.opts.clientScripts)\n        .compilerOptions(argParser.opts.compilerOptions);\n\n    runner.once('done-bootstrapping', () => log.hideSpinner());\n\n    try {\n        const runOpts = argParser.getRunOptions();\n\n        failed = await runner.run(runOpts);\n    }\n    finally {\n        showMessageOnExit = false;\n        await testCafe.close();\n    }\n\n    exit(failed);\n}\n\nasync function runDashboardIntegration (state) {\n    await dashboardIntegration(state);\n\n    exit(0);\n}\n\nasync function listBrowsers (providerName) {\n    const provider = await browserProviderPool.getProvider(providerName);\n\n    if (!provider)\n        throw new GeneralError(RUNTIME_ERRORS.browserProviderNotFound, providerName);\n\n    if (provider.isMultiBrowser) {\n        const browserNames = await provider.getBrowserList();\n\n        await browserProviderPool.dispose();\n\n        if (providerName === 'locally-installed')\n            console.log(browserNames.join('\\n'));\n        else\n            console.log(browserNames.map(browserName => `\"${ providerName }:${ browserName }\"`).join('\\n'));\n    }\n    else\n        console.log(`\"${ providerName }\"`);\n\n    exit(0);\n}\n\n(async function cli () {\n    const terminationHandler = new TerminationHandler();\n\n    terminationHandler.on(TerminationHandler.TERMINATION_LEVEL_INCREASED_EVENT, exitHandler);\n\n    try {\n        const argParser = new CliArgumentParser();\n\n        logEntry(LOGGER, process.argv);\n\n        await argParser.parse(process.argv);\n\n        logEntry(LOGGER, argParser.opts);\n\n        if (argParser.isDashboardCommand)\n            await runDashboardIntegration(argParser.sendReportState);\n        else if (argParser.opts.listBrowsers)\n            await listBrowsers(argParser.opts.providerName);\n        else\n            await runTests(argParser);\n    }\n    catch (err) {\n        showMessageOnExit = false;\n        error(err);\n    }\n})();\n\n"]}
|