UNPKG

testcafe

Version:

Automated browser testing for the modern web development stack.

123 lines 16.4 kB
"use strict"; var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); const path_1 = __importDefault(require("path")); const testcafe_hammerhead_1 = require("testcafe-hammerhead"); const _1 = __importDefault(require("./")); const ACTIVE_SESSIONS_MAP = {}; const UPLOADS_DIR_NAME = '_uploads_'; // NOTE: Native Automation cookie implementation doesn't require client-server communication. // This stub was created to reduce conditional logic in connected classes. class NativeAutomationCookieStub { getClientString() { return ''; } takePendingSyncCookies() { return []; } } class SessionController extends testcafe_hammerhead_1.Session { constructor(uploadRoots, options) { super(uploadRoots, options); this.currentTestRun = null; } // Hammerhead payload async getPayloadScript(windowId) { return this.currentTestRun.getPayloadScript(windowId); } async getIframePayloadScript() { return this.currentTestRun.getIframePayloadScript(); } // Hammerhead handlers handleServiceMessage(msg, serverInfo) { if (this.currentTestRun[msg.cmd]) return super.handleServiceMessage.call(this.currentTestRun, msg, serverInfo); return super.handleServiceMessage(msg, serverInfo); } getAuthCredentials() { return this.currentTestRun.getAuthCredentials(); } handleFileDownload() { return this.currentTestRun.handleFileDownload(); } handleAttachment(data) { return this.currentTestRun.handleAttachment(data); } handlePageError(ctx, err) { return this.currentTestRun.handlePageError(ctx, err); } createCookies() { return this.options.nativeAutomation ? new NativeAutomationCookieStub() : super.createCookies(); } // API static getSession(testRun) { let sessionInfo = ACTIVE_SESSIONS_MAP[testRun.browserConnection.id]; if (!sessionInfo || !testRun.disablePageReloads) { if (sessionInfo && sessionInfo.url) SessionController.closeSession(testRun); let session = null; if (testRun.test.isLegacy) session = testRun; else { const fixtureDir = path_1.default.dirname(testRun.test.fixture.path); const uploadRoots = [ path_1.default.resolve(UPLOADS_DIR_NAME), path_1.default.resolve(fixtureDir, UPLOADS_DIR_NAME), fixtureDir, ]; const options = { disablePageCaching: testRun.disablePageCaching, allowMultipleWindows: _1.default.isMultipleWindowsAllowed(testRun), requestTimeout: testRun.requestTimeout, nativeAutomation: testRun.isNativeAutomation, }; if (options.allowMultipleWindows) options.windowId = testRun.browserConnection.activeWindowId; session = new SessionController(uploadRoots, options); session.currentTestRun = testRun; } sessionInfo = { session: session, proxy: null, url: null, }; ACTIVE_SESSIONS_MAP[testRun.browserConnection.id] = sessionInfo; } else if (!testRun.test.isLegacy) sessionInfo.session.currentTestRun = testRun; return sessionInfo.session; } static getSessionUrl(testRun, proxy) { let sessionInfo = ACTIVE_SESSIONS_MAP[testRun.browserConnection.id]; if (!sessionInfo || testRun.test.isLegacy) { SessionController.getSession(testRun); sessionInfo = ACTIVE_SESSIONS_MAP[testRun.browserConnection.id]; } if (!sessionInfo.url) { const pageUrl = testRun.test.pageUrl; const externalProxyHost = testRun.opts.proxy; let externalProxySettings = null; if (externalProxyHost) { externalProxySettings = { url: externalProxyHost, bypassRules: testRun.opts.proxyBypass, }; } sessionInfo.proxy = proxy; sessionInfo.url = proxy.openSession(pageUrl, sessionInfo.session, externalProxySettings); } return sessionInfo.url; } static closeSession(testRun) { const sessionInfo = ACTIVE_SESSIONS_MAP[testRun.browserConnection.id]; if (!sessionInfo || !sessionInfo.url || !sessionInfo.proxy) return; sessionInfo.proxy.closeSession(sessionInfo.session); delete ACTIVE_SESSIONS_MAP[testRun.browserConnection.id]; } } exports.default = SessionController; module.exports = exports.default; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"session-controller.js","sourceRoot":"","sources":["../../src/test-run/session-controller.js"],"names":[],"mappings":"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","sourcesContent":["import path from 'path';\nimport { Session } from 'testcafe-hammerhead';\nimport TestRun from './';\n\n\nconst ACTIVE_SESSIONS_MAP = {};\nconst UPLOADS_DIR_NAME = '_uploads_';\n\n// NOTE: Native Automation cookie implementation doesn't require client-server communication.\n// This stub was created to reduce conditional logic in connected classes.\nclass NativeAutomationCookieStub {\n    getClientString () {\n        return '';\n    }\n\n    takePendingSyncCookies () {\n        return [];\n    }\n}\n\nexport default class SessionController extends Session {\n    constructor (uploadRoots, options) {\n        super(uploadRoots, options);\n\n        this.currentTestRun = null;\n    }\n\n    // Hammerhead payload\n    async getPayloadScript (windowId) {\n        return this.currentTestRun.getPayloadScript(windowId);\n    }\n\n    async getIframePayloadScript () {\n        return this.currentTestRun.getIframePayloadScript();\n    }\n\n\n    // Hammerhead handlers\n    handleServiceMessage (msg, serverInfo) {\n        if (this.currentTestRun[msg.cmd])\n            return super.handleServiceMessage.call(this.currentTestRun, msg, serverInfo);\n\n        return super.handleServiceMessage(msg, serverInfo);\n    }\n\n    getAuthCredentials () {\n        return this.currentTestRun.getAuthCredentials();\n    }\n\n    handleFileDownload () {\n        return this.currentTestRun.handleFileDownload();\n    }\n\n    handleAttachment (data) {\n        return this.currentTestRun.handleAttachment(data);\n    }\n\n    handlePageError (ctx, err) {\n        return this.currentTestRun.handlePageError(ctx, err);\n    }\n\n    createCookies () {\n        return this.options.nativeAutomation ? new NativeAutomationCookieStub() : super.createCookies();\n    }\n\n    // API\n    static getSession (testRun) {\n        let sessionInfo = ACTIVE_SESSIONS_MAP[testRun.browserConnection.id];\n\n        if (!sessionInfo || !testRun.disablePageReloads) {\n            if (sessionInfo && sessionInfo.url)\n                SessionController.closeSession(testRun);\n\n            let session = null;\n\n            if (testRun.test.isLegacy)\n                session = testRun;\n            else {\n                const fixtureDir = path.dirname(testRun.test.fixture.path);\n\n                const uploadRoots = [\n                    path.resolve(UPLOADS_DIR_NAME),\n                    path.resolve(fixtureDir, UPLOADS_DIR_NAME),\n                    fixtureDir,\n                ];\n\n                const options = {\n                    disablePageCaching:   testRun.disablePageCaching,\n                    allowMultipleWindows: TestRun.isMultipleWindowsAllowed(testRun),\n                    requestTimeout:       testRun.requestTimeout,\n                    nativeAutomation:     testRun.isNativeAutomation,\n                };\n\n                if (options.allowMultipleWindows)\n                    options.windowId = testRun.browserConnection.activeWindowId;\n\n                session = new SessionController(uploadRoots, options);\n\n                session.currentTestRun = testRun;\n            }\n\n            sessionInfo = {\n                session: session,\n                proxy:   null,\n                url:     null,\n            };\n\n            ACTIVE_SESSIONS_MAP[testRun.browserConnection.id] = sessionInfo;\n        }\n        else if (!testRun.test.isLegacy)\n            sessionInfo.session.currentTestRun = testRun;\n\n        return sessionInfo.session;\n    }\n\n    static getSessionUrl (testRun, proxy) {\n        let sessionInfo = ACTIVE_SESSIONS_MAP[testRun.browserConnection.id];\n\n        if (!sessionInfo || testRun.test.isLegacy) {\n            SessionController.getSession(testRun);\n\n            sessionInfo = ACTIVE_SESSIONS_MAP[testRun.browserConnection.id];\n        }\n\n        if (!sessionInfo.url) {\n            const pageUrl             = testRun.test.pageUrl;\n            const externalProxyHost   = testRun.opts.proxy;\n            let externalProxySettings = null;\n\n            if (externalProxyHost) {\n                externalProxySettings = {\n                    url:         externalProxyHost,\n                    bypassRules: testRun.opts.proxyBypass,\n                };\n            }\n\n            sessionInfo.proxy = proxy;\n            sessionInfo.url   = proxy.openSession(pageUrl, sessionInfo.session, externalProxySettings);\n        }\n\n        return sessionInfo.url;\n    }\n\n    static closeSession (testRun) {\n        const sessionInfo = ACTIVE_SESSIONS_MAP[testRun.browserConnection.id];\n\n        if (!sessionInfo || !sessionInfo.url || !sessionInfo.proxy)\n            return;\n\n        sessionInfo.proxy.closeSession(sessionInfo.session);\n\n        delete ACTIVE_SESSIONS_MAP[testRun.browserConnection.id];\n    }\n}\n\n"]}