UNPKG

testcafe

Version:

Automated browser testing for the modern web development stack.

124 lines 19 kB
"use strict"; var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { if (k2 === undefined) k2 = k; var desc = Object.getOwnPropertyDescriptor(m, k); if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { desc = { enumerable: true, get: function() { return m[k]; } }; } Object.defineProperty(o, k2, desc); }) : (function(o, m, k, k2) { if (k2 === undefined) k2 = k; o[k2] = m[k]; })); var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { Object.defineProperty(o, "default", { enumerable: true, value: v }); }) : function(o, v) { o["default"] = v; }); var __importStar = (this && this.__importStar) || function (mod) { if (mod && mod.__esModule) return mod; var result = {}; if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); __setModuleDefault(result, mod); return result; }; 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 content_types_1 = __importDefault(require("./assets/content-types")); const option_names_1 = __importDefault(require("./configuration/option-names")); const INJECTABLES = __importStar(require("./assets/injectables")); const setup_sourcemap_support_1 = require("./utils/setup-sourcemap-support"); const status_1 = __importDefault(require("./browser/connection/gateway/status")); const lazyRequire = require('import-lazy')(require); const hammerhead = lazyRequire('testcafe-hammerhead'); const loadAssets = lazyRequire('./load-assets'); const errorHandlers = lazyRequire('./utils/handle-errors'); const BrowserConnectionGateway = lazyRequire('./browser/connection/gateway'); const BrowserConnection = lazyRequire('./browser/connection'); const browserProviderPool = lazyRequire('./browser/provider/pool'); const Runner = lazyRequire('./runner'); const LiveModeRunner = lazyRequire('./live/test-runner'); // NOTE: CoffeeScript can't be loaded lazily, because it will break stack traces require('coffeescript'); class TestCafe { constructor(configuration) { (0, setup_sourcemap_support_1.setupSourceMapSupport)(); errorHandlers.registerErrorHandlers(); this.closed = false; this.proxy = new hammerhead.Proxy(); this.runners = []; this.configuration = configuration; this.browserConnectionGateway = new BrowserConnectionGateway(this.proxy, this.configuration.browserConnectionGatewayOptions); const developmentMode = configuration.getOption(option_names_1.default.developmentMode); this.browserConnectionGateway.on('initialized', () => { this._registerAssets(developmentMode); }); } _registerAssets(developmentMode) { const { favIcon, coreScript, driverScript, uiScript, uiStyle, uiSprite, uiSpriteSvg, automationScript, legacyRunnerScript } = loadAssets(developmentMode); this.proxy.GET(INJECTABLES.TESTCAFE_CORE, { content: coreScript, contentType: content_types_1.default.javascript }); this.proxy.GET(INJECTABLES.TESTCAFE_DRIVER, { content: driverScript, contentType: content_types_1.default.javascript }); this.proxy.GET(INJECTABLES.TESTCAFE_LEGACY_RUNNER, { content: legacyRunnerScript, contentType: content_types_1.default.javascript, }); this.proxy.GET(INJECTABLES.TESTCAFE_AUTOMATION, { content: automationScript, contentType: content_types_1.default.javascript }); this.proxy.GET(INJECTABLES.TESTCAFE_UI, { content: uiScript, contentType: content_types_1.default.javascript }); this.proxy.GET(INJECTABLES.TESTCAFE_UI_SPRITE, { content: uiSprite, contentType: content_types_1.default.png }); this.proxy.GET(INJECTABLES.TESTCAFE_UI_SPRITE_SVG, { content: uiSpriteSvg, contentType: content_types_1.default.svg }); this.proxy.GET(INJECTABLES.DEFAULT_FAVICON_PATH, { content: favIcon, contentType: content_types_1.default.icon }); this.proxy.GET(INJECTABLES.TESTCAFE_UI_STYLES, { content: uiStyle, contentType: content_types_1.default.css, isShadowUIStylesheet: true, }); } _createRunner(isLiveMode) { const Ctor = isLiveMode ? LiveModeRunner : Runner; const newRunner = new Ctor({ proxy: this.proxy, browserConnectionGateway: this.browserConnectionGateway, configuration: this.configuration.clone(option_names_1.default.hooks), }); this.runners.push(newRunner); return newRunner; } async initializeBrowserConnectionGateway() { await this.configuration.ensureHostname(); if (this.browserConnectionGateway.status === status_1.default.uninitialized) this.browserConnectionGateway.initialize(this.configuration.startOptions); } // API async createBrowserConnection() { const browserInfo = await browserProviderPool.getBrowserInfo('remote'); // NOTE: 'remote' browser connection cannot be in the 'native automation' mode. this.configuration.mergeOptions({ disableNativeAutomation: true }); await this.initializeBrowserConnectionGateway(); const connection = new BrowserConnection(this.browserConnectionGateway, browserInfo, true, this.configuration.remoteBrowserConnectionOptions); connection.initialize(); return connection; } createRunner() { return this._createRunner(false); } createLiveModeRunner() { if (this.runners.some(runner => runner instanceof LiveModeRunner)) throw new runtime_1.GeneralError(types_1.RUNTIME_ERRORS.cannotCreateMultipleLiveModeRunners); return this._createRunner(true); } async close() { if (this.closed) return; this.closed = true; await Promise.all(this.runners.map(runner => runner.stop())); await browserProviderPool.dispose(); await this.browserConnectionGateway.close(); } } exports.default = TestCafe; module.exports = exports.default; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"testcafe.js","sourceRoot":"","sources":["../src/testcafe.js"],"names":[],"mappings":"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","sourcesContent":["import { GeneralError } from './errors/runtime';\nimport { RUNTIME_ERRORS } from './errors/types';\nimport CONTENT_TYPES from './assets/content-types';\nimport OPTION_NAMES from './configuration/option-names';\nimport * as INJECTABLES from './assets/injectables';\nimport { setupSourceMapSupport } from './utils/setup-sourcemap-support';\nimport BrowserConnectionGatewayStatus from './browser/connection/gateway/status';\n\nconst lazyRequire              = require('import-lazy')(require);\nconst hammerhead               = lazyRequire('testcafe-hammerhead');\nconst loadAssets               = lazyRequire('./load-assets');\nconst errorHandlers            = lazyRequire('./utils/handle-errors');\nconst BrowserConnectionGateway = lazyRequire('./browser/connection/gateway');\nconst BrowserConnection        = lazyRequire('./browser/connection');\nconst browserProviderPool      = lazyRequire('./browser/provider/pool');\nconst Runner                   = lazyRequire('./runner');\nconst LiveModeRunner           = lazyRequire('./live/test-runner');\n\n// NOTE: CoffeeScript can't be loaded lazily, because it will break stack traces\nrequire('coffeescript');\n\nexport default class TestCafe {\n    constructor (configuration) {\n        setupSourceMapSupport();\n        errorHandlers.registerErrorHandlers();\n\n        this.closed        = false;\n        this.proxy         = new hammerhead.Proxy();\n        this.runners       = [];\n        this.configuration = configuration;\n\n        this.browserConnectionGateway = new BrowserConnectionGateway(this.proxy, this.configuration.browserConnectionGatewayOptions);\n\n        const developmentMode = configuration.getOption(OPTION_NAMES.developmentMode);\n\n        this.browserConnectionGateway.on('initialized', () => {\n            this._registerAssets(developmentMode);\n        });\n    }\n\n    _registerAssets (developmentMode) {\n        const { favIcon, coreScript, driverScript, uiScript,\n            uiStyle, uiSprite, uiSpriteSvg, automationScript, legacyRunnerScript } = loadAssets(developmentMode);\n\n        this.proxy.GET(INJECTABLES.TESTCAFE_CORE, { content: coreScript, contentType: CONTENT_TYPES.javascript });\n        this.proxy.GET(INJECTABLES.TESTCAFE_DRIVER, { content: driverScript, contentType: CONTENT_TYPES.javascript });\n\n        this.proxy.GET(INJECTABLES.TESTCAFE_LEGACY_RUNNER, {\n            content:     legacyRunnerScript,\n            contentType: CONTENT_TYPES.javascript,\n        });\n\n        this.proxy.GET(INJECTABLES.TESTCAFE_AUTOMATION, { content: automationScript, contentType: CONTENT_TYPES.javascript });\n        this.proxy.GET(INJECTABLES.TESTCAFE_UI, { content: uiScript, contentType: CONTENT_TYPES.javascript });\n        this.proxy.GET(INJECTABLES.TESTCAFE_UI_SPRITE, { content: uiSprite, contentType: CONTENT_TYPES.png });\n        this.proxy.GET(INJECTABLES.TESTCAFE_UI_SPRITE_SVG, { content: uiSpriteSvg, contentType: CONTENT_TYPES.svg });\n        this.proxy.GET(INJECTABLES.DEFAULT_FAVICON_PATH, { content: favIcon, contentType: CONTENT_TYPES.icon });\n\n        this.proxy.GET(INJECTABLES.TESTCAFE_UI_STYLES, {\n            content:              uiStyle,\n            contentType:          CONTENT_TYPES.css,\n            isShadowUIStylesheet: true,\n        });\n    }\n\n    _createRunner (isLiveMode) {\n        const Ctor      = isLiveMode ? LiveModeRunner : Runner;\n        const newRunner = new Ctor({\n            proxy:                    this.proxy,\n            browserConnectionGateway: this.browserConnectionGateway,\n            configuration:            this.configuration.clone(OPTION_NAMES.hooks),\n        });\n\n        this.runners.push(newRunner);\n\n        return newRunner;\n    }\n\n    async initializeBrowserConnectionGateway () {\n        await this.configuration.ensureHostname();\n\n        if (this.browserConnectionGateway.status === BrowserConnectionGatewayStatus.uninitialized)\n            this.browserConnectionGateway.initialize(this.configuration.startOptions);\n    }\n\n    // API\n    async createBrowserConnection () {\n        const browserInfo = await browserProviderPool.getBrowserInfo('remote');\n\n        // NOTE: 'remote' browser connection cannot be in the 'native automation' mode.\n        this.configuration.mergeOptions({ disableNativeAutomation: true });\n\n        await this.initializeBrowserConnectionGateway();\n\n        const connection = new BrowserConnection(this.browserConnectionGateway, browserInfo, true, this.configuration.remoteBrowserConnectionOptions);\n\n        connection.initialize();\n\n        return connection;\n    }\n\n    createRunner () {\n        return this._createRunner(false);\n    }\n\n    createLiveModeRunner () {\n        if (this.runners.some(runner => runner instanceof LiveModeRunner))\n            throw new GeneralError(RUNTIME_ERRORS.cannotCreateMultipleLiveModeRunners);\n\n        return this._createRunner(true);\n    }\n\n    async close () {\n        if (this.closed)\n            return;\n\n        this.closed = true;\n\n        await Promise.all(this.runners.map(runner => runner.stop()));\n\n        await browserProviderPool.dispose();\n        await this.browserConnectionGateway.close();\n    }\n}\n"]}