Innovenergy_trunk/frontend/node_modules/testcafe/lib/index.js

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"]}