testcafe-browser-provider-browserstack
Version:
Browserstack TestCafe browser provider plugin.
111 lines • 15.2 kB
JavaScript
;
var __rest = (this && this.__rest) || function (s, e) {
var t = {};
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
t[p] = s[p];
if (s != null && typeof Object.getOwnPropertySymbols === "function")
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
t[p[i]] = s[p[i]];
}
return t;
};
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
const base_1 = __importDefault(require("./base"));
const request_api_1 = __importDefault(require("../utils/request-api"));
const create_browserstack_status_1 = __importDefault(require("../utils/create-browserstack-status"));
const sharp_1 = __importDefault(require("sharp"));
const TESTS_TIMEOUT = process.env['BROWSERSTACK_TEST_TIMEOUT'] || 1800;
const BROWSERSTACK_API_PATHS = {
browserList: {
url: 'https://api.browserstack.com/4/browsers?flat=true',
},
newWorker: {
url: 'https://api.browserstack.com/4/worker',
method: 'POST',
},
getWorkerInfo: id => ({
url: `https://api.browserstack.com/4/worker/${id}`,
}),
deleteWorker: id => ({
url: `https://api.browserstack.com/4/worker/${id}`,
method: 'DELETE',
}),
screenshot: id => ({
url: `https://api.browserstack.com/4/worker/${id}/screenshot.png`,
encoding: null,
}),
setStatus: id => ({
url: `https://api.browserstack.com/automate/sessions/${id}.json`,
method: 'PUT',
}),
};
class JSTestingBackend extends base_1.default {
constructor(...args) {
super(...args);
this.workers = {};
}
async _requestSessionInfo(id) {
return await (0, request_api_1.default)(BROWSERSTACK_API_PATHS.getWorkerInfo(this.workers[id].id));
}
async _getSessionId(id) {
var sessionIdMatch = this.workers[id].sessionUrl.match(/[^/]*$/);
return sessionIdMatch && sessionIdMatch[0];
}
async getBrowsersList() {
var platformsInfo = await (0, request_api_1.default)(BROWSERSTACK_API_PATHS.browserList);
return platformsInfo.reverse();
}
getSessionUrl(id) {
return this.workers[id] ? this.workers[id].sessionUrl : '';
}
async getOSInfo(id) {
if (this.workers[id])
return this.workers[id].osInfo;
return null;
}
async openBrowser(id, pageUrl, capabilities) {
var { local } = capabilities, restCapabilities = __rest(capabilities, ["local"]);
capabilities = Object.assign({ 'browserstack.local': local, timeout: TESTS_TIMEOUT, url: pageUrl }, restCapabilities);
this.workers[id] = await (0, request_api_1.default)(BROWSERSTACK_API_PATHS.newWorker, {
body: Object.assign({}, capabilities)
});
const sessionInfo = await this._requestSessionInfo(id);
const osInfo = {
name: sessionInfo['os'] || '',
version: sessionInfo['os_version'] || ''
};
this.workers[id].started = Date.now();
this.workers[id].sessionUrl = sessionInfo['browser_url'];
this.workers[id].osInfo = osInfo;
this.workers[id].sessionId = await this._getSessionId(id);
}
async closeBrowser(id) {
var workerId = this.workers[id].id;
// Return incase of invalid workerId
if (!workerId || workerId === '')
return;
await (0, request_api_1.default)(BROWSERSTACK_API_PATHS.deleteWorker(workerId));
}
async takeScreenshot(id, screenshotPath) {
var buffer = await (0, request_api_1.default)(BROWSERSTACK_API_PATHS.screenshot(this.workers[id].id));
var pngBuffer = await (0, sharp_1.default)(buffer).toFormat('png').toBuffer();
await (0, sharp_1.default)(pngBuffer).toFile(screenshotPath);
}
async resizeWindow(id) {
this.reportWarning(id, 'The window resize functionality is not supported by the Browserstack JS Testing API. Use the Browserstack Automate API.');
}
async maximizeWindow(id) {
this.reportWarning(id, 'The window maximization functionality is not supported by the Browserstack JS Testing API. Use the Browserstack Automate API.');
}
async reportJobResult(id, jobResult, jobData, possibleResults) {
var sessionId = this.workers[id].sessionId;
var jobStatus = (0, create_browserstack_status_1.default)(jobResult, jobData, possibleResults);
await (0, request_api_1.default)(BROWSERSTACK_API_PATHS.setStatus(sessionId), { body: jobStatus });
}
}
exports.default = JSTestingBackend;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"js-testing.js","sourceRoot":"","sources":["../../src/backends/js-testing.js"],"names":[],"mappings":"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","sourcesContent":["import BaseBackend from './base';\nimport requestApi from '../utils/request-api';\nimport createBrowserstackStatus from '../utils/create-browserstack-status';\nimport sharp from 'sharp';\n\n\nconst TESTS_TIMEOUT = process.env['BROWSERSTACK_TEST_TIMEOUT'] || 1800;\n\nconst BROWSERSTACK_API_PATHS = {\n    browserList: {\n        url: 'https://api.browserstack.com/4/browsers?flat=true',\n    },\n\n    newWorker: {\n        url:    'https://api.browserstack.com/4/worker',\n        method: 'POST',\n    },\n\n    getWorkerInfo: id => ({\n        url: `https://api.browserstack.com/4/worker/${id}`,\n    }),\n\n    deleteWorker: id => ({\n        url:    `https://api.browserstack.com/4/worker/${id}`,\n        method: 'DELETE',\n    }),\n\n    screenshot: id => ({\n        url:      `https://api.browserstack.com/4/worker/${id}/screenshot.png`,\n        encoding: null,\n    }),\n\n    setStatus: id => ({\n        url:    `https://api.browserstack.com/automate/sessions/${id}.json`,\n        method: 'PUT',\n    }),\n};\n\nexport default class JSTestingBackend extends BaseBackend {\n    constructor (...args) {\n        super(...args);\n\n        this.workers = {};\n    }\n\n    async _requestSessionInfo (id) {\n        return await requestApi(BROWSERSTACK_API_PATHS.getWorkerInfo(this.workers[id].id));\n    }\n\n    async _getSessionId (id) {\n        var sessionIdMatch = this.workers[id].sessionUrl.match(/[^/]*$/);\n\n        return sessionIdMatch && sessionIdMatch[0];\n    }\n\n    async getBrowsersList () {\n        var platformsInfo = await requestApi(BROWSERSTACK_API_PATHS.browserList);\n\n        return platformsInfo.reverse();\n    }\n\n    getSessionUrl (id) {\n        return this.workers[id] ? this.workers[id].sessionUrl : '';\n    }\n\n    async getOSInfo (id) {\n        if (this.workers[id])\n            return this.workers[id].osInfo;\n\n        return null;\n    }\n\n    async openBrowser (id, pageUrl, capabilities) {\n        var { local, ...restCapabilities } = capabilities;\n\n        capabilities = {\n            'browserstack.local': local,\n\n            timeout: TESTS_TIMEOUT,\n            url:     pageUrl,\n\n            ...restCapabilities,\n        };\n\n        this.workers[id] = await requestApi(BROWSERSTACK_API_PATHS.newWorker, {\n            body: { ...capabilities }\n        });\n\n        const sessionInfo = await this._requestSessionInfo(id);\n        const osInfo      = {\n            name:    sessionInfo['os'] || '',\n            version: sessionInfo['os_version'] || ''\n        };\n\n        this.workers[id].started    = Date.now();\n        this.workers[id].sessionUrl = sessionInfo['browser_url'];\n        this.workers[id].osInfo     = osInfo;\n        this.workers[id].sessionId  = await this._getSessionId(id);\n    }\n\n    async closeBrowser (id) {\n        var workerId = this.workers[id].id;\n\n        // Return incase of invalid workerId\n        if (!workerId || workerId === '')\n            return;\n\n        await requestApi(BROWSERSTACK_API_PATHS.deleteWorker(workerId));\n\n    }\n\n    async takeScreenshot (id, screenshotPath) {\n        var buffer    = await requestApi(BROWSERSTACK_API_PATHS.screenshot(this.workers[id].id));\n        var pngBuffer = await sharp(buffer).toFormat('png').toBuffer();\n\n        await sharp(pngBuffer).toFile(screenshotPath);\n    }\n\n    async resizeWindow (id) {\n        this.reportWarning(id, 'The window resize functionality is not supported by the Browserstack JS Testing API. Use the Browserstack Automate API.');\n    }\n\n    async maximizeWindow (id) {\n        this.reportWarning(id, 'The window maximization functionality is not supported by the Browserstack JS Testing API. Use the Browserstack Automate API.');\n    }\n\n    async reportJobResult (id, jobResult, jobData, possibleResults) {\n        var sessionId = this.workers[id].sessionId;\n        var jobStatus = createBrowserstackStatus(jobResult, jobData, possibleResults);\n\n        await requestApi(BROWSERSTACK_API_PATHS.setStatus(sessionId), { body: jobStatus });\n    }\n}\n\n"]}