Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@wdio/local-runner

Package Overview
Dependencies
Maintainers
3
Versions
642
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@wdio/local-runner - npm Package Compare versions

Comparing version 5.0.0-beta.10 to 5.0.0-beta.12

build/repl.js

11

build/run.js

@@ -20,2 +20,6 @@ "use strict";

if (!m || !m.command) {
return log.info('Ignore message for worker:', m);
}
log.info(`Run worker command: ${m.command}`);

@@ -53,5 +57,10 @@ runner[m.command](m).then(result => process.send({

(0, _asyncExitHook.default)(callback => {
if (!callback) {
return;
}
runner.sigintWasCalled = true;
log.info(`Received SIGINT, giving process ${_constants.SHUTDOWN_TIMEOUT}ms to shutdown gracefully`);
setTimeout(callback, _constants.SHUTDOWN_TIMEOUT);
});
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9ydW4uanMiXSwibmFtZXMiOlsibG9nIiwicnVubmVyIiwiUnVubmVyIiwicHJvY2VzcyIsIm9uIiwibSIsImluZm8iLCJjb21tYW5kIiwidGhlbiIsInJlc3VsdCIsInNlbmQiLCJvcmlnaW4iLCJuYW1lIiwiY29udGVudCIsImUiLCJlcnJvciIsImV4aXQiLCJtZXNzYWdlIiwic3RhY2siLCJjYWxsYmFjayIsIlNIVVRET1dOX1RJTUVPVVQiLCJzZXRUaW1lb3V0Il0sIm1hcHBpbmdzIjoiOzs7O0FBQUE7O0FBRUE7O0FBQ0E7O0FBRUE7Ozs7QUFFQSxNQUFNQSxHQUFHLEdBQUcscUJBQU8sbUJBQVAsQ0FBWjtBQUVBLE1BQU1DLE1BQU0sR0FBRyxJQUFJQyxlQUFKLEVBQWY7QUFDQUMsT0FBTyxDQUFDQyxFQUFSLENBQVcsU0FBWCxFQUF1QkMsQ0FBRCxJQUFPO0FBQUE7O0FBQ3pCTCxFQUFBQSxHQUFHLENBQUNNLElBQUosQ0FBVSx1QkFBc0JELENBQUMsQ0FBQ0UsT0FBUSxFQUExQztBQUNBTixFQUFBQSxNQUFNLENBQUNJLENBQUMsQ0FBQ0UsT0FBSCxDQUFOLENBQWtCRixDQUFsQixFQUFxQkcsSUFBckIsQ0FDS0MsTUFBRCxJQUFZTixPQUFPLENBQUNPLElBQVIsQ0FBYTtBQUNyQkMsSUFBQUEsTUFBTSxFQUFFLFFBRGE7QUFFckJDLElBQUFBLElBQUksRUFBRSxnQkFGZTtBQUdyQkMsSUFBQUEsT0FBTyxFQUFFO0FBQ0xOLE1BQUFBLE9BQU8sRUFBRUYsQ0FBQyxDQUFDRSxPQUROO0FBRUxFLE1BQUFBO0FBRks7QUFIWSxHQUFiLENBRGhCLEVBU0tLLENBQUQsSUFBTztBQUNIZCxJQUFBQSxHQUFHLENBQUNlLEtBQUosQ0FBVyxnQ0FBWCxFQUE0Q0QsQ0FBNUM7QUFDQVgsSUFBQUEsT0FBTyxDQUFDYSxJQUFSLENBQWEsQ0FBYjtBQUNILEdBWkw7QUFlQWYsRUFBQUEsTUFBTSxDQUFDRyxFQUFQLENBQVUsTUFBVixFQUFvQixZQUFBRCxPQUFPLEVBQUNhLElBQTVCO0FBQ0FmLEVBQUFBLE1BQU0sQ0FBQ0csRUFBUCxDQUFVLE9BQVYsRUFBbUIsQ0FBQztBQUFFUSxJQUFBQSxJQUFGO0FBQVFLLElBQUFBLE9BQVI7QUFBaUJDLElBQUFBO0FBQWpCLEdBQUQsS0FBOEJmLE9BQU8sQ0FBQ08sSUFBUixDQUFhO0FBQzFEQyxJQUFBQSxNQUFNLEVBQUUsUUFEa0Q7QUFFMURDLElBQUFBLElBQUksRUFBRSxPQUZvRDtBQUcxREMsSUFBQUEsT0FBTyxFQUFFO0FBQUVELE1BQUFBLElBQUY7QUFBUUssTUFBQUEsT0FBUjtBQUFpQkMsTUFBQUE7QUFBakI7QUFIaUQsR0FBYixDQUFqRDtBQUtILENBdkJEO0FBeUJBOzs7O0FBR0EsNEJBQVVDLFFBQUQsSUFBYztBQUNuQm5CLEVBQUFBLEdBQUcsQ0FBQ00sSUFBSixDQUFVLG1DQUFrQ2MsMkJBQWlCLDJCQUE3RDtBQUNBQyxFQUFBQSxVQUFVLENBQUNGLFFBQUQsRUFBV0MsMkJBQVgsQ0FBVjtBQUNILENBSEQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgZXhpdEhvb2sgZnJvbSAnYXN5bmMtZXhpdC1ob29rJ1xuXG5pbXBvcnQgUnVubmVyIGZyb20gJ0B3ZGlvL3J1bm5lcidcbmltcG9ydCBsb2dnZXIgZnJvbSAnQHdkaW8vbG9nZ2VyJ1xuXG5pbXBvcnQgeyBTSFVURE9XTl9USU1FT1VUIH0gZnJvbSAnLi9jb25zdGFudHMnXG5cbmNvbnN0IGxvZyA9IGxvZ2dlcignd2Rpby1sb2NhbC1ydW5uZXInKVxuXG5jb25zdCBydW5uZXIgPSBuZXcgUnVubmVyKClcbnByb2Nlc3Mub24oJ21lc3NhZ2UnLCAobSkgPT4ge1xuICAgIGxvZy5pbmZvKGBSdW4gd29ya2VyIGNvbW1hbmQ6ICR7bS5jb21tYW5kfWApXG4gICAgcnVubmVyW20uY29tbWFuZF0obSkudGhlbihcbiAgICAgICAgKHJlc3VsdCkgPT4gcHJvY2Vzcy5zZW5kKHtcbiAgICAgICAgICAgIG9yaWdpbjogJ3dvcmtlcicsXG4gICAgICAgICAgICBuYW1lOiAnZmluaXNlZENvbW1hbmQnLFxuICAgICAgICAgICAgY29udGVudDoge1xuICAgICAgICAgICAgICAgIGNvbW1hbmQ6IG0uY29tbWFuZCxcbiAgICAgICAgICAgICAgICByZXN1bHRcbiAgICAgICAgICAgIH1cbiAgICAgICAgfSksXG4gICAgICAgIChlKSA9PiB7XG4gICAgICAgICAgICBsb2cuZXJyb3IoYEZhaWxlZCBsYXVuY2hpbmcgdGVzdCBzZXNzaW9uOmAsIGUpXG4gICAgICAgICAgICBwcm9jZXNzLmV4aXQoMSlcbiAgICAgICAgfVxuICAgIClcblxuICAgIHJ1bm5lci5vbignZXhpdCcsIDo6cHJvY2Vzcy5leGl0KVxuICAgIHJ1bm5lci5vbignZXJyb3InLCAoeyBuYW1lLCBtZXNzYWdlLCBzdGFjayB9KSA9PiBwcm9jZXNzLnNlbmQoe1xuICAgICAgICBvcmlnaW46ICd3b3JrZXInLFxuICAgICAgICBuYW1lOiAnZXJyb3InLFxuICAgICAgICBjb250ZW50OiB7IG5hbWUsIG1lc3NhZ2UsIHN0YWNrIH1cbiAgICB9KSlcbn0pXG5cbi8qKlxuICogY2F0Y2ggc2lnaW50IG1lc3NhZ2VzIGFzIHRoZXkgYXJlIGhhbmRsZWQgYnkgbWFpbiBwcm9jZXNzXG4gKi9cbmV4aXRIb29rKChjYWxsYmFjaykgPT4ge1xuICAgIGxvZy5pbmZvKGBSZWNlaXZlZCBTSUdJTlQsIGdpdmluZyBwcm9jZXNzICR7U0hVVERPV05fVElNRU9VVH1tcyB0byBzaHV0ZG93biBncmFjZWZ1bGx5YClcbiAgICBzZXRUaW1lb3V0KGNhbGxiYWNrLCBTSFVURE9XTl9USU1FT1VUKVxufSlcbiJdfQ==
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9ydW4uanMiXSwibmFtZXMiOlsibG9nIiwicnVubmVyIiwiUnVubmVyIiwicHJvY2VzcyIsIm9uIiwibSIsImNvbW1hbmQiLCJpbmZvIiwidGhlbiIsInJlc3VsdCIsInNlbmQiLCJvcmlnaW4iLCJuYW1lIiwiY29udGVudCIsImUiLCJlcnJvciIsImV4aXQiLCJtZXNzYWdlIiwic3RhY2siLCJjYWxsYmFjayIsInNpZ2ludFdhc0NhbGxlZCIsIlNIVVRET1dOX1RJTUVPVVQiLCJzZXRUaW1lb3V0Il0sIm1hcHBpbmdzIjoiOzs7O0FBQUE7O0FBRUE7O0FBQ0E7O0FBRUE7Ozs7QUFFQSxNQUFNQSxHQUFHLEdBQUcscUJBQU8sbUJBQVAsQ0FBWjtBQUVBLE1BQU1DLE1BQU0sR0FBRyxJQUFJQyxlQUFKLEVBQWY7QUFDQUMsT0FBTyxDQUFDQyxFQUFSLENBQVcsU0FBWCxFQUF1QkMsQ0FBRCxJQUFPO0FBQUE7O0FBQ3pCLE1BQUksQ0FBQ0EsQ0FBRCxJQUFNLENBQUNBLENBQUMsQ0FBQ0MsT0FBYixFQUFzQjtBQUNsQixXQUFPTixHQUFHLENBQUNPLElBQUosQ0FBUyw0QkFBVCxFQUF1Q0YsQ0FBdkMsQ0FBUDtBQUNIOztBQUVETCxFQUFBQSxHQUFHLENBQUNPLElBQUosQ0FBVSx1QkFBc0JGLENBQUMsQ0FBQ0MsT0FBUSxFQUExQztBQUNBTCxFQUFBQSxNQUFNLENBQUNJLENBQUMsQ0FBQ0MsT0FBSCxDQUFOLENBQWtCRCxDQUFsQixFQUFxQkcsSUFBckIsQ0FDS0MsTUFBRCxJQUFZTixPQUFPLENBQUNPLElBQVIsQ0FBYTtBQUNyQkMsSUFBQUEsTUFBTSxFQUFFLFFBRGE7QUFFckJDLElBQUFBLElBQUksRUFBRSxnQkFGZTtBQUdyQkMsSUFBQUEsT0FBTyxFQUFFO0FBQ0xQLE1BQUFBLE9BQU8sRUFBRUQsQ0FBQyxDQUFDQyxPQUROO0FBRUxHLE1BQUFBO0FBRks7QUFIWSxHQUFiLENBRGhCLEVBU0tLLENBQUQsSUFBTztBQUNIZCxJQUFBQSxHQUFHLENBQUNlLEtBQUosQ0FBVyxnQ0FBWCxFQUE0Q0QsQ0FBNUM7QUFDQVgsSUFBQUEsT0FBTyxDQUFDYSxJQUFSLENBQWEsQ0FBYjtBQUNILEdBWkw7QUFlQWYsRUFBQUEsTUFBTSxDQUFDRyxFQUFQLENBQVUsTUFBVixFQUFvQixZQUFBRCxPQUFPLEVBQUNhLElBQTVCO0FBQ0FmLEVBQUFBLE1BQU0sQ0FBQ0csRUFBUCxDQUFVLE9BQVYsRUFBbUIsQ0FBQztBQUFFUSxJQUFBQSxJQUFGO0FBQVFLLElBQUFBLE9BQVI7QUFBaUJDLElBQUFBO0FBQWpCLEdBQUQsS0FBOEJmLE9BQU8sQ0FBQ08sSUFBUixDQUFhO0FBQzFEQyxJQUFBQSxNQUFNLEVBQUUsUUFEa0Q7QUFFMURDLElBQUFBLElBQUksRUFBRSxPQUZvRDtBQUcxREMsSUFBQUEsT0FBTyxFQUFFO0FBQUVELE1BQUFBLElBQUY7QUFBUUssTUFBQUEsT0FBUjtBQUFpQkMsTUFBQUE7QUFBakI7QUFIaUQsR0FBYixDQUFqRDtBQUtILENBM0JEO0FBNkJBOzs7O0FBR0EsNEJBQVVDLFFBQUQsSUFBYztBQUNuQixNQUFJLENBQUNBLFFBQUwsRUFBZTtBQUNYO0FBQ0g7O0FBRURsQixFQUFBQSxNQUFNLENBQUNtQixlQUFQLEdBQXlCLElBQXpCO0FBQ0FwQixFQUFBQSxHQUFHLENBQUNPLElBQUosQ0FBVSxtQ0FBa0NjLDJCQUFpQiwyQkFBN0Q7QUFDQUMsRUFBQUEsVUFBVSxDQUFDSCxRQUFELEVBQVdFLDJCQUFYLENBQVY7QUFDSCxDQVJEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGV4aXRIb29rIGZyb20gJ2FzeW5jLWV4aXQtaG9vaydcblxuaW1wb3J0IFJ1bm5lciBmcm9tICdAd2Rpby9ydW5uZXInXG5pbXBvcnQgbG9nZ2VyIGZyb20gJ0B3ZGlvL2xvZ2dlcidcblxuaW1wb3J0IHsgU0hVVERPV05fVElNRU9VVCB9IGZyb20gJy4vY29uc3RhbnRzJ1xuXG5jb25zdCBsb2cgPSBsb2dnZXIoJ3dkaW8tbG9jYWwtcnVubmVyJylcblxuY29uc3QgcnVubmVyID0gbmV3IFJ1bm5lcigpXG5wcm9jZXNzLm9uKCdtZXNzYWdlJywgKG0pID0+IHtcbiAgICBpZiAoIW0gfHwgIW0uY29tbWFuZCkge1xuICAgICAgICByZXR1cm4gbG9nLmluZm8oJ0lnbm9yZSBtZXNzYWdlIGZvciB3b3JrZXI6JywgbSlcbiAgICB9XG5cbiAgICBsb2cuaW5mbyhgUnVuIHdvcmtlciBjb21tYW5kOiAke20uY29tbWFuZH1gKVxuICAgIHJ1bm5lclttLmNvbW1hbmRdKG0pLnRoZW4oXG4gICAgICAgIChyZXN1bHQpID0+IHByb2Nlc3Muc2VuZCh7XG4gICAgICAgICAgICBvcmlnaW46ICd3b3JrZXInLFxuICAgICAgICAgICAgbmFtZTogJ2ZpbmlzZWRDb21tYW5kJyxcbiAgICAgICAgICAgIGNvbnRlbnQ6IHtcbiAgICAgICAgICAgICAgICBjb21tYW5kOiBtLmNvbW1hbmQsXG4gICAgICAgICAgICAgICAgcmVzdWx0XG4gICAgICAgICAgICB9XG4gICAgICAgIH0pLFxuICAgICAgICAoZSkgPT4ge1xuICAgICAgICAgICAgbG9nLmVycm9yKGBGYWlsZWQgbGF1bmNoaW5nIHRlc3Qgc2Vzc2lvbjpgLCBlKVxuICAgICAgICAgICAgcHJvY2Vzcy5leGl0KDEpXG4gICAgICAgIH1cbiAgICApXG5cbiAgICBydW5uZXIub24oJ2V4aXQnLCA6OnByb2Nlc3MuZXhpdClcbiAgICBydW5uZXIub24oJ2Vycm9yJywgKHsgbmFtZSwgbWVzc2FnZSwgc3RhY2sgfSkgPT4gcHJvY2Vzcy5zZW5kKHtcbiAgICAgICAgb3JpZ2luOiAnd29ya2VyJyxcbiAgICAgICAgbmFtZTogJ2Vycm9yJyxcbiAgICAgICAgY29udGVudDogeyBuYW1lLCBtZXNzYWdlLCBzdGFjayB9XG4gICAgfSkpXG59KVxuXG4vKipcbiAqIGNhdGNoIHNpZ2ludCBtZXNzYWdlcyBhcyB0aGV5IGFyZSBoYW5kbGVkIGJ5IG1haW4gcHJvY2Vzc1xuICovXG5leGl0SG9vaygoY2FsbGJhY2spID0+IHtcbiAgICBpZiAoIWNhbGxiYWNrKSB7XG4gICAgICAgIHJldHVyblxuICAgIH1cblxuICAgIHJ1bm5lci5zaWdpbnRXYXNDYWxsZWQgPSB0cnVlXG4gICAgbG9nLmluZm8oYFJlY2VpdmVkIFNJR0lOVCwgZ2l2aW5nIHByb2Nlc3MgJHtTSFVURE9XTl9USU1FT1VUfW1zIHRvIHNodXRkb3duIGdyYWNlZnVsbHlgKVxuICAgIHNldFRpbWVvdXQoY2FsbGJhY2ssIFNIVVRET1dOX1RJTUVPVVQpXG59KVxuIl19

13

build/transformStream.js

@@ -13,9 +13,16 @@ "use strict";

class RunnerTransformStream extends _stream.Transform {
constructor(cid) {
constructor(cid, emitter) {
super();
this.cid = cid;
this.emitter = emitter;
}
_transform(chunk, encoding, callback) {
this.push(`[${this.cid}] ${chunk.toString()}`);
const logMsg = chunk.toString();
if (logMsg.startsWith('Debugger listening on ws')) {
return callback();
}
this.push(`[${this.cid}] ${logMsg}`);
callback();

@@ -27,2 +34,2 @@ }

exports.default = RunnerTransformStream;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy90cmFuc2Zvcm1TdHJlYW0uanMiXSwibmFtZXMiOlsiUnVubmVyVHJhbnNmb3JtU3RyZWFtIiwiVHJhbnNmb3JtIiwiY29uc3RydWN0b3IiLCJjaWQiLCJfdHJhbnNmb3JtIiwiY2h1bmsiLCJlbmNvZGluZyIsImNhbGxiYWNrIiwicHVzaCIsInRvU3RyaW5nIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBQTs7QUFFZSxNQUFNQSxxQkFBTixTQUFvQ0MsaUJBQXBDLENBQThDO0FBQ3pEQyxFQUFBQSxXQUFXLENBQUVDLEdBQUYsRUFBTztBQUNkO0FBQ0EsU0FBS0EsR0FBTCxHQUFXQSxHQUFYO0FBQ0g7O0FBRURDLEVBQUFBLFVBQVUsQ0FBQ0MsS0FBRCxFQUFRQyxRQUFSLEVBQWtCQyxRQUFsQixFQUE0QjtBQUNsQyxTQUFLQyxJQUFMLENBQVcsSUFBRyxLQUFLTCxHQUFJLEtBQUlFLEtBQUssQ0FBQ0ksUUFBTixFQUFpQixFQUE1QztBQUNBRixJQUFBQSxRQUFRO0FBQ1g7O0FBVHdEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVHJhbnNmb3JtIH0gZnJvbSAnc3RyZWFtJ1xuXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBSdW5uZXJUcmFuc2Zvcm1TdHJlYW0gZXh0ZW5kcyBUcmFuc2Zvcm0ge1xuICAgIGNvbnN0cnVjdG9yIChjaWQpIHtcbiAgICAgICAgc3VwZXIoKVxuICAgICAgICB0aGlzLmNpZCA9IGNpZFxuICAgIH1cblxuICAgIF90cmFuc2Zvcm0oY2h1bmssIGVuY29kaW5nLCBjYWxsYmFjaykge1xuICAgICAgICB0aGlzLnB1c2goYFske3RoaXMuY2lkfV0gJHtjaHVuay50b1N0cmluZygpfWApXG4gICAgICAgIGNhbGxiYWNrKClcbiAgICB9XG59XG4iXX0=
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy90cmFuc2Zvcm1TdHJlYW0uanMiXSwibmFtZXMiOlsiUnVubmVyVHJhbnNmb3JtU3RyZWFtIiwiVHJhbnNmb3JtIiwiY29uc3RydWN0b3IiLCJjaWQiLCJlbWl0dGVyIiwiX3RyYW5zZm9ybSIsImNodW5rIiwiZW5jb2RpbmciLCJjYWxsYmFjayIsImxvZ01zZyIsInRvU3RyaW5nIiwic3RhcnRzV2l0aCIsInB1c2giXSwibWFwcGluZ3MiOiI7Ozs7Ozs7OztBQUFBOztBQUVlLE1BQU1BLHFCQUFOLFNBQW9DQyxpQkFBcEMsQ0FBOEM7QUFDekRDLEVBQUFBLFdBQVcsQ0FBRUMsR0FBRixFQUFPQyxPQUFQLEVBQWdCO0FBQ3ZCO0FBQ0EsU0FBS0QsR0FBTCxHQUFXQSxHQUFYO0FBQ0EsU0FBS0MsT0FBTCxHQUFlQSxPQUFmO0FBQ0g7O0FBRURDLEVBQUFBLFVBQVUsQ0FBQ0MsS0FBRCxFQUFRQyxRQUFSLEVBQWtCQyxRQUFsQixFQUE0QjtBQUNsQyxVQUFNQyxNQUFNLEdBQUdILEtBQUssQ0FBQ0ksUUFBTixFQUFmOztBQUVBLFFBQUlELE1BQU0sQ0FBQ0UsVUFBUCxDQUFrQiwwQkFBbEIsQ0FBSixFQUFtRDtBQUMvQyxhQUFPSCxRQUFRLEVBQWY7QUFDSDs7QUFFRCxTQUFLSSxJQUFMLENBQVcsSUFBRyxLQUFLVCxHQUFJLEtBQUlNLE1BQU8sRUFBbEM7QUFDQUQsSUFBQUEsUUFBUTtBQUNYOztBQWhCd0QiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUcmFuc2Zvcm0gfSBmcm9tICdzdHJlYW0nXG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFJ1bm5lclRyYW5zZm9ybVN0cmVhbSBleHRlbmRzIFRyYW5zZm9ybSB7XG4gICAgY29uc3RydWN0b3IgKGNpZCwgZW1pdHRlcikge1xuICAgICAgICBzdXBlcigpXG4gICAgICAgIHRoaXMuY2lkID0gY2lkXG4gICAgICAgIHRoaXMuZW1pdHRlciA9IGVtaXR0ZXJcbiAgICB9XG5cbiAgICBfdHJhbnNmb3JtKGNodW5rLCBlbmNvZGluZywgY2FsbGJhY2spIHtcbiAgICAgICAgY29uc3QgbG9nTXNnID0gY2h1bmsudG9TdHJpbmcoKVxuXG4gICAgICAgIGlmIChsb2dNc2cuc3RhcnRzV2l0aCgnRGVidWdnZXIgbGlzdGVuaW5nIG9uIHdzJykpIHtcbiAgICAgICAgICAgIHJldHVybiBjYWxsYmFjaygpXG4gICAgICAgIH1cblxuICAgICAgICB0aGlzLnB1c2goYFske3RoaXMuY2lkfV0gJHtsb2dNc2d9YClcbiAgICAgICAgY2FsbGJhY2soKVxuICAgIH1cbn1cbiJdfQ==

@@ -20,4 +20,10 @@ "use strict";

var _repl = _interopRequireDefault(require("./repl"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; var ownKeys = Object.keys(source); if (typeof Object.getOwnPropertySymbols === 'function') { ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) { return Object.getOwnPropertyDescriptor(source, sym).enumerable; })); } ownKeys.forEach(function (key) { _defineProperty(target, key, source[key]); }); } return target; }
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
const log = (0, _logger.default)('wdio-local-runner');

@@ -71,3 +77,4 @@ /**

const runnerEnv = Object.assign(process.env, this.config.runnerEnv, {
WDIO_LOG_LEVEL: this.config.logLevel
WDIO_LOG_LEVEL: this.config.logLevel,
WDIO_WORKER: true
});

@@ -81,3 +88,3 @@

const childProcess = _child_process.default.fork(_path.default.join(__dirname, 'run.js'), argv, {
const childProcess = this.childProcess = _child_process.default.fork(_path.default.join(__dirname, 'run.js'), argv, {
cwd: process.cwd(),

@@ -89,42 +96,95 @@ env: runnerEnv,

childProcess.on('message', payload => {
/**
* resolve pending commands
*/
if (payload.name === 'finisedCommand') {
this.isBusy = false;
}
/**
* store sessionId and connection data to worker instance
*/
childProcess.on('message', this._handleMessage.bind(this));
childProcess.on('error', this._handleError.bind(this));
childProcess.on('exit', this._handleExit.bind(this));
/* istanbul ignore if */
if (!process.env.JEST_WORKER_ID) {
childProcess.stdout.pipe(new _transformStream.default(cid)).pipe(process.stdout);
childProcess.stderr.pipe(new _transformStream.default(cid)).pipe(process.stderr);
process.stdin.pipe(childProcess.stdin);
}
if (payload.name === 'sessionStarted') {
this.sessionId = payload.content.sessionId;
delete payload.content.sessionId;
Object.assign(this.server, payload.content);
}
return childProcess;
}
this.emit('message', Object.assign(payload, {
cid
}));
});
childProcess.on('error', payload => this.emit('error', Object.assign(payload, {
_handleMessage(payload) {
const {
cid,
childProcess
} = this;
/**
* resolve pending commands
*/
if (payload.name === 'finisedCommand') {
this.isBusy = false;
}
/**
* store sessionId and connection data to worker instance
*/
if (payload.name === 'sessionStarted') {
this.sessionId = payload.content.sessionId;
delete payload.content.sessionId;
Object.assign(this.server, payload.content);
}
this.emit('message', Object.assign(payload, {
cid
})));
childProcess.on('exit', code => {
/**
* delete process of worker
*/
delete this.childProcess;
this.isBusy = false;
log.debug(`Runner ${cid} finished with exit code ${code}`);
this.emit('exit', {
cid,
exitCode: code
}));
/**
* handle debug command called within worker process
*/
if (payload.origin === 'debugger' && payload.name === 'start') {
this.repl = new _repl.default(childProcess, _objectSpread({
prompt: `[${cid}] \u203A `
}, payload.params));
this.repl.start().then(() => {
const ev = {
origin: 'debugger',
name: 'stop'
};
childProcess.send(ev);
this.emit('message', ev);
});
}
/**
* handle debugger results
*/
if (this.repl && payload.origin === 'debugger' && payload.name === 'result') {
this.repl.onResult(payload.params);
}
}
_handleError(payload) {
const {
cid
} = this;
this.emit('error', Object.assign(payload, {
cid
}));
}
_handleExit(exitCode) {
const {
cid,
childProcess
} = this;
/**
* delete process of worker
*/
delete this.childProcess;
this.isBusy = false;
log.debug(`Runner ${cid} finished with exit code ${exitCode}`);
this.emit('exit', {
cid,
exitCode
});
childProcess.stdout.pipe(new _transformStream.default(cid)).pipe(process.stdout);
childProcess.stderr.pipe(new _transformStream.default(cid)).pipe(process.stderr);
return childProcess;
childProcess.kill('SIGTERM');
}

@@ -177,2 +237,2 @@ /**

exports.default = WorkerInstance;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/worker.js"],"names":["log","WorkerInstance","EventEmitter","constructor","config","cid","configFile","caps","specs","server","execArgv","isBusy","startProcess","argv","process","slice","runnerEnv","Object","assign","env","WDIO_LOG_LEVEL","logLevel","logDir","WDIO_LOG_PATH","path","join","info","childProcess","child","fork","__dirname","cwd","silent","on","payload","name","sessionId","content","emit","code","debug","exitCode","stdout","pipe","RunnerTransformStream","stderr","postMessage","command","send"],"mappings":"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","sourcesContent":["import path from 'path'\nimport child from 'child_process'\nimport EventEmitter from 'events'\n\nimport logger from '@wdio/logger'\n\nimport RunnerTransformStream from './transformStream'\n\nconst log = logger('wdio-local-runner')\n\n/**\n * WorkerInstance\n * responsible for spawning a sub process to run the framework in and handle its\n * session lifetime.\n */\nexport default class WorkerInstance extends EventEmitter {\n    /**\n     * assigns paramters to scope of instance\n     * @param  {object}   config      parsed configuration object\n     * @param  {string}   cid         capability id (e.g. 0-1)\n     * @param  {string}   configFile  path to config file (for sub process to parse)\n     * @param  {object}   caps        capability object\n     * @param  {string[]} specs       list of paths to test files to run in this worker\n     * @param  {object}   server      configuration details about automation backend this session is using\n     * @param  {object}   execArgv    execution arguments for the test run\n     */\n    constructor (config, { cid, configFile, caps, specs, server, execArgv }) {\n        super()\n        this.cid = cid\n        this.config = config\n        this.configFile = configFile\n        this.caps = caps\n        this.specs = specs\n        this.server = server\n        this.execArgv = execArgv\n        this.isBusy = false\n    }\n\n    /**\n     * spawns process to kick of wdio-runner\n     */\n    startProcess () {\n        const { cid, execArgv } = this\n        const argv = process.argv.slice(2)\n\n        const runnerEnv = Object.assign(process.env, this.config.runnerEnv, {\n            WDIO_LOG_LEVEL: this.config.logLevel\n        })\n\n        if (this.config.logDir) {\n            runnerEnv.WDIO_LOG_PATH = path.join(this.config.logDir, `wdio-${cid}.log`)\n        }\n\n        log.info(`Start worker ${cid} with arg: ${argv}`)\n        const childProcess = child.fork(path.join(__dirname, 'run.js'), argv, {\n            cwd: process.cwd(),\n            env: runnerEnv,\n            execArgv,\n            silent: true\n        })\n\n        childProcess.on('message', (payload) => {\n            /**\n             * resolve pending commands\n             */\n            if (payload.name === 'finisedCommand') {\n                this.isBusy = false\n            }\n\n            /**\n             * store sessionId and connection data to worker instance\n             */\n            if (payload.name === 'sessionStarted') {\n                this.sessionId = payload.content.sessionId\n                delete payload.content.sessionId\n                Object.assign(this.server, payload.content)\n            }\n\n            this.emit('message', Object.assign(payload, { cid }))\n        })\n\n        childProcess.on('error',\n            (payload) => this.emit('error', Object.assign(payload, { cid })))\n\n        childProcess.on('exit', (code) => {\n            /**\n             * delete process of worker\n             */\n            delete this.childProcess\n            this.isBusy = false\n\n            log.debug(`Runner ${cid} finished with exit code ${code}`)\n            this.emit('exit', { cid, exitCode: code })\n        })\n\n        childProcess.stdout.pipe(new RunnerTransformStream(cid)).pipe(process.stdout)\n        childProcess.stderr.pipe(new RunnerTransformStream(cid)).pipe(process.stderr)\n\n        return childProcess\n    }\n\n    /**\n     * sends message to sub process to execute functions in wdio-runner\n     * @param  {string} command  method to run in wdio-runner\n     * @param  {object} argv     arguments for functions to call\n     * @return null\n     */\n    postMessage (command, argv) {\n        const { cid, configFile, caps, specs, server, isBusy } = this\n\n        if (isBusy && command !== 'endSession') {\n            return log.info(`worker with cid ${cid} already busy and can't take new commands`)\n        }\n\n        /**\n         * start up process if worker hasn't done yet or if child process\n         * closes after running its job\n         */\n        if (!this.childProcess) {\n            this.childProcess = this.startProcess()\n        }\n\n        this.childProcess.send({ cid, command, configFile, argv, caps, specs, server })\n        this.isBusy = true\n    }\n}\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/worker.js"],"names":["log","WorkerInstance","EventEmitter","constructor","config","cid","configFile","caps","specs","server","execArgv","isBusy","startProcess","argv","process","slice","runnerEnv","Object","assign","env","WDIO_LOG_LEVEL","logLevel","WDIO_WORKER","logDir","WDIO_LOG_PATH","path","join","info","childProcess","child","fork","__dirname","cwd","silent","on","_handleMessage","_handleError","_handleExit","JEST_WORKER_ID","stdout","pipe","RunnerTransformStream","stderr","stdin","payload","name","sessionId","content","emit","origin","repl","WDIORepl","prompt","params","start","then","ev","send","onResult","exitCode","debug","kill","postMessage","command"],"mappings":"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","sourcesContent":["import path from 'path'\nimport child from 'child_process'\nimport EventEmitter from 'events'\n\nimport logger from '@wdio/logger'\n\nimport RunnerTransformStream from './transformStream'\nimport WDIORepl from './repl'\n\nconst log = logger('wdio-local-runner')\n\n/**\n * WorkerInstance\n * responsible for spawning a sub process to run the framework in and handle its\n * session lifetime.\n */\nexport default class WorkerInstance extends EventEmitter {\n    /**\n     * assigns paramters to scope of instance\n     * @param  {object}   config      parsed configuration object\n     * @param  {string}   cid         capability id (e.g. 0-1)\n     * @param  {string}   configFile  path to config file (for sub process to parse)\n     * @param  {object}   caps        capability object\n     * @param  {string[]} specs       list of paths to test files to run in this worker\n     * @param  {object}   server      configuration details about automation backend this session is using\n     * @param  {object}   execArgv    execution arguments for the test run\n     */\n    constructor (config, { cid, configFile, caps, specs, server, execArgv }) {\n        super()\n        this.cid = cid\n        this.config = config\n        this.configFile = configFile\n        this.caps = caps\n        this.specs = specs\n        this.server = server\n        this.execArgv = execArgv\n        this.isBusy = false\n    }\n\n    /**\n     * spawns process to kick of wdio-runner\n     */\n    startProcess () {\n        const { cid, execArgv } = this\n        const argv = process.argv.slice(2)\n\n        const runnerEnv = Object.assign(process.env, this.config.runnerEnv, {\n            WDIO_LOG_LEVEL: this.config.logLevel,\n            WDIO_WORKER: true\n        })\n\n        if (this.config.logDir) {\n            runnerEnv.WDIO_LOG_PATH = path.join(this.config.logDir, `wdio-${cid}.log`)\n        }\n\n        log.info(`Start worker ${cid} with arg: ${argv}`)\n        const childProcess = this.childProcess = child.fork(path.join(__dirname, 'run.js'), argv, {\n            cwd: process.cwd(),\n            env: runnerEnv,\n            execArgv,\n            silent: true\n        })\n\n        childProcess.on('message', ::this._handleMessage)\n        childProcess.on('error', ::this._handleError)\n        childProcess.on('exit', ::this._handleExit)\n\n        /* istanbul ignore if */\n        if (!process.env.JEST_WORKER_ID) {\n            childProcess.stdout.pipe(new RunnerTransformStream(cid)).pipe(process.stdout)\n            childProcess.stderr.pipe(new RunnerTransformStream(cid)).pipe(process.stderr)\n            process.stdin.pipe(childProcess.stdin)\n        }\n\n        return childProcess\n    }\n\n    _handleMessage (payload) {\n        const { cid, childProcess } = this\n\n        /**\n         * resolve pending commands\n         */\n        if (payload.name === 'finisedCommand') {\n            this.isBusy = false\n        }\n\n        /**\n         * store sessionId and connection data to worker instance\n         */\n        if (payload.name === 'sessionStarted') {\n            this.sessionId = payload.content.sessionId\n            delete payload.content.sessionId\n            Object.assign(this.server, payload.content)\n        }\n\n        this.emit('message', Object.assign(payload, { cid }))\n\n        /**\n         * handle debug command called within worker process\n         */\n        if (payload.origin === 'debugger' && payload.name === 'start') {\n            this.repl = new WDIORepl(\n                childProcess,\n                { prompt: `[${cid}] \\u203A `, ...payload.params }\n            )\n            this.repl.start().then(() => {\n                const ev = {\n                    origin: 'debugger',\n                    name: 'stop'\n                }\n                childProcess.send(ev)\n                this.emit('message', ev)\n            })\n        }\n\n        /**\n         * handle debugger results\n         */\n        if (this.repl && payload.origin === 'debugger' && payload.name === 'result') {\n            this.repl.onResult(payload.params)\n        }\n    }\n\n    _handleError (payload) {\n        const { cid } = this\n        this.emit('error', Object.assign(payload, { cid }))\n    }\n\n    _handleExit (exitCode) {\n        const { cid, childProcess } = this\n\n        /**\n         * delete process of worker\n         */\n        delete this.childProcess\n        this.isBusy = false\n\n        log.debug(`Runner ${cid} finished with exit code ${exitCode}`)\n        this.emit('exit', { cid, exitCode })\n        childProcess.kill('SIGTERM')\n    }\n\n    /**\n     * sends message to sub process to execute functions in wdio-runner\n     * @param  {string} command  method to run in wdio-runner\n     * @param  {object} argv     arguments for functions to call\n     * @return null\n     */\n    postMessage (command, argv) {\n        const { cid, configFile, caps, specs, server, isBusy } = this\n\n        if (isBusy && command !== 'endSession') {\n            return log.info(`worker with cid ${cid} already busy and can't take new commands`)\n        }\n\n        /**\n         * start up process if worker hasn't done yet or if child process\n         * closes after running its job\n         */\n        if (!this.childProcess) {\n            this.childProcess = this.startProcess()\n        }\n\n        this.childProcess.send({ cid, command, configFile, argv, caps, specs, server })\n        this.isBusy = true\n    }\n}\n"]}
{
"name": "@wdio/local-runner",
"version": "5.0.0-beta.10",
"version": "5.0.0-beta.12",
"description": "A WebdriverIO runner to run tests locally",

@@ -34,4 +34,5 @@ "author": "Christian Bromann <christian@saucelabs.com>",

"dependencies": {
"@wdio/logger": "^5.0.0-beta.10",
"@wdio/runner": "^5.0.0-beta.10",
"@wdio/logger": "^5.0.0-beta.12",
"@wdio/repl": "^5.0.0-beta.12",
"@wdio/runner": "^5.0.0-beta.12",
"async-exit-hook": "^2.0.1"

@@ -42,3 +43,3 @@ },

},
"gitHead": "6d5e90a29903eb5097377488de76701f0aa36aa4"
"gitHead": "f690f04cceebb45f695d8fff9d3fa6916654ee87"
}
SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc