135 lines
17 KiB
JavaScript
135 lines
17 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 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*/) {
|
|
return Promise.resolve();
|
|
}
|
|
async getOSInfo( /*browserId*/) {
|
|
return null;
|
|
}
|
|
}
|
|
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*/) {\n        return Promise.resolve();\n    }\n\n    async getOSInfo (/*browserId*/) {\n        return null;\n    }\n}\n"]}
|