@wdio/local-runner
Advanced tools
Comparing version 5.0.0-beta.10 to 5.0.0-beta.12
@@ -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,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" | ||
} |
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
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
New author
Supply chain riskA new npm collaborator published a version of the package for the first time. New collaborators are usually benign additions to a project, but do indicate a change to the security surface area of a package.
Found 1 instance in 1 package
Environment variable access
Supply chain riskPackage accesses environment variables, which may be a sign of credential stuffing or data theft.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
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
57983
9
395
4
2
3
+ Added@wdio/repl@^5.0.0-beta.12
Updated@wdio/logger@^5.0.0-beta.12
Updated@wdio/runner@^5.0.0-beta.12