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