UNPKG

@browserstack/testcafe

Version:

Automated browser testing for the modern web development stack.

113 lines 15.7 kB
"use strict"; var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; var __importStar = (this && this.__importStar) || function (mod) { if (mod && mod.__esModule) return mod; var result = {}; if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k]; result["default"] = mod; return result; }; Object.defineProperty(exports, "__esModule", { value: true }); /* eslint-disable */ const lodash_1 = require("lodash"); const moment_1 = __importDefault(require("moment")); const async_event_emitter_1 = __importDefault(require("../utils/async-event-emitter")); const browser_job_1 = __importDefault(require("./browser-job")); const screenshots_1 = __importDefault(require("../screenshots")); const warning_log_1 = __importDefault(require("../notifications/warning-log")); const fixture_hook_controller_1 = __importDefault(require("./fixture-hook-controller")); const clientScriptsRouting = __importStar(require("../custom-client-scripts/routing")); const videos_1 = __importDefault(require("../video-recorder/videos")); class Task extends async_event_emitter_1.default { constructor(tests, browserConnectionGroups, proxy, opts) { super(); this.timeStamp = moment_1.default(); this.running = false; this.browserConnectionGroups = browserConnectionGroups; this.tests = tests; this.opts = opts; this.proxy = proxy; this.warningLog = new warning_log_1.default(); this.screenshots = new screenshots_1.default(Object.assign({ enabled: !this.opts.disableScreenshots }, this.opts.screenshots)); this.fixtureHookController = new fixture_hook_controller_1.default(tests, browserConnectionGroups.length); this.pendingBrowserJobs = this._createBrowserJobs(proxy, this.opts); this.clientScriptRoutes = clientScriptsRouting.register(proxy, tests); this.testStructure = this._prepareTestStructure(tests); if (this.opts.videoPath) this.videos = new videos_1.default(this.pendingBrowserJobs, this.opts, this.warningLog, this.timeStamp); } _assignBrowserJobEventHandlers(job) { job.on('test-run-start', async (testRun) => { await this.emit('test-run-start', testRun); }); job.on('test-run-done', async (testRun) => { await this.emit('test-run-done', testRun); if (this.opts.stopOnFirstFail && testRun.errs.length) { this.abort(); await this.emit('done'); } }); job.once('start', async () => { if (!this.running) { this.running = true; await this.emit('start'); } }); job.once('done', async () => { await this.emit('browser-job-done', job); lodash_1.pull(this.pendingBrowserJobs, job); // console.log(` // Jobs is asked to remove from queue // ${this.pendingBrowserJobs.length} // `); if (!this.pendingBrowserJobs.length) await this.emit('done'); }); job.on('test-action-start', async (args) => { await this.emit('test-action-start', args); }); job.on('test-action-done', async (args) => { await this.emit('test-action-done', args); }); } _prepareTestStructure(tests) { const groups = lodash_1.groupBy(tests, 'fixture.id'); return Object.keys(groups).map(fixtureId => { const testsByGroup = groups[fixtureId]; const fixture = testsByGroup[0].fixture; return { fixture: { id: fixture.id, name: fixture.name, tests: testsByGroup.map(test => { return { id: test.id, name: test.name, skip: test.skip }; }) } }; }); } _createBrowserJobs(proxy, opts) { return this.browserConnectionGroups.map(browserConnectionGroup => { const job = new browser_job_1.default(this.tests, browserConnectionGroup, proxy, this.screenshots, this.warningLog, this.fixtureHookController, opts); this._assignBrowserJobEventHandlers(job); browserConnectionGroup.map(bc => bc.addJob(job)); return job; }); } unRegisterClientScriptRouting() { clientScriptsRouting.unRegister(this.proxy, this.clientScriptRoutes); } // API abort() { this.pendingBrowserJobs.forEach(job => job.abort()); } } exports.default = Task; module.exports = exports.default; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"task.js","sourceRoot":"","sources":["../../src/runner/task.js"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable */\nimport { pull as remove, groupBy } from 'lodash';\nimport moment from 'moment';\nimport AsyncEventEmitter from '../utils/async-event-emitter';\nimport BrowserJob from './browser-job';\nimport Screenshots from '../screenshots';\nimport WarningLog from '../notifications/warning-log';\nimport FixtureHookController from './fixture-hook-controller';\nimport * as clientScriptsRouting from '../custom-client-scripts/routing';\nimport Videos from '../video-recorder/videos';\n\nexport default class Task extends AsyncEventEmitter {\n    constructor (tests, browserConnectionGroups, proxy, opts) {\n        super();\n\n        this.timeStamp               = moment();\n        this.running                 = false;\n        this.browserConnectionGroups = browserConnectionGroups;\n        this.tests                   = tests;\n        this.opts                    = opts;\n        this.proxy                   = proxy;\n        this.warningLog              = new WarningLog();\n\n        this.screenshots = new Screenshots({\n            enabled: !this.opts.disableScreenshots,\n\n            ...this.opts.screenshots\n        });\n\n        this.fixtureHookController = new FixtureHookController(tests, browserConnectionGroups.length);\n        this.pendingBrowserJobs    = this._createBrowserJobs(proxy, this.opts);\n        this.clientScriptRoutes    = clientScriptsRouting.register(proxy, tests);\n        this.testStructure         = this._prepareTestStructure(tests);\n\n        if (this.opts.videoPath)\n            this.videos = new Videos(this.pendingBrowserJobs, this.opts, this.warningLog, this.timeStamp);\n    }\n\n    _assignBrowserJobEventHandlers (job) {\n        job.on('test-run-start', async testRun => {\n            await this.emit('test-run-start', testRun);\n        });\n\n        job.on('test-run-done', async testRun => {\n            await this.emit('test-run-done', testRun);\n\n            if (this.opts.stopOnFirstFail && testRun.errs.length) {\n                this.abort();\n                await this.emit('done');\n            }\n        });\n\n        job.once('start', async () => {\n            if (!this.running) {\n                this.running = true;\n                await this.emit('start');\n            }\n        });\n\n        job.once('done', async () => {\n            await this.emit('browser-job-done', job);\n\n            remove(this.pendingBrowserJobs, job);\n            // console.log(`\n            //     Jobs is asked to remove from queue\n            //     ${this.pendingBrowserJobs.length}\n            // `);\n\n            if (!this.pendingBrowserJobs.length)\n                await this.emit('done');\n        });\n\n        job.on('test-action-start', async args => {\n            await this.emit('test-action-start', args);\n        });\n\n        job.on('test-action-done', async args => {\n            await this.emit('test-action-done', args);\n        });\n\n    }\n\n    _prepareTestStructure (tests) {\n        const groups = groupBy(tests, 'fixture.id');\n\n        return Object.keys(groups).map(fixtureId => {\n            const testsByGroup = groups[fixtureId];\n            const fixture      = testsByGroup[0].fixture;\n\n            return {\n                fixture: {\n                    id:    fixture.id,\n                    name:  fixture.name,\n                    tests: testsByGroup.map(test => {\n                        return {\n                            id:   test.id,\n                            name: test.name,\n                            skip: test.skip\n                        };\n                    })\n                }\n            };\n        });\n    }\n\n    _createBrowserJobs (proxy, opts) {\n        return this.browserConnectionGroups.map(browserConnectionGroup => {\n            const job = new BrowserJob(this.tests, browserConnectionGroup, proxy, this.screenshots, this.warningLog, this.fixtureHookController, opts);\n\n            this._assignBrowserJobEventHandlers(job);\n            browserConnectionGroup.map(bc => bc.addJob(job));\n\n            return job;\n        });\n    }\n\n    unRegisterClientScriptRouting () {\n        clientScriptsRouting.unRegister(this.proxy, this.clientScriptRoutes);\n    }\n\n    // API\n    abort () {\n        this.pendingBrowserJobs.forEach(job => job.abort());\n    }\n}\n"]}