UNPKG

testcafe

Version:

Automated browser testing for the modern web development stack.

147 lines 18.8 kB
"use strict"; var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); const lodash_1 = require("lodash"); const promisify_event_1 = __importDefault(require("promisify-event")); const browser_job_result_1 = __importDefault(require("../../runner/browser-job-result")); const connection_1 = __importDefault(require("../connection")); const warning_message_1 = __importDefault(require("../../notifications/warning-message")); const testcafe_hammerhead_1 = require("testcafe-hammerhead"); const name = Symbol(); class BrowserProviderPluginHost { constructor(providerObject, providerName) { this.JOB_RESULT = (0, lodash_1.assignIn)({}, browser_job_result_1.default); (0, lodash_1.assignIn)(this, providerObject); this[name] = providerName; } // Helpers get providerName() { return this[name]; } async runInitScript(browserId, code) { const connection = connection_1.default.getById(browserId); return connection.runInitScript(`(${code})()`); } calculateWindowId() { return (0, testcafe_hammerhead_1.generateUniqueId)(); } waitForConnectionReady(browserId) { const connection = connection_1.default.getById(browserId); if (connection.isReady()) return Promise.resolve(); return (0, promisify_event_1.default)(connection, 'ready'); } reportWarning(browserId, ...args) { const connection = connection_1.default.getById(browserId); connection.addWarning(...args); } setUserAgentMetaInfo(browserId, message, ...args) { const connection = connection_1.default.getById(browserId); connection.setProviderMetaInfo(message, ...args); } async closeLocalBrowser(browserId) { const connection = connection_1.default.getById(browserId); await connection.provider._ensureBrowserWindowDescriptor(browserId); await connection.provider._closeLocalBrowser(browserId); } async resizeLocalBrowserWindow(browserId, width, height, currentWidth, currentHeight) { const connection = connection_1.default.getById(browserId); await connection.provider._ensureBrowserWindowParameters(browserId); await connection.provider._resizeLocalBrowserWindow(browserId, width, height, currentWidth, currentHeight); } // API // Browser control async openBrowser( /* browserId, pageUrl, browserName */) { throw new Error('Not implemented!'); } async closeBrowser( /* browserId */) { throw new Error('Not implemented!'); } // Initialization async init() { return; } async dispose() { return; } // Browser names handling async getBrowserList() { throw new Error('Not implemented!'); } async isValidBrowserName( /* browserName */) { return true; } // Extra functions // NOTE: // The browserName argument is optional, and must be supplied if the browserId argument is not valid // (browser is not opened) async isLocalBrowser( /* browserId[, browserName] */) { return false; } // NOTE: // The browserName argument is optional, and must be supplied if the browserId argument is not valid // (browser is not opened) isHeadlessBrowser( /* browserId[, browserName] */) { return false; } async hasCustomActionForBrowser( /* browserId */) { return { hasCloseBrowser: this.hasOwnProperty('closeBrowser'), hasResizeWindow: this.hasOwnProperty('resizeWindow'), hasTakeScreenshot: this.hasOwnProperty('takeScreenshot'), hasGetVideoFrameData: this.hasOwnProperty('getVideoFrameData'), hasCanResizeWindowToDimensions: this.hasOwnProperty('canResizeWindowToDimensions'), hasMaximizeWindow: this.hasOwnProperty('maximizeWindow'), hasChromelessScreenshots: false, }; } async resizeWindow(browserId /*, width, height, currentWidth, currentHeight */) { this.reportWarning(browserId, warning_message_1.default.resizeNotSupportedByBrowserProvider, this[name]); } async canResizeWindowToDimensions( /* browserId, width, height */) { return true; } async takeScreenshot(browserId /*, screenshotPath, pageWidth, pageHeight */) { this.reportWarning(browserId, warning_message_1.default.screenshotNotSupportedByBrowserProvider, this[name]); } async maximizeWindow(browserId) { this.reportWarning(browserId, warning_message_1.default.maximizeNotSupportedByBrowserProvider, this[name]); } async startCapturingVideo( /*browserId*/) { } async stopCapturingVideo( /*browserId*/) { } async getVideoFrameData(browserId) { const browserAlias = connection_1.default.getById(browserId).browserInfo.alias; this.reportWarning(browserId, warning_message_1.default.videoNotSupportedByBrowser, browserAlias); } async reportJobResult( /*browserId, status, data*/) { return; } getConfig(value) { return value; } async closeBrowserChildWindow( /*browserId, windowId*/) { return Promise.resolve(); } async getOSInfo( /*browserId*/) { return null; } supportNativeAutomation() { return false; } getNativeAutomation( /*browserId*/) { return null; } getNewWindowIdInNativeAutomation( /*browserId, windowId*/) { return Promise.resolve(); } async getCurrentCDPSession( /*browserId*/) { return Promise.resolve(); } } exports.default = BrowserProviderPluginHost; module.exports = exports.default; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"plugin-host.js","sourceRoot":"","sources":["../../../src/browser/provider/plugin-host.js"],"names":[],"mappings":"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","sourcesContent":["import { assignIn } from 'lodash';\nimport promisifyEvent from 'promisify-event';\nimport BROWSER_JOB_RESULT from '../../runner/browser-job-result';\nimport BrowserConnection from '../connection';\nimport WARNING_MESSAGE from '../../notifications/warning-message';\nimport { generateUniqueId } from 'testcafe-hammerhead';\n\nconst name = Symbol();\n\nexport default class BrowserProviderPluginHost {\n    constructor (providerObject, providerName) {\n        this.JOB_RESULT = assignIn({}, BROWSER_JOB_RESULT);\n\n        assignIn(this, providerObject);\n\n        this[name] = providerName;\n    }\n\n\n    // Helpers\n    get providerName () {\n        return this[name];\n    }\n\n    async runInitScript (browserId, code) {\n        const connection = BrowserConnection.getById(browserId);\n\n        return connection.runInitScript(`(${code})()`);\n    }\n\n    calculateWindowId () {\n        return generateUniqueId();\n    }\n\n    waitForConnectionReady (browserId) {\n        const connection = BrowserConnection.getById(browserId);\n\n        if (connection.isReady())\n            return Promise.resolve();\n\n        return promisifyEvent(connection, 'ready');\n    }\n\n    reportWarning (browserId, ...args) {\n        const connection = BrowserConnection.getById(browserId);\n\n        connection.addWarning(...args);\n    }\n\n    setUserAgentMetaInfo (browserId, message, ...args) {\n        const connection = BrowserConnection.getById(browserId);\n\n        connection.setProviderMetaInfo(message, ...args);\n    }\n\n    async closeLocalBrowser (browserId) {\n        const connection = BrowserConnection.getById(browserId);\n\n        await connection.provider._ensureBrowserWindowDescriptor(browserId);\n        await connection.provider._closeLocalBrowser(browserId);\n    }\n\n    async resizeLocalBrowserWindow (browserId, width, height, currentWidth, currentHeight) {\n        const connection = BrowserConnection.getById(browserId);\n\n        await connection.provider._ensureBrowserWindowParameters(browserId);\n        await connection.provider._resizeLocalBrowserWindow(browserId, width, height, currentWidth, currentHeight);\n    }\n\n    // API\n    // Browser control\n    async openBrowser (/* browserId, pageUrl, browserName */) {\n        throw new Error('Not implemented!');\n    }\n\n    async closeBrowser (/* browserId */) {\n        throw new Error('Not implemented!');\n    }\n\n    // Initialization\n    async init () {\n        return;\n    }\n\n    async dispose () {\n        return;\n    }\n\n\n    // Browser names handling\n    async getBrowserList () {\n        throw new Error('Not implemented!');\n    }\n\n    async isValidBrowserName (/* browserName */) {\n        return true;\n    }\n\n    // Extra functions\n    // NOTE:\n    // The browserName argument is optional, and must be supplied if the browserId argument is not valid\n    // (browser is not opened)\n    async isLocalBrowser (/* browserId[, browserName] */) {\n        return false;\n    }\n\n    // NOTE:\n    // The browserName argument is optional, and must be supplied if the browserId argument is not valid\n    // (browser is not opened)\n    isHeadlessBrowser (/* browserId[, browserName] */) {\n        return false;\n    }\n\n    async hasCustomActionForBrowser (/* browserId */) {\n        return {\n            hasCloseBrowser:                this.hasOwnProperty('closeBrowser'),\n            hasResizeWindow:                this.hasOwnProperty('resizeWindow'),\n            hasTakeScreenshot:              this.hasOwnProperty('takeScreenshot'),\n            hasGetVideoFrameData:           this.hasOwnProperty('getVideoFrameData'),\n            hasCanResizeWindowToDimensions: this.hasOwnProperty('canResizeWindowToDimensions'),\n            hasMaximizeWindow:              this.hasOwnProperty('maximizeWindow'),\n            hasChromelessScreenshots:       false,\n        };\n    }\n\n    async resizeWindow (browserId/*, width, height, currentWidth, currentHeight */) {\n        this.reportWarning(browserId, WARNING_MESSAGE.resizeNotSupportedByBrowserProvider, this[name]);\n    }\n\n    async canResizeWindowToDimensions (/* browserId, width, height */) {\n        return true;\n    }\n\n    async takeScreenshot (browserId/*, screenshotPath, pageWidth, pageHeight */) {\n        this.reportWarning(browserId, WARNING_MESSAGE.screenshotNotSupportedByBrowserProvider, this[name]);\n    }\n\n    async maximizeWindow (browserId) {\n        this.reportWarning(browserId, WARNING_MESSAGE.maximizeNotSupportedByBrowserProvider, this[name]);\n    }\n\n    async startCapturingVideo (/*browserId*/) {\n    }\n\n    async stopCapturingVideo (/*browserId*/) {\n    }\n\n    async getVideoFrameData (browserId) {\n        const browserAlias = BrowserConnection.getById(browserId).browserInfo.alias;\n\n        this.reportWarning(browserId, WARNING_MESSAGE.videoNotSupportedByBrowser, browserAlias);\n    }\n\n    async reportJobResult (/*browserId, status, data*/) {\n        return;\n    }\n\n    getConfig (value) {\n        return value;\n    }\n\n    async closeBrowserChildWindow (/*browserId, windowId*/) {\n        return Promise.resolve();\n    }\n\n    async getOSInfo (/*browserId*/) {\n        return null;\n    }\n\n    supportNativeAutomation () {\n        return false;\n    }\n\n    getNativeAutomation (/*browserId*/) {\n        return null;\n    }\n\n    getNewWindowIdInNativeAutomation (/*browserId, windowId*/) {\n        return Promise.resolve();\n    }\n\n    async getCurrentCDPSession (/*browserId*/) {\n        return Promise.resolve();\n    }\n}\n"]}