91 lines
12 KiB
JavaScript
91 lines
12 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 runtime_1 = require("./errors/runtime");
|
|
const types_1 = require("./errors/types");
|
|
const embedding_utils_1 = __importDefault(require("./embedding-utils"));
|
|
const exportable_lib_1 = __importDefault(require("./api/exportable-lib"));
|
|
const testcafe_configuration_1 = __importDefault(require("./configuration/testcafe-configuration"));
|
|
const option_names_1 = __importDefault(require("./configuration/option-names"));
|
|
const process_title_1 = __importDefault(require("./services/process-title"));
|
|
const user_variables_1 = __importDefault(require("./api/user-variables"));
|
|
const lazyRequire = require('import-lazy')(require);
|
|
const TestCafe = lazyRequire('./testcafe');
|
|
const endpointUtils = lazyRequire('endpoint-utils');
|
|
const setupExitHook = lazyRequire('async-exit-hook');
|
|
// Validations
|
|
async function getValidHostname(hostname) {
|
|
if (hostname) {
|
|
const valid = await endpointUtils.isMyHostname(hostname);
|
|
if (!valid)
|
|
throw new runtime_1.GeneralError(types_1.RUNTIME_ERRORS.invalidHostname, hostname);
|
|
}
|
|
else
|
|
hostname = endpointUtils.getIPAddress();
|
|
return hostname;
|
|
}
|
|
async function getValidPort(port) {
|
|
if (port) {
|
|
const isFree = await endpointUtils.isFreePort(port);
|
|
if (!isFree)
|
|
throw new runtime_1.GeneralError(types_1.RUNTIME_ERRORS.portIsNotFree, port);
|
|
}
|
|
else
|
|
port = await endpointUtils.getFreePort();
|
|
return port;
|
|
}
|
|
// API
|
|
async function getConfiguration(args) {
|
|
var _a;
|
|
let configuration;
|
|
if (args.length === 1 && typeof args[0] === 'object') {
|
|
configuration = new testcafe_configuration_1.default((_a = args[0]) === null || _a === void 0 ? void 0 : _a.configFile);
|
|
await configuration.init(args[0]);
|
|
}
|
|
else {
|
|
// NOTE: Positional arguments support is left only for backward compatibility.
|
|
// It should be removed in future TestCafe versions.
|
|
// All new APIs should be enabled trough the configuration object in the upper clause.
|
|
// Please do not add new APIs here.
|
|
const [hostname, port1, port2, ssl, developmentMode, retryTestPages, cache, configFile] = args;
|
|
configuration = new testcafe_configuration_1.default(configFile);
|
|
await configuration.init({
|
|
hostname,
|
|
port1,
|
|
port2,
|
|
ssl,
|
|
developmentMode,
|
|
retryTestPages,
|
|
cache,
|
|
});
|
|
}
|
|
return configuration;
|
|
}
|
|
// API
|
|
async function createTestCafe(...args) {
|
|
process.title = process_title_1.default.main;
|
|
const configuration = await getConfiguration(args);
|
|
const [hostname, port1, port2] = await Promise.all([
|
|
getValidHostname(configuration.getOption(option_names_1.default.hostname)),
|
|
getValidPort(configuration.getOption(option_names_1.default.port1)),
|
|
getValidPort(configuration.getOption(option_names_1.default.port2)),
|
|
]);
|
|
const userVariablesOption = configuration.getOption(option_names_1.default.userVariables);
|
|
if (userVariablesOption)
|
|
user_variables_1.default.value = userVariablesOption;
|
|
configuration.mergeOptions({ hostname, port1, port2 });
|
|
const testcafe = new TestCafe(configuration);
|
|
setupExitHook(cb => testcafe.close().then(cb));
|
|
return testcafe;
|
|
}
|
|
// Embedding utils
|
|
createTestCafe.embeddingUtils = embedding_utils_1.default;
|
|
// Common API
|
|
Object.keys(exportable_lib_1.default).forEach(key => {
|
|
Object.defineProperty(createTestCafe, key, { get: () => exportable_lib_1.default[key] });
|
|
});
|
|
exports.default = createTestCafe;
|
|
module.exports = exports.default;
|
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.js"],"names":[],"mappings":";;;;;AAAA,8CAAgD;AAChD,0CAAgD;AAChD,wEAA+C;AAC/C,0EAAiD;AACjD,oGAA2E;AAC3E,gFAAwD;AACxD,6EAAoD;AACpD,0EAAiD;AAEjD,MAAM,WAAW,GAAK,OAAO,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,CAAC;AACtD,MAAM,QAAQ,GAAQ,WAAW,CAAC,YAAY,CAAC,CAAC;AAChD,MAAM,aAAa,GAAG,WAAW,CAAC,gBAAgB,CAAC,CAAC;AACpD,MAAM,aAAa,GAAG,WAAW,CAAC,iBAAiB,CAAC,CAAC;AAErD,cAAc;AACd,KAAK,UAAU,gBAAgB,CAAE,QAAQ;IACrC,IAAI,QAAQ,EAAE;QACV,MAAM,KAAK,GAAG,MAAM,aAAa,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;QAEzD,IAAI,CAAC,KAAK;YACN,MAAM,IAAI,sBAAY,CAAC,sBAAc,CAAC,eAAe,EAAE,QAAQ,CAAC,CAAC;KACxE;;QAEG,QAAQ,GAAG,aAAa,CAAC,YAAY,EAAE,CAAC;IAE5C,OAAO,QAAQ,CAAC;AACpB,CAAC;AAED,KAAK,UAAU,YAAY,CAAE,IAAI;IAC7B,IAAI,IAAI,EAAE;QACN,MAAM,MAAM,GAAG,MAAM,aAAa,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;QAEpD,IAAI,CAAC,MAAM;YACP,MAAM,IAAI,sBAAY,CAAC,sBAAc,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC;KAClE;;QAEG,IAAI,GAAG,MAAM,aAAa,CAAC,WAAW,EAAE,CAAC;IAE7C,OAAO,IAAI,CAAC;AAChB,CAAC;AAED,MAAM;AACN,KAAK,UAAU,gBAAgB,CAAE,IAAI;;IACjC,IAAI,aAAa,CAAC;IAElB,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,IAAI,OAAO,IAAI,CAAC,CAAC,CAAC,KAAK,QAAQ,EAAE;QAClD,aAAa,GAAG,IAAI,gCAAqB,CAAC,MAAA,IAAI,CAAC,CAAC,CAAC,0CAAE,UAAU,CAAC,CAAC;QAE/D,MAAM,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;KACrC;SACI;QACD,8EAA8E;QAC9E,oDAAoD;QACpD,sFAAsF;QACtF,mCAAmC;QACnC,MAAM,CAAC,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,EAAE,eAAe,EAAE,cAAc,EAAE,KAAK,EAAE,UAAU,CAAC,GAAG,IAAI,CAAC;QAE/F,aAAa,GAAG,IAAI,gCAAqB,CAAC,UAAU,CAAC,CAAC;QAEtD,MAAM,aAAa,CAAC,IAAI,CAAC;YACrB,QAAQ;YACR,KAAK;YACL,KAAK;YACL,GAAG;YACH,eAAe;YACf,cAAc;YACd,KAAK;SACR,CAAC,CAAC;KACN;IAED,OAAO,aAAa,CAAC;AACzB,CAAC;AAED,MAAM;AACN,KAAK,UAAU,cAAc,CAAE,GAAG,IAAI;IAClC,OAAO,CAAC,KAAK,GAAG,uBAAY,CAAC,IAAI,CAAC;IAElC,MAAM,aAAa,GAAG,MAAM,gBAAgB,CAAC,IAAI,CAAC,CAAC;IAEnD,MAAM,CAAC,QAAQ,EAAE,KAAK,EAAE,KAAK,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;QAC/C,gBAAgB,CAAC,aAAa,CAAC,SAAS,CAAC,sBAAY,CAAC,QAAQ,CAAC,CAAC;QAChE,YAAY,CAAC,aAAa,CAAC,SAAS,CAAC,sBAAY,CAAC,KAAK,CAAC,CAAC;QACzD,YAAY,CAAC,aAAa,CAAC,SAAS,CAAC,sBAAY,CAAC,KAAK,CAAC,CAAC;KAC5D,CAAC,CAAC;IAEH,MAAM,mBAAmB,GAAG,aAAa,CAAC,SAAS,CAAC,sBAAY,CAAC,aAAa,CAAC,CAAC;IAEhF,IAAI,mBAAmB;QACnB,wBAAa,CAAC,KAAK,GAAG,mBAAmB,CAAC;IAE9C,aAAa,CAAC,YAAY,CAAC,EAAE,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC;IAEvD,MAAM,QAAQ,GAAG,IAAI,QAAQ,CAAC,aAAa,CAAC,CAAC;IAE7C,aAAa,CAAC,EAAE,CAAC,EAAE,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;IAE/C,OAAO,QAAQ,CAAC;AACpB,CAAC;AAED,kBAAkB;AAClB,cAAc,CAAC,cAAc,GAAG,yBAAc,CAAC;AAE/C,aAAa;AACb,MAAM,CAAC,IAAI,CAAC,wBAAa,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;IACrC,MAAM,CAAC,cAAc,CAAC,cAAc,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,wBAAa,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;AAClF,CAAC,CAAC,CAAC;AAEH,kBAAe,cAAc,CAAC","sourcesContent":["import { GeneralError } from './errors/runtime';\nimport { RUNTIME_ERRORS } from './errors/types';\nimport embeddingUtils from './embedding-utils';\nimport exportableLib from './api/exportable-lib';\nimport TestCafeConfiguration from './configuration/testcafe-configuration';\nimport OPTION_NAMES from './configuration/option-names';\nimport ProcessTitle from './services/process-title';\nimport userVariables from './api/user-variables';\n\nconst lazyRequire   = require('import-lazy')(require);\nconst TestCafe      = lazyRequire('./testcafe');\nconst endpointUtils = lazyRequire('endpoint-utils');\nconst setupExitHook = lazyRequire('async-exit-hook');\n\n// Validations\nasync function getValidHostname (hostname) {\n    if (hostname) {\n        const valid = await endpointUtils.isMyHostname(hostname);\n\n        if (!valid)\n            throw new GeneralError(RUNTIME_ERRORS.invalidHostname, hostname);\n    }\n    else\n        hostname = endpointUtils.getIPAddress();\n\n    return hostname;\n}\n\nasync function getValidPort (port) {\n    if (port) {\n        const isFree = await endpointUtils.isFreePort(port);\n\n        if (!isFree)\n            throw new GeneralError(RUNTIME_ERRORS.portIsNotFree, port);\n    }\n    else\n        port = await endpointUtils.getFreePort();\n\n    return port;\n}\n\n// API\nasync function getConfiguration (args) {\n    let configuration;\n\n    if (args.length === 1 && typeof args[0] === 'object') {\n        configuration = new TestCafeConfiguration(args[0]?.configFile);\n\n        await configuration.init(args[0]);\n    }\n    else {\n        // NOTE: Positional arguments support is left only for backward compatibility.\n        // It should be removed in future TestCafe versions.\n        // All new APIs should be enabled trough the configuration object in the upper clause.\n        // Please do not add new APIs here.\n        const [hostname, port1, port2, ssl, developmentMode, retryTestPages, cache, configFile] = args;\n\n        configuration = new TestCafeConfiguration(configFile);\n\n        await configuration.init({\n            hostname,\n            port1,\n            port2,\n            ssl,\n            developmentMode,\n            retryTestPages,\n            cache,\n        });\n    }\n\n    return configuration;\n}\n\n// API\nasync function createTestCafe (...args) {\n    process.title = ProcessTitle.main;\n\n    const configuration = await getConfiguration(args);\n\n    const [hostname, port1, port2] = await Promise.all([\n        getValidHostname(configuration.getOption(OPTION_NAMES.hostname)),\n        getValidPort(configuration.getOption(OPTION_NAMES.port1)),\n        getValidPort(configuration.getOption(OPTION_NAMES.port2)),\n    ]);\n\n    const userVariablesOption = configuration.getOption(OPTION_NAMES.userVariables);\n\n    if (userVariablesOption)\n        userVariables.value = userVariablesOption;\n\n    configuration.mergeOptions({ hostname, port1, port2 });\n\n    const testcafe = new TestCafe(configuration);\n\n    setupExitHook(cb => testcafe.close().then(cb));\n\n    return testcafe;\n}\n\n// Embedding utils\ncreateTestCafe.embeddingUtils = embeddingUtils;\n\n// Common API\nObject.keys(exportableLib).forEach(key => {\n    Object.defineProperty(createTestCafe, key, { get: () => exportableLib[key] });\n});\n\nexport default createTestCafe;\n"]}
|