testcafe
Version:
Automated browser testing for the modern web development stack.
115 lines • 15.8 kB
JavaScript
;
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
/* global Symbol */
const pinkie_1 = __importDefault(require("pinkie"));
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 name = Symbol();
class BrowserProviderPluginHost {
constructor(providerObject, providerName) {
this.JOB_RESULT = lodash_1.assignIn({}, browser_job_result_1.default);
lodash_1.assignIn(this, providerObject);
this[name] = providerName;
}
// Helpers
get providerName() {
return this[name];
}
runInitScript(browserId, code) {
const connection = connection_1.default.getById(browserId);
return connection.runInitScript(`(${code})()`);
}
waitForConnectionReady(browserId) {
const connection = connection_1.default.getById(browserId);
if (connection.ready)
return pinkie_1.default.resolve();
return promisify_event_1.default(connection, 'ready');
}
reportWarning(browserId, ...args) {
const connection = connection_1.default.getById(browserId);
connection.addWarning(...args);
}
setUserAgentMetaInfo(browserId, message) {
const connection = connection_1.default.getById(browserId);
connection.setProviderMetaInfo(message);
}
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;
}
isHeadlessBrowser( /* browserId */) {
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 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;
}
}
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":["/* global Symbol */\nimport Promise from 'pinkie';\nimport { 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';\n\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    runInitScript (browserId, code) {\n        const connection = BrowserConnection.getById(browserId);\n\n        return connection.runInitScript(`(${code})()`);\n    }\n\n    waitForConnectionReady (browserId) {\n        const connection = BrowserConnection.getById(browserId);\n\n        if (connection.ready)\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) {\n        const connection = BrowserConnection.getById(browserId);\n\n        connection.setProviderMetaInfo(message);\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: The browserName argument is optional, and must be supplied if the browserId argument is not valid (browser is not opened)\n    async isLocalBrowser (/* browserId[, browserName] */) {\n        return false;\n    }\n\n    isHeadlessBrowser (/* browserId */) {\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 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"]}