@wdio/runner
Advanced tools
Comparing version 5.0.3 to 5.1.0
@@ -239,3 +239,3 @@ "use strict"; | ||
*/ | ||
!config.logDir || | ||
!config.outputDir || | ||
/** | ||
@@ -265,3 +265,3 @@ * the session wasn't killed during start up phase | ||
const stringLogs = logs.map(log => JSON.stringify(log)).join('\n'); | ||
return _util.default.promisify(_fs.default.writeFile)(_path.default.join(config.logDir, `wdio-${this.cid}-${logType}.log`), stringLogs, 'utf-8'); | ||
return _util.default.promisify(_fs.default.writeFile)(_path.default.join(config.outputDir, `wdio-${this.cid}-${logType}.log`), stringLogs, 'utf-8'); | ||
})); | ||
@@ -315,2 +315,2 @@ } | ||
exports.default = Runner; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/index.js"],"names":["log","Runner","EventEmitter","constructor","configParser","ConfigParser","sigintWasCalled","run","cid","argv","specs","caps","configFile","server","addConfigFile","merge","config","getConfig","map","addService","reporter","BaseReporter","inWatchMode","Boolean","watch","browser","_initSession","_shutdown","isMultiremote","info","endSession","framework","emit","sessionId","capabilities","instances","reduce","browserName","options","protocol","hostname","port","path","queryParams","isW3C","process","send","origin","name","content","failures","_fetchDriverLogs","e","error","global","url","driver","$","selector","$$","on","command","Object","assign","result","logDir","getLogs","logTypes","getLogTypes","debug","join","Promise","all","logType","logs","length","stringLogs","JSON","stringify","util","promisify","fs","writeFile","waitForSync","shutdown","resolve","setTimeout","deleteSession"],"mappings":"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","sourcesContent":["import fs from 'fs'\nimport path from 'path'\nimport util from 'util'\nimport EventEmitter from 'events'\n\nimport logger from '@wdio/logger'\nimport { ConfigParser, initialisePlugin } from '@wdio/config'\n\nimport BaseReporter from './reporter'\nimport { runHook, initialiseServices, initialiseInstance } from './utils'\n\nconst log = logger('wdio-runner')\n\nexport default class Runner extends EventEmitter {\n    constructor () {\n        super()\n        this.configParser = new ConfigParser()\n        this.sigintWasCalled = false\n    }\n\n    /**\n     * run test suite\n     * @param  {String}    cid            worker id (e.g. `0-0`)\n     * @param  {Object}    argv           cli arguments passed into wdio command\n     * @param  {String[]}  specs          list of spec files to run\n     * @param  {Object}    caps           capabilties to run session with\n     * @param  {String}    configFile     path to config file to get config from\n     * @param  {Object}    server         modified WebDriver target\n     * @return {Promise}                  resolves in number of failures for testrun\n     */\n    async run ({ cid, argv, specs, caps, configFile, server }) {\n        this.cid = cid\n        this.specs = specs\n        this.caps = caps\n\n        /**\n         * add config file\n         */\n        this.configParser.addConfigFile(configFile)\n\n        /**\n         * merge cli arguments into config\n         */\n        this.configParser.merge(argv)\n\n        /**\n         * merge host/port changes by service launcher into config\n         */\n        this.configParser.merge(server)\n\n        this.config = this.configParser.getConfig()\n        initialiseServices(this.config, caps).map(::this.configParser.addService)\n\n        this.reporter = new BaseReporter(this.config, this.cid)\n        this.inWatchMode = Boolean(this.config.watch)\n\n        await runHook('beforeSession', this.config, this.caps, this.specs)\n        const browser = await this._initSession(this.config, this.caps)\n\n        /**\n         * return if session initialisation failed\n         */\n        if (!browser) {\n            return this._shutdown(1)\n        }\n\n        const isMultiremote = Boolean(browser.isMultiremote)\n\n        /**\n         * kill session of SIGINT signal showed up while trying to\n         * get a session ID\n         */\n        if (this.sigintWasCalled) {\n            log.info('SIGINT signal detected while starting session, shutting down...')\n            await this.endSession()\n            return this._shutdown(0)\n        }\n\n        /**\n         * initialise framework\n         */\n        this.framework = initialisePlugin(this.config.framework, 'framework')\n\n        /**\n         * initialisation successful, send start message\n         */\n        this.reporter.emit('runner:start', {\n            cid,\n            specs,\n            config: this.config,\n            isMultiremote,\n            sessionId: browser.sessionId,\n            capabilities: isMultiremote\n                ? browser.instances.reduce((caps, browserName) => {\n                    caps[browserName] = browser[browserName].capabilities\n                    return caps\n                }, {})\n                : browser.options.capabilities\n        })\n\n        /**\n         * report sessionId and target connection information to worker\n         */\n        const { protocol, hostname, port, path, queryParams } = browser.options\n        const { isW3C, sessionId } = browser\n        process.send({\n            origin: 'worker',\n            name: 'sessionStarted',\n            content: { sessionId, isW3C, protocol, hostname, port, path, queryParams }\n        })\n\n        /**\n         * kick off tests in framework\n         */\n        let failures = 0\n        try {\n            failures = failures = await this.framework.run(cid, this.config, specs, caps, this.reporter)\n            await this._fetchDriverLogs(this.config)\n        } catch (e) {\n            log.error(e)\n            this.emit('error', e)\n            failures = 1\n        }\n\n        /**\n         * in watch mode we don't close the session and open a blank page instead\n         */\n        if (!argv.watch) {\n            await this.endSession()\n        } else {\n            await global.browser.url('about:blank')\n        }\n\n        this.reporter.emit('runner:end', {\n            failures,\n            cid: this.cid\n        })\n\n        await this._shutdown(failures)\n        return failures\n    }\n\n    /**\n     * init WebDriver session\n     * @param  {object}  config        configuration of sessions\n     * @param  {Object}  caps          desired cabilities of session\n     * @return {Promise}               resolves with browser object or null if session couldn't get established\n     */\n    async _initSession (config, caps) {\n        let browser = null\n\n        try {\n            browser = global.browser = global.driver = await initialiseInstance(config, caps, this.isMultiremote)\n        } catch (e) {\n            log.error(e)\n            this.emit('error', e)\n            return browser\n        }\n\n        browser.config = config\n\n        /**\n         * register global helper method to fetch elements\n         */\n        global.$ = (selector) => browser.$(selector)\n        global.$$ = (selector) => browser.$$(selector)\n\n        /**\n         * register command event\n         */\n        browser.on('command', (command) => this.reporter.emit(\n            'client:beforeCommand',\n            Object.assign(command, { sessionId: browser.sessionId })\n        ))\n\n        /**\n         * register result event\n         */\n        browser.on('result', (result) => this.reporter.emit(\n            'client:afterCommand',\n            Object.assign(result, { sessionId: browser.sessionId })\n        ))\n\n        return browser\n    }\n\n    /**\n     * fetch logs provided by browser driver\n     */\n    async _fetchDriverLogs (config) {\n        /**\n         * only fetch logs if\n         */\n        if (\n            /**\n             * a log directory is given in config\n             */\n            !config.logDir ||\n            /**\n             * the session wasn't killed during start up phase\n             */\n            !global.browser.sessionId ||\n            /**\n             * driver supports it\n             */\n            typeof global.browser.getLogs === 'undefined'\n        ) {\n            return\n        }\n\n        const logTypes = await global.browser.getLogTypes()\n        log.debug(`Fetching logs for ${logTypes.join(', ')}`)\n        return Promise.all(logTypes.map(async (logType) => {\n            const logs = await global.browser.getLogs(logType)\n\n            /**\n             * don't write to file if no logs were captured\n             */\n            if (logs.length === 0) {\n                return\n            }\n\n            const stringLogs = logs.map((log) => JSON.stringify(log)).join('\\n')\n            return util.promisify(fs.writeFile)(\n                path.join(config.logDir, `wdio-${this.cid}-${logType}.log`),\n                stringLogs,\n                'utf-8'\n            )\n        }))\n    }\n\n    /**\n     * kill worker session\n     */\n    async _shutdown (failures) {\n        await this.reporter.waitForSync()\n        this.emit('exit', failures === 0 ? 0 : 1)\n    }\n\n    /**\n     * end WebDriver session, a config object can be applied if object has changed\n     * within a hook by the user\n     */\n    async endSession (shutdown) {\n        /**\n         * don't do anything if test framework returns after SIGINT\n         * if endSession is called without shutdown flag we expect a session id\n         */\n        if (!shutdown && (!global.browser || !global.browser.sessionId)) {\n            return\n        }\n\n        /**\n         * if shutdown was called but no session was created, wait until it was\n         * and try to end it\n         */\n        if (shutdown && (!global.browser || !global.browser.sessionId)) {\n            await new Promise((resolve) => setTimeout(resolve, 250))\n            return this.endSession(shutdown)\n        }\n\n        await global.browser.deleteSession()\n        delete global.browser.sessionId\n\n        await runHook('afterSession', global.browser.config, this.caps, this.specs)\n\n        if (shutdown) {\n            await this._shutdown()\n        }\n    }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/index.js"],"names":["log","Runner","EventEmitter","constructor","configParser","ConfigParser","sigintWasCalled","run","cid","argv","specs","caps","configFile","server","addConfigFile","merge","config","getConfig","map","addService","reporter","BaseReporter","inWatchMode","Boolean","watch","browser","_initSession","_shutdown","isMultiremote","info","endSession","framework","emit","sessionId","capabilities","instances","reduce","browserName","options","protocol","hostname","port","path","queryParams","isW3C","process","send","origin","name","content","failures","_fetchDriverLogs","e","error","global","url","driver","$","selector","$$","on","command","Object","assign","result","outputDir","getLogs","logTypes","getLogTypes","debug","join","Promise","all","logType","logs","length","stringLogs","JSON","stringify","util","promisify","fs","writeFile","waitForSync","shutdown","resolve","setTimeout","deleteSession"],"mappings":"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","sourcesContent":["import fs from 'fs'\nimport path from 'path'\nimport util from 'util'\nimport EventEmitter from 'events'\n\nimport logger from '@wdio/logger'\nimport { ConfigParser, initialisePlugin } from '@wdio/config'\n\nimport BaseReporter from './reporter'\nimport { runHook, initialiseServices, initialiseInstance } from './utils'\n\nconst log = logger('wdio-runner')\n\nexport default class Runner extends EventEmitter {\n    constructor () {\n        super()\n        this.configParser = new ConfigParser()\n        this.sigintWasCalled = false\n    }\n\n    /**\n     * run test suite\n     * @param  {String}    cid            worker id (e.g. `0-0`)\n     * @param  {Object}    argv           cli arguments passed into wdio command\n     * @param  {String[]}  specs          list of spec files to run\n     * @param  {Object}    caps           capabilties to run session with\n     * @param  {String}    configFile     path to config file to get config from\n     * @param  {Object}    server         modified WebDriver target\n     * @return {Promise}                  resolves in number of failures for testrun\n     */\n    async run ({ cid, argv, specs, caps, configFile, server }) {\n        this.cid = cid\n        this.specs = specs\n        this.caps = caps\n\n        /**\n         * add config file\n         */\n        this.configParser.addConfigFile(configFile)\n\n        /**\n         * merge cli arguments into config\n         */\n        this.configParser.merge(argv)\n\n        /**\n         * merge host/port changes by service launcher into config\n         */\n        this.configParser.merge(server)\n\n        this.config = this.configParser.getConfig()\n        initialiseServices(this.config, caps).map(::this.configParser.addService)\n\n        this.reporter = new BaseReporter(this.config, this.cid)\n        this.inWatchMode = Boolean(this.config.watch)\n\n        await runHook('beforeSession', this.config, this.caps, this.specs)\n        const browser = await this._initSession(this.config, this.caps)\n\n        /**\n         * return if session initialisation failed\n         */\n        if (!browser) {\n            return this._shutdown(1)\n        }\n\n        const isMultiremote = Boolean(browser.isMultiremote)\n\n        /**\n         * kill session of SIGINT signal showed up while trying to\n         * get a session ID\n         */\n        if (this.sigintWasCalled) {\n            log.info('SIGINT signal detected while starting session, shutting down...')\n            await this.endSession()\n            return this._shutdown(0)\n        }\n\n        /**\n         * initialise framework\n         */\n        this.framework = initialisePlugin(this.config.framework, 'framework')\n\n        /**\n         * initialisation successful, send start message\n         */\n        this.reporter.emit('runner:start', {\n            cid,\n            specs,\n            config: this.config,\n            isMultiremote,\n            sessionId: browser.sessionId,\n            capabilities: isMultiremote\n                ? browser.instances.reduce((caps, browserName) => {\n                    caps[browserName] = browser[browserName].capabilities\n                    return caps\n                }, {})\n                : browser.options.capabilities\n        })\n\n        /**\n         * report sessionId and target connection information to worker\n         */\n        const { protocol, hostname, port, path, queryParams } = browser.options\n        const { isW3C, sessionId } = browser\n        process.send({\n            origin: 'worker',\n            name: 'sessionStarted',\n            content: { sessionId, isW3C, protocol, hostname, port, path, queryParams }\n        })\n\n        /**\n         * kick off tests in framework\n         */\n        let failures = 0\n        try {\n            failures = failures = await this.framework.run(cid, this.config, specs, caps, this.reporter)\n            await this._fetchDriverLogs(this.config)\n        } catch (e) {\n            log.error(e)\n            this.emit('error', e)\n            failures = 1\n        }\n\n        /**\n         * in watch mode we don't close the session and open a blank page instead\n         */\n        if (!argv.watch) {\n            await this.endSession()\n        } else {\n            await global.browser.url('about:blank')\n        }\n\n        this.reporter.emit('runner:end', {\n            failures,\n            cid: this.cid\n        })\n\n        await this._shutdown(failures)\n        return failures\n    }\n\n    /**\n     * init WebDriver session\n     * @param  {object}  config        configuration of sessions\n     * @param  {Object}  caps          desired cabilities of session\n     * @return {Promise}               resolves with browser object or null if session couldn't get established\n     */\n    async _initSession (config, caps) {\n        let browser = null\n\n        try {\n            browser = global.browser = global.driver = await initialiseInstance(config, caps, this.isMultiremote)\n        } catch (e) {\n            log.error(e)\n            this.emit('error', e)\n            return browser\n        }\n\n        browser.config = config\n\n        /**\n         * register global helper method to fetch elements\n         */\n        global.$ = (selector) => browser.$(selector)\n        global.$$ = (selector) => browser.$$(selector)\n\n        /**\n         * register command event\n         */\n        browser.on('command', (command) => this.reporter.emit(\n            'client:beforeCommand',\n            Object.assign(command, { sessionId: browser.sessionId })\n        ))\n\n        /**\n         * register result event\n         */\n        browser.on('result', (result) => this.reporter.emit(\n            'client:afterCommand',\n            Object.assign(result, { sessionId: browser.sessionId })\n        ))\n\n        return browser\n    }\n\n    /**\n     * fetch logs provided by browser driver\n     */\n    async _fetchDriverLogs (config) {\n        /**\n         * only fetch logs if\n         */\n        if (\n            /**\n             * a log directory is given in config\n             */\n            !config.outputDir ||\n            /**\n             * the session wasn't killed during start up phase\n             */\n            !global.browser.sessionId ||\n            /**\n             * driver supports it\n             */\n            typeof global.browser.getLogs === 'undefined'\n        ) {\n            return\n        }\n\n        const logTypes = await global.browser.getLogTypes()\n        log.debug(`Fetching logs for ${logTypes.join(', ')}`)\n        return Promise.all(logTypes.map(async (logType) => {\n            const logs = await global.browser.getLogs(logType)\n\n            /**\n             * don't write to file if no logs were captured\n             */\n            if (logs.length === 0) {\n                return\n            }\n\n            const stringLogs = logs.map((log) => JSON.stringify(log)).join('\\n')\n            return util.promisify(fs.writeFile)(\n                path.join(config.outputDir, `wdio-${this.cid}-${logType}.log`),\n                stringLogs,\n                'utf-8'\n            )\n        }))\n    }\n\n    /**\n     * kill worker session\n     */\n    async _shutdown (failures) {\n        await this.reporter.waitForSync()\n        this.emit('exit', failures === 0 ? 0 : 1)\n    }\n\n    /**\n     * end WebDriver session, a config object can be applied if object has changed\n     * within a hook by the user\n     */\n    async endSession (shutdown) {\n        /**\n         * don't do anything if test framework returns after SIGINT\n         * if endSession is called without shutdown flag we expect a session id\n         */\n        if (!shutdown && (!global.browser || !global.browser.sessionId)) {\n            return\n        }\n\n        /**\n         * if shutdown was called but no session was created, wait until it was\n         * and try to end it\n         */\n        if (shutdown && (!global.browser || !global.browser.sessionId)) {\n            await new Promise((resolve) => setTimeout(resolve, 250))\n            return this.endSession(shutdown)\n        }\n\n        await global.browser.deleteSession()\n        delete global.browser.sessionId\n\n        await runHook('afterSession', global.browser.config, this.caps, this.specs)\n\n        if (shutdown) {\n            await this._shutdown()\n        }\n    }\n}\n"]} |
@@ -62,7 +62,7 @@ "use strict"; | ||
getLogFile(name) { | ||
if (!this.config.logDir) { | ||
if (!this.config.outputDir) { | ||
return; | ||
} | ||
return _path.default.join(this.config.logDir, `wdio-${this.cid}-${name}-reporter.log`); | ||
return _path.default.join(this.config.outputDir, `wdio-${this.cid}-${name}-reporter.log`); | ||
} | ||
@@ -193,2 +193,2 @@ /** | ||
exports.default = BaseReporter; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/reporter.js"],"names":["log","NOOP","DEFAULT_SYNC_TIMEOUT","DEFAULT_SYNC_INTERVAL","BaseReporter","constructor","config","cid","reporters","map","initReporter","reporterSyncInterval","reporterSyncTimeout","emit","e","payload","forEach","reporter","getLogFile","name","logDir","path","join","getWriteStreamObject","write","content","process","send","origin","waitForSync","startTime","Date","now","Promise","resolve","reject","interval","setInterval","unsyncedReporter","filter","isSynchronised","length","clearInterval","Error","info","ReporterClass","options","logLevel","setLogFile","Array","isArray","Object","assign","customLogFile","logFile","writeStream"],"mappings":"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","sourcesContent":["import path from 'path'\nimport logger from '@wdio/logger'\nimport { initialisePlugin } from '@wdio/config'\n\nconst log = logger('wdio-runner')\n\nconst NOOP = () => {}\nconst DEFAULT_SYNC_TIMEOUT = 5000 // 5s\nconst DEFAULT_SYNC_INTERVAL = 100 // 100ms\n\n/**\n * BaseReporter\n * responsible for initialising reporters for every testrun and propagating events\n * to all these reporters\n */\nexport default class BaseReporter {\n    constructor (config, cid) {\n        this.config = config\n        this.cid = cid\n        this.reporters = config.reporters.map(::this.initReporter)\n\n        /**\n         * these configurations are not publicly documented as there should be no desire for it\n         */\n        this.reporterSyncInterval = this.config.reporterSyncInterval || DEFAULT_SYNC_INTERVAL\n        this.reporterSyncTimeout = this.config.reporterSyncTimeout || DEFAULT_SYNC_TIMEOUT\n    }\n\n    /**\n     * emit events to all registered reporter and wdio launcer\n     *\n     * @param  {String} e       event name\n     * @param  {object} payload event payload\n     */\n    emit (e, payload) {\n        payload.cid = this.cid\n        this.reporters.forEach((reporter) => reporter.emit(e, payload))\n    }\n\n    /**\n     * returns name of log file\n     */\n    getLogFile (name) {\n        if (!this.config.logDir) {\n            return\n        }\n        return path.join(this.config.logDir, `wdio-${this.cid}-${name}-reporter.log`)\n    }\n\n    /**\n     * return write stream object based on reporter name\n     */\n    getWriteStreamObject (reporter) {\n        return {\n            write: /* istanbul ignore next */ (content) => process.send({\n                origin: 'reporter',\n                name: reporter,\n                content\n            })\n        }\n    }\n\n    /**\n     * wait for reporter to finish synchronization, e.g. when sending data asynchronous\n     * to a server (e.g. sumo reporter)\n     */\n    waitForSync () {\n        const startTime = Date.now()\n        return new Promise((resolve, reject) => {\n            const interval = setInterval(() => {\n                const unsyncedReporter = this.reporters\n                    .filter((reporter) => !reporter.isSynchronised)\n                    .map((reporter) => reporter.constructor.name)\n\n                if ((Date.now() - startTime) > this.reporterSyncTimeout && unsyncedReporter.length) {\n                    clearInterval(interval)\n                    return reject(new Error(`Some reporters are still unsynced: ${unsyncedReporter.join(', ')}`))\n                }\n\n                /**\n                 * no reporter are in need to sync anymore, continue\n                 */\n                if (!unsyncedReporter.length) {\n                    clearInterval(interval)\n                    return resolve(true)\n                }\n\n                log.info(`Wait for ${unsyncedReporter.length} reporter to synchronise`)\n                // wait otherwise\n            }, this.reporterSyncInterval)\n        })\n    }\n\n    /**\n     * initialise reporters\n     */\n    initReporter (reporter) {\n        let ReporterClass\n        let options = {\n            logLevel: this.config.logLevel,\n            setLogFile: NOOP\n        }\n\n        /**\n         * check if reporter has custom options\n         */\n        if (Array.isArray(reporter)) {\n            options = Object.assign(options, reporter[1])\n            reporter = reporter[0]\n        }\n\n        /**\n         * check if reporter was passed in from a file, e.g.\n         *\n         * ```js\n         * const MyCustomeReporter = require('/some/path/MyCustomeReporter.js')\n         * export.config = {\n         *     //...\n         *     reporters: [\n         *         MyCustomeReporter, // or\n         *         [MyCustomeReporter, { custom: 'option' }]\n         *     ]\n         *     //...\n         * }\n         * ```\n         */\n        if (typeof reporter === 'function') {\n            ReporterClass = reporter\n            const customLogFile = options.setLogFile(this.cid, ReporterClass.name)\n            options.logFile = customLogFile || this.getLogFile(ReporterClass.name)\n            options.writeStream = this.getWriteStreamObject(ReporterClass.name)\n            return new ReporterClass(options)\n        }\n\n        /**\n         * check if reporter is a node package, e.g. wdio-dot reporter\n         *\n         * ```js\n         * export.config = {\n         *     //...\n         *     reporters: [\n         *         'dot', // or\n         *         ['dot', { custom: 'option' }]\n         *     ]\n         *     //...\n         * }\n         * ```\n         */\n        if (typeof reporter === 'string') {\n            ReporterClass = initialisePlugin(reporter, 'reporter')\n            const customLogFile = options.setLogFile(this.cid, reporter)\n            options.logFile = customLogFile || this.getLogFile(reporter)\n            options.writeStream = this.getWriteStreamObject(reporter)\n            return new ReporterClass(options)\n        }\n\n        /**\n         * throw error if reporter property was invalid\n         */\n        throw new Error('Invalid reporters config')\n    }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/reporter.js"],"names":["log","NOOP","DEFAULT_SYNC_TIMEOUT","DEFAULT_SYNC_INTERVAL","BaseReporter","constructor","config","cid","reporters","map","initReporter","reporterSyncInterval","reporterSyncTimeout","emit","e","payload","forEach","reporter","getLogFile","name","outputDir","path","join","getWriteStreamObject","write","content","process","send","origin","waitForSync","startTime","Date","now","Promise","resolve","reject","interval","setInterval","unsyncedReporter","filter","isSynchronised","length","clearInterval","Error","info","ReporterClass","options","logLevel","setLogFile","Array","isArray","Object","assign","customLogFile","logFile","writeStream"],"mappings":"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","sourcesContent":["import path from 'path'\nimport logger from '@wdio/logger'\nimport { initialisePlugin } from '@wdio/config'\n\nconst log = logger('wdio-runner')\n\nconst NOOP = () => {}\nconst DEFAULT_SYNC_TIMEOUT = 5000 // 5s\nconst DEFAULT_SYNC_INTERVAL = 100 // 100ms\n\n/**\n * BaseReporter\n * responsible for initialising reporters for every testrun and propagating events\n * to all these reporters\n */\nexport default class BaseReporter {\n    constructor (config, cid) {\n        this.config = config\n        this.cid = cid\n        this.reporters = config.reporters.map(::this.initReporter)\n\n        /**\n         * these configurations are not publicly documented as there should be no desire for it\n         */\n        this.reporterSyncInterval = this.config.reporterSyncInterval || DEFAULT_SYNC_INTERVAL\n        this.reporterSyncTimeout = this.config.reporterSyncTimeout || DEFAULT_SYNC_TIMEOUT\n    }\n\n    /**\n     * emit events to all registered reporter and wdio launcer\n     *\n     * @param  {String} e       event name\n     * @param  {object} payload event payload\n     */\n    emit (e, payload) {\n        payload.cid = this.cid\n        this.reporters.forEach((reporter) => reporter.emit(e, payload))\n    }\n\n    /**\n     * returns name of log file\n     */\n    getLogFile (name) {\n        if (!this.config.outputDir) {\n            return\n        }\n        return path.join(this.config.outputDir, `wdio-${this.cid}-${name}-reporter.log`)\n    }\n\n    /**\n     * return write stream object based on reporter name\n     */\n    getWriteStreamObject (reporter) {\n        return {\n            write: /* istanbul ignore next */ (content) => process.send({\n                origin: 'reporter',\n                name: reporter,\n                content\n            })\n        }\n    }\n\n    /**\n     * wait for reporter to finish synchronization, e.g. when sending data asynchronous\n     * to a server (e.g. sumo reporter)\n     */\n    waitForSync () {\n        const startTime = Date.now()\n        return new Promise((resolve, reject) => {\n            const interval = setInterval(() => {\n                const unsyncedReporter = this.reporters\n                    .filter((reporter) => !reporter.isSynchronised)\n                    .map((reporter) => reporter.constructor.name)\n\n                if ((Date.now() - startTime) > this.reporterSyncTimeout && unsyncedReporter.length) {\n                    clearInterval(interval)\n                    return reject(new Error(`Some reporters are still unsynced: ${unsyncedReporter.join(', ')}`))\n                }\n\n                /**\n                 * no reporter are in need to sync anymore, continue\n                 */\n                if (!unsyncedReporter.length) {\n                    clearInterval(interval)\n                    return resolve(true)\n                }\n\n                log.info(`Wait for ${unsyncedReporter.length} reporter to synchronise`)\n                // wait otherwise\n            }, this.reporterSyncInterval)\n        })\n    }\n\n    /**\n     * initialise reporters\n     */\n    initReporter (reporter) {\n        let ReporterClass\n        let options = {\n            logLevel: this.config.logLevel,\n            setLogFile: NOOP\n        }\n\n        /**\n         * check if reporter has custom options\n         */\n        if (Array.isArray(reporter)) {\n            options = Object.assign(options, reporter[1])\n            reporter = reporter[0]\n        }\n\n        /**\n         * check if reporter was passed in from a file, e.g.\n         *\n         * ```js\n         * const MyCustomeReporter = require('/some/path/MyCustomeReporter.js')\n         * export.config = {\n         *     //...\n         *     reporters: [\n         *         MyCustomeReporter, // or\n         *         [MyCustomeReporter, { custom: 'option' }]\n         *     ]\n         *     //...\n         * }\n         * ```\n         */\n        if (typeof reporter === 'function') {\n            ReporterClass = reporter\n            const customLogFile = options.setLogFile(this.cid, ReporterClass.name)\n            options.logFile = customLogFile || this.getLogFile(ReporterClass.name)\n            options.writeStream = this.getWriteStreamObject(ReporterClass.name)\n            return new ReporterClass(options)\n        }\n\n        /**\n         * check if reporter is a node package, e.g. wdio-dot reporter\n         *\n         * ```js\n         * export.config = {\n         *     //...\n         *     reporters: [\n         *         'dot', // or\n         *         ['dot', { custom: 'option' }]\n         *     ]\n         *     //...\n         * }\n         * ```\n         */\n        if (typeof reporter === 'string') {\n            ReporterClass = initialisePlugin(reporter, 'reporter')\n            const customLogFile = options.setLogFile(this.cid, reporter)\n            options.logFile = customLogFile || this.getLogFile(reporter)\n            options.writeStream = this.getWriteStreamObject(reporter)\n            return new ReporterClass(options)\n        }\n\n        /**\n         * throw error if reporter property was invalid\n         */\n        throw new Error('Invalid reporters config')\n    }\n}\n"]} |
{ | ||
"name": "@wdio/runner", | ||
"version": "5.0.3", | ||
"version": "5.1.0", | ||
"description": "A WebdriverIO service that runs tests in arbitrary environments", | ||
@@ -33,11 +33,12 @@ "author": "Christian Bromann <christian@saucelabs.com>", | ||
"dependencies": { | ||
"@wdio/config": "^5.0.3", | ||
"@wdio/config": "^5.1.0", | ||
"@wdio/logger": "^5.0.3", | ||
"deepmerge": "^2.0.1", | ||
"gaze": "^1.1.2", | ||
"webdriverio": "^5.0.3" | ||
"webdriverio": "^5.1.0" | ||
}, | ||
"publishConfig": { | ||
"access": "public" | ||
} | ||
}, | ||
"gitHead": "db1fd4728453075c5c549e755a3e5685ad85284e" | ||
} |
Native code
Supply chain riskContains native code (e.g., compiled binaries or shared libraries). Including native code can obscure malicious behavior.
Found 1 instance in 1 package
0
59116
5
Updated@wdio/config@^5.1.0
Updatedwebdriverio@^5.1.0