@browserstack/testcafe
Version:
Automated browser testing for the modern web development stack.
113 lines • 15.7 kB
JavaScript
"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"]}