@appium/support 2.55.2 → 2.56.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (55) hide show
  1. package/build/lib/env.js +102 -0
  2. package/build/lib/fs.js +74 -56
  3. package/build/lib/image-util.js +4 -332
  4. package/build/lib/index.js +18 -6
  5. package/build/lib/log-internal.js +2 -4
  6. package/build/lib/logger.js +2 -4
  7. package/build/lib/logging.js +2 -4
  8. package/build/lib/mjpeg.js +2 -4
  9. package/build/lib/mkdirp.js +7 -11
  10. package/build/lib/net.js +2 -4
  11. package/build/lib/node.js +99 -2
  12. package/build/lib/npm.js +240 -0
  13. package/build/lib/plist.js +2 -4
  14. package/build/lib/process.js +2 -4
  15. package/build/lib/system.js +2 -4
  16. package/build/lib/tempdir.js +2 -4
  17. package/build/lib/timing.js +2 -4
  18. package/build/lib/util.js +6 -8
  19. package/build/lib/zip.js +4 -8
  20. package/lib/env.js +162 -0
  21. package/lib/fs.js +193 -69
  22. package/lib/image-util.js +3 -570
  23. package/lib/index.js +8 -2
  24. package/lib/log-internal.js +2 -2
  25. package/lib/logging.js +1 -1
  26. package/lib/mkdirp.js +3 -6
  27. package/lib/net.js +4 -4
  28. package/lib/node.js +104 -1
  29. package/lib/npm.js +335 -0
  30. package/lib/tempdir.js +6 -6
  31. package/lib/util.js +28 -24
  32. package/lib/zip.js +7 -8
  33. package/package.json +20 -9
  34. package/build/test/assets/sample_binary.plist +0 -0
  35. package/build/test/assets/sample_text.plist +0 -28
  36. package/build/test/fs-specs.js +0 -264
  37. package/build/test/helpers.js +0 -35
  38. package/build/test/image-util-e2e-specs.js +0 -227
  39. package/build/test/index-specs.js +0 -49
  40. package/build/test/log-internals-specs.js +0 -97
  41. package/build/test/logger/helpers.js +0 -71
  42. package/build/test/logger/logger-force-specs.js +0 -41
  43. package/build/test/logger/logger-normal-specs.js +0 -113
  44. package/build/test/logger/logger-test-specs.js +0 -40
  45. package/build/test/mjpeg-e2e-specs.js +0 -96
  46. package/build/test/net-e2e-specs.js +0 -32
  47. package/build/test/node-e2e-specs.js +0 -22
  48. package/build/test/plist-specs.js +0 -54
  49. package/build/test/process-specs.js +0 -104
  50. package/build/test/system-specs.js +0 -136
  51. package/build/test/tempdir-specs.js +0 -86
  52. package/build/test/timing-specs.js +0 -125
  53. package/build/test/util-e2e-specs.js +0 -136
  54. package/build/test/util-specs.js +0 -537
  55. package/build/test/zip-e2e-specs.js +0 -233
@@ -1,113 +0,0 @@
1
- "use strict";
2
-
3
- require("source-map-support/register");
4
-
5
- var _helpers = require("./helpers");
6
-
7
- const LOG_LEVELS = ['silly', 'verbose', 'info', 'http', 'warn', 'error'];
8
- describe('normal logger', function () {
9
- let writers, log;
10
- beforeEach(function () {
11
- writers = (0, _helpers.setupWriters)();
12
- log = (0, _helpers.getDynamicLogger)(false, false);
13
- log.level = 'silly';
14
- });
15
- afterEach(function () {
16
- (0, _helpers.restoreWriters)(writers);
17
- });
18
- it('should not rewrite log levels outside of testing', function () {
19
- for (const levelName of LOG_LEVELS) {
20
- log[levelName](levelName);
21
- (0, _helpers.assertOutputContains)(writers, levelName);
22
- }
23
- });
24
- it('throw should not rewrite log levels outside of testing and throw error', function () {
25
- (() => {
26
- log.errorAndThrow('msg1');
27
- }).should.throw('msg1');
28
- (() => {
29
- log.errorAndThrow(new Error('msg2'));
30
- }).should.throw('msg2');
31
- (0, _helpers.assertOutputContains)(writers, 'msg1');
32
- (0, _helpers.assertOutputContains)(writers, 'msg2');
33
- });
34
- it('should get and set log levels', function () {
35
- log.level = 'warn';
36
- log.level.should.equal('warn');
37
- log.info('information');
38
- log.warn('warning');
39
- (0, _helpers.assertOutputDoesntContain)(writers, 'information');
40
- (0, _helpers.assertOutputContains)(writers, 'warning');
41
- });
42
- it('should split lines of multi-line logs', function () {
43
- log.level = 'warn';
44
- log.warn('this is one line\nand this is another');
45
- (0, _helpers.assertOutputDoesntContain)(writers, 'this is one line\nand this is another');
46
- (0, _helpers.assertOutputContains)(writers, 'this is one line');
47
- (0, _helpers.assertOutputContains)(writers, 'and this is another');
48
- });
49
- it('should split stack trace of Error', function () {
50
- log.level = 'warn';
51
- let error = new Error('this is an error');
52
- error.stack = 'stack line 1\nstack line 2';
53
- log.warn(error);
54
- (0, _helpers.assertOutputDoesntContain)(writers, 'stack line 1\nstack line 2');
55
- (0, _helpers.assertOutputContains)(writers, 'stack line 1');
56
- (0, _helpers.assertOutputContains)(writers, 'stack line 2');
57
- });
58
- });
59
- describe('normal logger with static prefix', function () {
60
- let writers, log;
61
- const PREFIX = 'my_static_prefix';
62
- before(function () {
63
- writers = (0, _helpers.setupWriters)();
64
- log = (0, _helpers.getDynamicLogger)(false, false, PREFIX);
65
- log.level = 'silly';
66
- });
67
- after(function () {
68
- (0, _helpers.restoreWriters)(writers);
69
- });
70
- it('should not rewrite log levels outside of testing', function () {
71
- for (const levelName of LOG_LEVELS) {
72
- log[levelName](levelName);
73
- (0, _helpers.assertOutputContains)(writers, levelName);
74
- (0, _helpers.assertOutputContains)(writers, PREFIX);
75
- }
76
- });
77
- it('throw should not rewrite log levels outside of testing and throw error', function () {
78
- (() => {
79
- log.errorAndThrow('msg');
80
- }).should.throw('msg');
81
- (0, _helpers.assertOutputContains)(writers, 'error');
82
- (0, _helpers.assertOutputContains)(writers, PREFIX);
83
- });
84
- });
85
- describe('normal logger with dynamic prefix', function () {
86
- let writers, log;
87
- const PREFIX = 'my_dynamic_prefix';
88
- before(function () {
89
- writers = (0, _helpers.setupWriters)();
90
- log = (0, _helpers.getDynamicLogger)(false, false, () => PREFIX);
91
- log.level = 'silly';
92
- });
93
- after(function () {
94
- (0, _helpers.restoreWriters)(writers);
95
- });
96
- it('should not rewrite log levels outside of testing', function () {
97
- for (const levelName of LOG_LEVELS) {
98
- log[levelName](levelName);
99
- (0, _helpers.assertOutputContains)(writers, levelName);
100
- (0, _helpers.assertOutputContains)(writers, PREFIX);
101
- }
102
- });
103
- it('throw should not rewrite log levels outside of testing and throw error', function () {
104
- (() => {
105
- log.errorAndThrow('msg');
106
- }).should.throw('msg');
107
- (0, _helpers.assertOutputContains)(writers, 'error');
108
- (0, _helpers.assertOutputContains)(writers, PREFIX);
109
- });
110
- });require('source-map-support').install();
111
-
112
-
113
- //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["test/logger/logger-normal-specs.js"],"names":["LOG_LEVELS","describe","writers","log","beforeEach","level","afterEach","it","levelName","errorAndThrow","should","throw","Error","equal","info","warn","error","stack","PREFIX","before","after"],"mappings":"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","sourcesContent":["// transpile:mocha\n\nimport { getDynamicLogger, restoreWriters, setupWriters,\n         assertOutputContains, assertOutputDoesntContain } from './helpers';\n\nconst LOG_LEVELS = ['silly', 'verbose', 'info', 'http', 'warn', 'error'];\n\ndescribe('normal logger', function () {\n  let writers, log;\n  beforeEach(function () {\n    writers = setupWriters();\n    log = getDynamicLogger(false, false);\n    log.level = 'silly';\n  });\n\n  afterEach(function () {\n    restoreWriters(writers);\n  });\n\n  it('should not rewrite log levels outside of testing', function () {\n    for (const levelName of LOG_LEVELS) {\n      log[levelName](levelName);\n      assertOutputContains(writers, levelName);\n    }\n  });\n  it('throw should not rewrite log levels outside of testing and throw error', function () {\n    (() => { log.errorAndThrow('msg1'); }).should.throw('msg1');\n    (() => { log.errorAndThrow(new Error('msg2')); }).should.throw('msg2');\n    assertOutputContains(writers, 'msg1');\n    assertOutputContains(writers, 'msg2');\n  });\n  it('should get and set log levels', function () {\n    log.level = 'warn';\n    log.level.should.equal('warn');\n    log.info('information');\n    log.warn('warning');\n    assertOutputDoesntContain(writers, 'information');\n    assertOutputContains(writers, 'warning');\n  });\n  it('should split lines of multi-line logs', function () {\n    log.level = 'warn';\n    log.warn('this is one line\\nand this is another');\n    assertOutputDoesntContain(writers, 'this is one line\\nand this is another');\n    assertOutputContains(writers, 'this is one line');\n    assertOutputContains(writers, 'and this is another');\n  });\n  it('should split stack trace of Error', function () {\n    log.level = 'warn';\n    let error = new Error('this is an error');\n    error.stack = 'stack line 1\\nstack line 2';\n    log.warn(error);\n    assertOutputDoesntContain(writers, 'stack line 1\\nstack line 2');\n    assertOutputContains(writers, 'stack line 1');\n    assertOutputContains(writers, 'stack line 2');\n  });\n});\n\ndescribe('normal logger with static prefix', function () {\n  let writers, log;\n  const PREFIX = 'my_static_prefix';\n\n  before(function () {\n    writers = setupWriters();\n    log = getDynamicLogger(false, false, PREFIX);\n    log.level = 'silly';\n  });\n\n  after(function () {\n    restoreWriters(writers);\n  });\n\n  it('should not rewrite log levels outside of testing', function () {\n    for (const levelName of LOG_LEVELS) {\n      log[levelName](levelName);\n      assertOutputContains(writers, levelName);\n      assertOutputContains(writers, PREFIX);\n    }\n  });\n  it('throw should not rewrite log levels outside of testing and throw error', function () {\n    (() => { log.errorAndThrow('msg'); }).should.throw('msg');\n    assertOutputContains(writers, 'error');\n    assertOutputContains(writers, PREFIX);\n  });\n});\n\ndescribe('normal logger with dynamic prefix', function () {\n  let writers, log;\n  const PREFIX = 'my_dynamic_prefix';\n\n  before(function () {\n    writers = setupWriters();\n    log = getDynamicLogger(false, false, () => PREFIX);\n    log.level = 'silly';\n  });\n\n  after(function () {\n    restoreWriters(writers);\n  });\n\n  it('should not rewrite log levels outside of testing', function () {\n    for (const levelName of LOG_LEVELS) {\n      log[levelName](levelName);\n      assertOutputContains(writers, levelName);\n      assertOutputContains(writers, PREFIX);\n    }\n  });\n  it('throw should not rewrite log levels outside of testing and throw error', function () {\n    (() => { log.errorAndThrow('msg'); }).should.throw('msg');\n    assertOutputContains(writers, 'error');\n    assertOutputContains(writers, PREFIX);\n  });\n});\n"],"file":"test/logger/logger-normal-specs.js","sourceRoot":"../../.."}
@@ -1,40 +0,0 @@
1
- "use strict";
2
-
3
- require("source-map-support/register");
4
-
5
- var _helpers = require("./helpers");
6
-
7
- describe('test logger', function () {
8
- let writers, log;
9
- before(function () {
10
- writers = (0, _helpers.setupWriters)();
11
- log = (0, _helpers.getDynamicLogger)(true);
12
- });
13
- after(function () {
14
- (0, _helpers.restoreWriters)(writers);
15
- });
16
- it('should contains levels', function () {
17
- log.levels.should.have.length.above(3);
18
- log.levels[2].should.equal('debug');
19
- });
20
- it('should unwrap', function () {
21
- log.unwrap.should.exist;
22
- log.unwrap().should.exist;
23
- });
24
- it('should rewrite npmlog levels during testing', function () {
25
- const text = 'hi';
26
- log.silly(text);
27
- log.verbose(text);
28
- log.info(text);
29
- log.http(text);
30
- log.warn(text);
31
- log.error(text);
32
- (() => {
33
- log.errorAndThrow(text);
34
- }).should.throw(text);
35
- (0, _helpers.assertOutputDoesntContain)(writers, text);
36
- });
37
- });require('source-map-support').install();
38
-
39
-
40
- //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRlc3QvbG9nZ2VyL2xvZ2dlci10ZXN0LXNwZWNzLmpzIl0sIm5hbWVzIjpbImRlc2NyaWJlIiwid3JpdGVycyIsImxvZyIsImJlZm9yZSIsImFmdGVyIiwiaXQiLCJsZXZlbHMiLCJzaG91bGQiLCJoYXZlIiwibGVuZ3RoIiwiYWJvdmUiLCJlcXVhbCIsInVud3JhcCIsImV4aXN0IiwidGV4dCIsInNpbGx5IiwidmVyYm9zZSIsImluZm8iLCJodHRwIiwid2FybiIsImVycm9yIiwiZXJyb3JBbmRUaHJvdyIsInRocm93Il0sIm1hcHBpbmdzIjoiOzs7O0FBRUE7O0FBR0FBLFFBQVEsQ0FBQyxhQUFELEVBQWdCLFlBQVk7QUFDbEMsTUFBSUMsT0FBSixFQUFhQyxHQUFiO0FBQ0FDLEVBQUFBLE1BQU0sQ0FBQyxZQUFZO0FBQ2pCRixJQUFBQSxPQUFPLEdBQUcsNEJBQVY7QUFDQUMsSUFBQUEsR0FBRyxHQUFHLCtCQUFpQixJQUFqQixDQUFOO0FBQ0QsR0FISyxDQUFOO0FBS0FFLEVBQUFBLEtBQUssQ0FBQyxZQUFZO0FBQ2hCLGlDQUFlSCxPQUFmO0FBQ0QsR0FGSSxDQUFMO0FBSUFJLEVBQUFBLEVBQUUsQ0FBQyx3QkFBRCxFQUEyQixZQUFZO0FBQ3ZDSCxJQUFBQSxHQUFHLENBQUNJLE1BQUosQ0FBV0MsTUFBWCxDQUFrQkMsSUFBbEIsQ0FBdUJDLE1BQXZCLENBQThCQyxLQUE5QixDQUFvQyxDQUFwQztBQUNBUixJQUFBQSxHQUFHLENBQUNJLE1BQUosQ0FBVyxDQUFYLEVBQWNDLE1BQWQsQ0FBcUJJLEtBQXJCLENBQTJCLE9BQTNCO0FBQ0QsR0FIQyxDQUFGO0FBS0FOLEVBQUFBLEVBQUUsQ0FBQyxlQUFELEVBQWtCLFlBQVk7QUFDOUJILElBQUFBLEdBQUcsQ0FBQ1UsTUFBSixDQUFXTCxNQUFYLENBQWtCTSxLQUFsQjtBQUNBWCxJQUFBQSxHQUFHLENBQUNVLE1BQUosR0FBYUwsTUFBYixDQUFvQk0sS0FBcEI7QUFDRCxHQUhDLENBQUY7QUFLQVIsRUFBQUEsRUFBRSxDQUFDLDZDQUFELEVBQWdELFlBQVk7QUFDNUQsVUFBTVMsSUFBSSxHQUFHLElBQWI7QUFDQVosSUFBQUEsR0FBRyxDQUFDYSxLQUFKLENBQVVELElBQVY7QUFDQVosSUFBQUEsR0FBRyxDQUFDYyxPQUFKLENBQVlGLElBQVo7QUFDQVosSUFBQUEsR0FBRyxDQUFDZSxJQUFKLENBQVNILElBQVQ7QUFDQVosSUFBQUEsR0FBRyxDQUFDZ0IsSUFBSixDQUFTSixJQUFUO0FBQ0FaLElBQUFBLEdBQUcsQ0FBQ2lCLElBQUosQ0FBU0wsSUFBVDtBQUNBWixJQUFBQSxHQUFHLENBQUNrQixLQUFKLENBQVVOLElBQVY7QUFDQSxLQUFDLE1BQU07QUFBRVosTUFBQUEsR0FBRyxDQUFDbUIsYUFBSixDQUFrQlAsSUFBbEI7QUFBMEIsS0FBbkMsRUFBcUNQLE1BQXJDLENBQTRDZSxLQUE1QyxDQUFrRFIsSUFBbEQ7QUFDQSw0Q0FBMEJiLE9BQTFCLEVBQW1DYSxJQUFuQztBQUNELEdBVkMsQ0FBRjtBQVdELENBaENPLENBQVIiLCJzb3VyY2VzQ29udGVudCI6WyIvLyB0cmFuc3BpbGU6bW9jaGFcblxuaW1wb3J0IHsgZ2V0RHluYW1pY0xvZ2dlciwgcmVzdG9yZVdyaXRlcnMsIHNldHVwV3JpdGVycyxcbiAgICAgICAgIGFzc2VydE91dHB1dERvZXNudENvbnRhaW4gfSBmcm9tICcuL2hlbHBlcnMnO1xuXG5kZXNjcmliZSgndGVzdCBsb2dnZXInLCBmdW5jdGlvbiAoKSB7XG4gIGxldCB3cml0ZXJzLCBsb2c7XG4gIGJlZm9yZShmdW5jdGlvbiAoKSB7XG4gICAgd3JpdGVycyA9IHNldHVwV3JpdGVycygpO1xuICAgIGxvZyA9IGdldER5bmFtaWNMb2dnZXIodHJ1ZSk7XG4gIH0pO1xuXG4gIGFmdGVyKGZ1bmN0aW9uICgpIHtcbiAgICByZXN0b3JlV3JpdGVycyh3cml0ZXJzKTtcbiAgfSk7XG5cbiAgaXQoJ3Nob3VsZCBjb250YWlucyBsZXZlbHMnLCBmdW5jdGlvbiAoKSB7XG4gICAgbG9nLmxldmVscy5zaG91bGQuaGF2ZS5sZW5ndGguYWJvdmUoMyk7XG4gICAgbG9nLmxldmVsc1syXS5zaG91bGQuZXF1YWwoJ2RlYnVnJyk7XG4gIH0pO1xuXG4gIGl0KCdzaG91bGQgdW53cmFwJywgZnVuY3Rpb24gKCkge1xuICAgIGxvZy51bndyYXAuc2hvdWxkLmV4aXN0O1xuICAgIGxvZy51bndyYXAoKS5zaG91bGQuZXhpc3Q7XG4gIH0pO1xuXG4gIGl0KCdzaG91bGQgcmV3cml0ZSBucG1sb2cgbGV2ZWxzIGR1cmluZyB0ZXN0aW5nJywgZnVuY3Rpb24gKCkge1xuICAgIGNvbnN0IHRleHQgPSAnaGknO1xuICAgIGxvZy5zaWxseSh0ZXh0KTtcbiAgICBsb2cudmVyYm9zZSh0ZXh0KTtcbiAgICBsb2cuaW5mbyh0ZXh0KTtcbiAgICBsb2cuaHR0cCh0ZXh0KTtcbiAgICBsb2cud2Fybih0ZXh0KTtcbiAgICBsb2cuZXJyb3IodGV4dCk7XG4gICAgKCgpID0+IHsgbG9nLmVycm9yQW5kVGhyb3codGV4dCk7IH0pLnNob3VsZC50aHJvdyh0ZXh0KTtcbiAgICBhc3NlcnRPdXRwdXREb2VzbnRDb250YWluKHdyaXRlcnMsIHRleHQpO1xuICB9KTtcbn0pO1xuIl0sImZpbGUiOiJ0ZXN0L2xvZ2dlci9sb2dnZXItdGVzdC1zcGVjcy5qcyIsInNvdXJjZVJvb3QiOiIuLi8uLi8uLiJ9
@@ -1,96 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- require("source-map-support/register");
6
-
7
- var _lodash = _interopRequireDefault(require("lodash"));
8
-
9
- var _lib = require("../lib");
10
-
11
- var _bluebird = _interopRequireDefault(require("bluebird"));
12
-
13
- var _http = _interopRequireDefault(require("http"));
14
-
15
- var _mjpegServer = _interopRequireDefault(require("mjpeg-server"));
16
-
17
- var _getPort = _interopRequireDefault(require("get-port"));
18
-
19
- const {
20
- MJpegStream
21
- } = _lib.mjpeg;
22
- const TEST_IMG_JPG = '/9j/4QAYRXhpZgAASUkqAAgAAAAAAAAAAAAAAP/sABFEdWNreQABAAQAAAAeAAD/4QOBaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wLwA8P3hwYWNrZXQgYmVnaW49Iu+7vyIgaWQ9Ilc1TTBNcENlaGlIenJlU3pOVGN6a2M5ZCI/PiA8eDp4bXBtZXRhIHhtbG5zOng9ImFkb2JlOm5zOm1ldGEvIiB4OnhtcHRrPSJBZG9iZSBYTVAgQ29yZSA1LjYtYzE0MCA3OS4xNjA0NTEsIDIwMTcvMDUvMDYtMDE6MDg6MjEgICAgICAgICI+IDxyZGY6UkRGIHhtbG5zOnJkZj0iaHR0cDovL3d3dy53My5vcmcvMTk5OS8wMi8yMi1yZGYtc3ludGF4LW5zIyI+IDxyZGY6RGVzY3JpcHRpb24gcmRmOmFib3V0PSIiIHhtbG5zOnhtcE1NPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvbW0vIiB4bWxuczpzdFJlZj0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL3NUeXBlL1Jlc291cmNlUmVmIyIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIiB4bXBNTTpPcmlnaW5hbERvY3VtZW50SUQ9InhtcC5kaWQ6NGY5ODc1OTctZGE2My00Y2M0LTkzNDMtNGYyNjgzMGUwNjk3IiB4bXBNTTpEb2N1bWVudElEPSJ4bXAuZGlkOjlDMzI3QkY0N0Q3NTExRThCMTlDOTVDMDc2RDE5MDY5IiB4bXBNTTpJbnN0YW5jZUlEPSJ4bXAuaWlkOjlDMzI3QkYzN0Q3NTExRThCMTlDOTVDMDc2RDE5MDY5IiB4bXA6Q3JlYXRvclRvb2w9IkFkb2JlIFBob3Rvc2hvcCBDQyAyMDE4IChNYWNpbnRvc2gpIj4gPHhtcE1NOkRlcml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6NGY5ODc1OTctZGE2My00Y2M0LTkzNDMtNGYyNjgzMGUwNjk3IiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOjRmOTg3NTk3LWRhNjMtNGNjNC05MzQzLTRmMjY4MzBlMDY5NyIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/Pv/uAA5BZG9iZQBkwAAAAAH/2wCEABALCwsMCxAMDBAXDw0PFxsUEBAUGx8XFxcXFx8eFxoaGhoXHh4jJSclIx4vLzMzLy9AQEBAQEBAQEBAQEBAQEABEQ8PERMRFRISFRQRFBEUGhQWFhQaJhoaHBoaJjAjHh4eHiMwKy4nJycuKzU1MDA1NUBAP0BAQEBAQEBAQEBAQP/AABEIACAAIAMBIgACEQEDEQH/xABgAAEAAwEAAAAAAAAAAAAAAAAABAUHCAEBAAAAAAAAAAAAAAAAAAAAABAAAQMCAgsAAAAAAAAAAAAAAAECBBEDEgYhMRODo7PTVAUWNhEBAAAAAAAAAAAAAAAAAAAAAP/aAAwDAQACEQMRAD8Az8AAdAAAAAAI8+fE8dEuTZtzZR7VMb6OdTE5GJoYirrUp/e8qd9wb3TGe/lJ2551sx8D/9k=';
23
- const MJPEG_HOST = '127.0.0.1';
24
-
25
- function initMJpegServer(port, intMs = 300, times = 20) {
26
- const server = _http.default.createServer(async function (req, res) {
27
- const mJpegReqHandler = _mjpegServer.default.createReqHandler(req, res);
28
-
29
- const jpg = Buffer.from(TEST_IMG_JPG, 'base64');
30
-
31
- for (let i = 0; i < times; i++) {
32
- await _bluebird.default.delay(intMs);
33
-
34
- mJpegReqHandler._write(jpg, null, _lodash.default.noop);
35
- }
36
-
37
- mJpegReqHandler.close();
38
- }).listen(port);
39
-
40
- return server;
41
- }
42
-
43
- describe('MJpeg Stream (e2e)', function () {
44
- let mJpegServer, stream;
45
- let serverUrl, port;
46
- before(async function () {
47
- if (process.version.startsWith('v12')) {
48
- return this.skip();
49
- }
50
-
51
- port = await (0, _getPort.default)();
52
- serverUrl = `http://${MJPEG_HOST}:${port}`;
53
- mJpegServer = await initMJpegServer(port);
54
- });
55
- after(function () {
56
- if (mJpegServer) {
57
- mJpegServer.close();
58
- }
59
-
60
- if (stream) {
61
- stream.stop();
62
- }
63
- });
64
- it('should update mjpeg stream based on new data from mjpeg server', async function () {
65
- stream = new MJpegStream(serverUrl, _lodash.default.noop);
66
- should.not.exist(stream.lastChunk);
67
- await stream.start();
68
- should.exist(stream.lastChunk);
69
- stream.updateCount.should.eql(1);
70
- await _bluebird.default.delay(1000);
71
- stream.updateCount.should.be.above(1);
72
- const startBytes = Buffer.from([0xff, 0xd8]);
73
- const endBytes = Buffer.from([0xff, 0xd9]);
74
- const startPos = stream.lastChunk.indexOf(startBytes);
75
- const endPos = stream.lastChunk.indexOf(endBytes);
76
- startPos.should.eql(0);
77
- endPos.should.eql(1278);
78
- const b64 = stream.lastChunkBase64;
79
- b64.should.eql(TEST_IMG_JPG);
80
- const png = await stream.lastChunkPNGBase64();
81
- png.should.be.a('string');
82
- png.indexOf('iVBOR').should.eql(0);
83
- png.length.should.be.above(400);
84
- stream.stop();
85
- await _bluebird.default.delay(1000);
86
- should.not.exist(stream.lastChunk);
87
- stream.updateCount.should.eql(0);
88
- });
89
- it('should error out if the server does not send any images before a timeout', async function () {
90
- stream = new MJpegStream(serverUrl, _lodash.default.noop);
91
- await stream.start(0).should.eventually.be.rejectedWith(/never sent/);
92
- });
93
- });require('source-map-support').install();
94
-
95
-
96
- //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["test/mjpeg-e2e-specs.js"],"names":["MJpegStream","mjpeg","TEST_IMG_JPG","MJPEG_HOST","initMJpegServer","port","intMs","times","server","http","createServer","req","res","mJpegReqHandler","mJpegServer","createReqHandler","jpg","Buffer","from","i","B","delay","_write","_","noop","close","listen","describe","stream","serverUrl","before","process","version","startsWith","skip","after","stop","it","should","not","exist","lastChunk","start","updateCount","eql","be","above","startBytes","endBytes","startPos","indexOf","endPos","b64","lastChunkBase64","png","lastChunkPNGBase64","a","length","eventually","rejectedWith"],"mappings":";;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAEA,MAAM;AAACA,EAAAA;AAAD,IAAgBC,UAAtB;AAEA,MAAMC,YAAY,GAAG,8qDAArB;AAEA,MAAMC,UAAU,GAAG,WAAnB;;AAWA,SAASC,eAAT,CAA0BC,IAA1B,EAAgCC,KAAK,GAAG,GAAxC,EAA6CC,KAAK,GAAG,EAArD,EAAyD;AACvD,QAAMC,MAAM,GAAGC,cAAKC,YAAL,CAAkB,gBAAgBC,GAAhB,EAAqBC,GAArB,EAA0B;AACzD,UAAMC,eAAe,GAAGC,qBAAYC,gBAAZ,CAA6BJ,GAA7B,EAAkCC,GAAlC,CAAxB;;AACA,UAAMI,GAAG,GAAGC,MAAM,CAACC,IAAP,CAAYhB,YAAZ,EAA0B,QAA1B,CAAZ;;AAGA,SAAK,IAAIiB,CAAC,GAAG,CAAb,EAAgBA,CAAC,GAAGZ,KAApB,EAA2BY,CAAC,EAA5B,EAAgC;AAC9B,YAAMC,kBAAEC,KAAF,CAAQf,KAAR,CAAN;;AACAO,MAAAA,eAAe,CAACS,MAAhB,CAAuBN,GAAvB,EAA4B,IAA5B,EAAkCO,gBAAEC,IAApC;AACD;;AACDX,IAAAA,eAAe,CAACY,KAAhB;AACD,GAVc,EAUZC,MAVY,CAULrB,IAVK,CAAf;;AAYA,SAAOG,MAAP;AACD;;AAGDmB,QAAQ,CAAC,oBAAD,EAAuB,YAAY;AACzC,MAAIb,WAAJ,EAAiBc,MAAjB;AACA,MAAIC,SAAJ,EAAexB,IAAf;AAEAyB,EAAAA,MAAM,CAAC,kBAAkB;AAEvB,QAAIC,OAAO,CAACC,OAAR,CAAgBC,UAAhB,CAA2B,KAA3B,CAAJ,EAAuC;AACrC,aAAO,KAAKC,IAAL,EAAP;AACD;;AAED7B,IAAAA,IAAI,GAAG,MAAM,uBAAb;AACAwB,IAAAA,SAAS,GAAI,UAAS1B,UAAW,IAAGE,IAAK,EAAzC;AACAS,IAAAA,WAAW,GAAG,MAAMV,eAAe,CAACC,IAAD,CAAnC;AACD,GATK,CAAN;AAWA8B,EAAAA,KAAK,CAAC,YAAY;AAChB,QAAIrB,WAAJ,EAAiB;AACfA,MAAAA,WAAW,CAACW,KAAZ;AACD;;AACD,QAAIG,MAAJ,EAAY;AACVA,MAAAA,MAAM,CAACQ,IAAP;AACD;AACF,GAPI,CAAL;AASAC,EAAAA,EAAE,CAAC,gEAAD,EAAmE,kBAAkB;AACrFT,IAAAA,MAAM,GAAG,IAAI5B,WAAJ,CAAgB6B,SAAhB,EAA2BN,gBAAEC,IAA7B,CAAT;AACAc,IAAAA,MAAM,CAACC,GAAP,CAAWC,KAAX,CAAiBZ,MAAM,CAACa,SAAxB;AACA,UAAMb,MAAM,CAACc,KAAP,EAAN;AACAJ,IAAAA,MAAM,CAACE,KAAP,CAAaZ,MAAM,CAACa,SAApB;AACAb,IAAAA,MAAM,CAACe,WAAP,CAAmBL,MAAnB,CAA0BM,GAA1B,CAA8B,CAA9B;AAEA,UAAMxB,kBAAEC,KAAF,CAAQ,IAAR,CAAN;AACAO,IAAAA,MAAM,CAACe,WAAP,CAAmBL,MAAnB,CAA0BO,EAA1B,CAA6BC,KAA7B,CAAmC,CAAnC;AAGA,UAAMC,UAAU,GAAG9B,MAAM,CAACC,IAAP,CAAY,CAAC,IAAD,EAAO,IAAP,CAAZ,CAAnB;AACA,UAAM8B,QAAQ,GAAG/B,MAAM,CAACC,IAAP,CAAY,CAAC,IAAD,EAAO,IAAP,CAAZ,CAAjB;AACA,UAAM+B,QAAQ,GAAGrB,MAAM,CAACa,SAAP,CAAiBS,OAAjB,CAAyBH,UAAzB,CAAjB;AACA,UAAMI,MAAM,GAAGvB,MAAM,CAACa,SAAP,CAAiBS,OAAjB,CAAyBF,QAAzB,CAAf;AACAC,IAAAA,QAAQ,CAACX,MAAT,CAAgBM,GAAhB,CAAoB,CAApB;AACAO,IAAAA,MAAM,CAACb,MAAP,CAAcM,GAAd,CAAkB,IAAlB;AAGA,UAAMQ,GAAG,GAAGxB,MAAM,CAACyB,eAAnB;AACAD,IAAAA,GAAG,CAACd,MAAJ,CAAWM,GAAX,CAAe1C,YAAf;AAGA,UAAMoD,GAAG,GAAG,MAAM1B,MAAM,CAAC2B,kBAAP,EAAlB;AACAD,IAAAA,GAAG,CAAChB,MAAJ,CAAWO,EAAX,CAAcW,CAAd,CAAgB,QAAhB;AACAF,IAAAA,GAAG,CAACJ,OAAJ,CAAY,OAAZ,EAAqBZ,MAArB,CAA4BM,GAA5B,CAAgC,CAAhC;AACAU,IAAAA,GAAG,CAACG,MAAJ,CAAWnB,MAAX,CAAkBO,EAAlB,CAAqBC,KAArB,CAA2B,GAA3B;AAIAlB,IAAAA,MAAM,CAACQ,IAAP;AACA,UAAMhB,kBAAEC,KAAF,CAAQ,IAAR,CAAN;AACAiB,IAAAA,MAAM,CAACC,GAAP,CAAWC,KAAX,CAAiBZ,MAAM,CAACa,SAAxB;AACAb,IAAAA,MAAM,CAACe,WAAP,CAAmBL,MAAnB,CAA0BM,GAA1B,CAA8B,CAA9B;AACD,GAlCC,CAAF;AAoCAP,EAAAA,EAAE,CAAC,0EAAD,EAA6E,kBAAkB;AAC/FT,IAAAA,MAAM,GAAG,IAAI5B,WAAJ,CAAgB6B,SAAhB,EAA2BN,gBAAEC,IAA7B,CAAT;AACA,UAAMI,MAAM,CAACc,KAAP,CAAa,CAAb,EAAgBJ,MAAhB,CAAuBoB,UAAvB,CAAkCb,EAAlC,CAAqCc,YAArC,CAAkD,YAAlD,CAAN;AACD,GAHC,CAAF;AAKD,CAjEO,CAAR","sourcesContent":["import _ from 'lodash';\nimport { mjpeg } from '../lib';\nimport B from 'bluebird';\nimport http from 'http';\nimport mJpegServer from 'mjpeg-server';\nimport getPort from 'get-port';\n\nconst {MJpegStream} = mjpeg;\n\nconst TEST_IMG_JPG = '/9j/4QAYRXhpZgAASUkqAAgAAAAAAAAAAAAAAP/sABFEdWNreQABAAQAAAAeAAD/4QOBaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wLwA8P3hwYWNrZXQgYmVnaW49Iu+7vyIgaWQ9Ilc1TTBNcENlaGlIenJlU3pOVGN6a2M5ZCI/PiA8eDp4bXBtZXRhIHhtbG5zOng9ImFkb2JlOm5zOm1ldGEvIiB4OnhtcHRrPSJBZG9iZSBYTVAgQ29yZSA1LjYtYzE0MCA3OS4xNjA0NTEsIDIwMTcvMDUvMDYtMDE6MDg6MjEgICAgICAgICI+IDxyZGY6UkRGIHhtbG5zOnJkZj0iaHR0cDovL3d3dy53My5vcmcvMTk5OS8wMi8yMi1yZGYtc3ludGF4LW5zIyI+IDxyZGY6RGVzY3JpcHRpb24gcmRmOmFib3V0PSIiIHhtbG5zOnhtcE1NPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvbW0vIiB4bWxuczpzdFJlZj0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL3NUeXBlL1Jlc291cmNlUmVmIyIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIiB4bXBNTTpPcmlnaW5hbERvY3VtZW50SUQ9InhtcC5kaWQ6NGY5ODc1OTctZGE2My00Y2M0LTkzNDMtNGYyNjgzMGUwNjk3IiB4bXBNTTpEb2N1bWVudElEPSJ4bXAuZGlkOjlDMzI3QkY0N0Q3NTExRThCMTlDOTVDMDc2RDE5MDY5IiB4bXBNTTpJbnN0YW5jZUlEPSJ4bXAuaWlkOjlDMzI3QkYzN0Q3NTExRThCMTlDOTVDMDc2RDE5MDY5IiB4bXA6Q3JlYXRvclRvb2w9IkFkb2JlIFBob3Rvc2hvcCBDQyAyMDE4IChNYWNpbnRvc2gpIj4gPHhtcE1NOkRlcml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InhtcC5paWQ6NGY5ODc1OTctZGE2My00Y2M0LTkzNDMtNGYyNjgzMGUwNjk3IiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOjRmOTg3NTk3LWRhNjMtNGNjNC05MzQzLTRmMjY4MzBlMDY5NyIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/Pv/uAA5BZG9iZQBkwAAAAAH/2wCEABALCwsMCxAMDBAXDw0PFxsUEBAUGx8XFxcXFx8eFxoaGhoXHh4jJSclIx4vLzMzLy9AQEBAQEBAQEBAQEBAQEABEQ8PERMRFRISFRQRFBEUGhQWFhQaJhoaHBoaJjAjHh4eHiMwKy4nJycuKzU1MDA1NUBAP0BAQEBAQEBAQEBAQP/AABEIACAAIAMBIgACEQEDEQH/xABgAAEAAwEAAAAAAAAAAAAAAAAABAUHCAEBAAAAAAAAAAAAAAAAAAAAABAAAQMCAgsAAAAAAAAAAAAAAAECBBEDEgYhMRODo7PTVAUWNhEBAAAAAAAAAAAAAAAAAAAAAP/aAAwDAQACEQMRAD8Az8AAdAAAAAAI8+fE8dEuTZtzZR7VMb6OdTE5GJoYirrUp/e8qd9wb3TGe/lJ2551sx8D/9k=';\n\nconst MJPEG_HOST = '127.0.0.1';\n\n/**\n * Start an mjpeg server for the purpose of testing, which just sends the same\n * image over and over. Caller is responsible for closing the server.\n * @param {int} port - port the server should listen on\n * @param {int} [intMs] - how often the server should push an image\n * @param {int} [times] - how many times the server should push an image before\n * it closes the connection\n * @returns {http.Server}\n */\nfunction initMJpegServer (port, intMs = 300, times = 20) {\n  const server = http.createServer(async function (req, res) {\n    const mJpegReqHandler = mJpegServer.createReqHandler(req, res);\n    const jpg = Buffer.from(TEST_IMG_JPG, 'base64');\n\n    // just send the same jpeg over and over\n    for (let i = 0; i < times; i++) {\n      await B.delay(intMs);\n      mJpegReqHandler._write(jpg, null, _.noop);\n    }\n    mJpegReqHandler.close();\n  }).listen(port);\n\n  return server;\n}\n\n\ndescribe('MJpeg Stream (e2e)', function () {\n  let mJpegServer, stream;\n  let serverUrl, port;\n\n  before(async function () {\n    // TODO: remove when buffertools can handle v12\n    if (process.version.startsWith('v12')) {\n      return this.skip();\n    }\n\n    port = await getPort();\n    serverUrl = `http://${MJPEG_HOST}:${port}`;\n    mJpegServer = await initMJpegServer(port);\n  });\n\n  after(function () {\n    if (mJpegServer) {\n      mJpegServer.close();\n    }\n    if (stream) {\n      stream.stop(); // ensure streams are always stopped\n    }\n  });\n\n  it('should update mjpeg stream based on new data from mjpeg server', async function () {\n    stream = new MJpegStream(serverUrl, _.noop);\n    should.not.exist(stream.lastChunk);\n    await stream.start();\n    should.exist(stream.lastChunk);\n    stream.updateCount.should.eql(1);\n\n    await B.delay(1000); // let the stream update a bit\n    stream.updateCount.should.be.above(1);\n\n    // verify jpeg type and byte length of fixture image\n    const startBytes = Buffer.from([0xff, 0xd8]);\n    const endBytes = Buffer.from([0xff, 0xd9]);\n    const startPos = stream.lastChunk.indexOf(startBytes);\n    const endPos = stream.lastChunk.indexOf(endBytes);\n    startPos.should.eql(0); // proves we have a jpeg\n    endPos.should.eql(1278); // proves we have a jpeg of the right size\n\n    // verify we can get the base64 version too\n    const b64 = stream.lastChunkBase64;\n    b64.should.eql(TEST_IMG_JPG);\n\n    // verify we can get the PNG version too\n    const png = await stream.lastChunkPNGBase64();\n    png.should.be.a('string');\n    png.indexOf('iVBOR').should.eql(0);\n    png.length.should.be.above(400);\n\n\n    // now stop the stream and wait some more then assert no new data has come in\n    stream.stop();\n    await B.delay(1000);\n    should.not.exist(stream.lastChunk);\n    stream.updateCount.should.eql(0);\n  });\n\n  it('should error out if the server does not send any images before a timeout', async function () {\n    stream = new MJpegStream(serverUrl, _.noop);\n    await stream.start(0).should.eventually.be.rejectedWith(/never sent/);\n  });\n\n});\n"],"file":"test/mjpeg-e2e-specs.js","sourceRoot":"../.."}
@@ -1,32 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- require("source-map-support/register");
6
-
7
- var _path = _interopRequireDefault(require("path"));
8
-
9
- var _net = require("../lib/net");
10
-
11
- var _index = require("../lib/index");
12
-
13
- describe('#net', function () {
14
- let tmpRoot;
15
- beforeEach(async function () {
16
- tmpRoot = await _index.tempDir.openDir();
17
- });
18
- afterEach(async function () {
19
- await _index.fs.rimraf(tmpRoot);
20
- });
21
- describe('downloadFile()', function () {
22
- it('should download file into the target folder', async function () {
23
- const dstPath = _path.default.join(tmpRoot, 'download.tmp');
24
-
25
- await (0, _net.downloadFile)('https://appium.io/ico/apple-touch-icon-114x114-precomposed.png', dstPath);
26
- await _index.fs.exists(dstPath).should.eventually.be.true;
27
- });
28
- });
29
- });require('source-map-support').install();
30
-
31
-
32
- //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRlc3QvbmV0LWUyZS1zcGVjcy5qcyJdLCJuYW1lcyI6WyJkZXNjcmliZSIsInRtcFJvb3QiLCJiZWZvcmVFYWNoIiwidGVtcERpciIsIm9wZW5EaXIiLCJhZnRlckVhY2giLCJmcyIsInJpbXJhZiIsIml0IiwiZHN0UGF0aCIsInBhdGgiLCJqb2luIiwiZXhpc3RzIiwic2hvdWxkIiwiZXZlbnR1YWxseSIsImJlIiwidHJ1ZSJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUE7O0FBQ0E7O0FBQ0E7O0FBR0FBLFFBQVEsQ0FBQyxNQUFELEVBQVMsWUFBWTtBQUMzQixNQUFJQyxPQUFKO0FBRUFDLEVBQUFBLFVBQVUsQ0FBQyxrQkFBa0I7QUFDM0JELElBQUFBLE9BQU8sR0FBRyxNQUFNRSxlQUFRQyxPQUFSLEVBQWhCO0FBQ0QsR0FGUyxDQUFWO0FBSUFDLEVBQUFBLFNBQVMsQ0FBQyxrQkFBa0I7QUFDMUIsVUFBTUMsVUFBR0MsTUFBSCxDQUFVTixPQUFWLENBQU47QUFDRCxHQUZRLENBQVQ7QUFJQUQsRUFBQUEsUUFBUSxDQUFDLGdCQUFELEVBQW1CLFlBQVk7QUFDckNRLElBQUFBLEVBQUUsQ0FBQyw2Q0FBRCxFQUFnRCxrQkFBa0I7QUFDbEUsWUFBTUMsT0FBTyxHQUFHQyxjQUFLQyxJQUFMLENBQVVWLE9BQVYsRUFBbUIsY0FBbkIsQ0FBaEI7O0FBQ0EsWUFBTSx1QkFBYSxnRUFBYixFQUNKUSxPQURJLENBQU47QUFFQSxZQUFNSCxVQUFHTSxNQUFILENBQVVILE9BQVYsRUFBbUJJLE1BQW5CLENBQTBCQyxVQUExQixDQUFxQ0MsRUFBckMsQ0FBd0NDLElBQTlDO0FBQ0QsS0FMQyxDQUFGO0FBTUQsR0FQTyxDQUFSO0FBU0QsQ0FwQk8sQ0FBUiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBwYXRoIGZyb20gJ3BhdGgnO1xuaW1wb3J0IHsgZG93bmxvYWRGaWxlIH0gZnJvbSAnLi4vbGliL25ldCc7XG5pbXBvcnQgeyB0ZW1wRGlyLCBmcyB9IGZyb20gJy4uL2xpYi9pbmRleCc7XG5cblxuZGVzY3JpYmUoJyNuZXQnLCBmdW5jdGlvbiAoKSB7XG4gIGxldCB0bXBSb290O1xuXG4gIGJlZm9yZUVhY2goYXN5bmMgZnVuY3Rpb24gKCkge1xuICAgIHRtcFJvb3QgPSBhd2FpdCB0ZW1wRGlyLm9wZW5EaXIoKTtcbiAgfSk7XG5cbiAgYWZ0ZXJFYWNoKGFzeW5jIGZ1bmN0aW9uICgpIHtcbiAgICBhd2FpdCBmcy5yaW1yYWYodG1wUm9vdCk7XG4gIH0pO1xuXG4gIGRlc2NyaWJlKCdkb3dubG9hZEZpbGUoKScsIGZ1bmN0aW9uICgpIHtcbiAgICBpdCgnc2hvdWxkIGRvd25sb2FkIGZpbGUgaW50byB0aGUgdGFyZ2V0IGZvbGRlcicsIGFzeW5jIGZ1bmN0aW9uICgpIHtcbiAgICAgIGNvbnN0IGRzdFBhdGggPSBwYXRoLmpvaW4odG1wUm9vdCwgJ2Rvd25sb2FkLnRtcCcpO1xuICAgICAgYXdhaXQgZG93bmxvYWRGaWxlKCdodHRwczovL2FwcGl1bS5pby9pY28vYXBwbGUtdG91Y2gtaWNvbi0xMTR4MTE0LXByZWNvbXBvc2VkLnBuZycsXG4gICAgICAgIGRzdFBhdGgpO1xuICAgICAgYXdhaXQgZnMuZXhpc3RzKGRzdFBhdGgpLnNob3VsZC5ldmVudHVhbGx5LmJlLnRydWU7XG4gICAgfSk7XG4gIH0pO1xuXG59KTtcbiJdLCJmaWxlIjoidGVzdC9uZXQtZTJlLXNwZWNzLmpzIiwic291cmNlUm9vdCI6Ii4uLy4uIn0=
@@ -1,22 +0,0 @@
1
- "use strict";
2
-
3
- require("source-map-support/register");
4
-
5
- var _lib = require("../lib");
6
-
7
- describe('node utilities', function () {
8
- describe('requirePackage', function () {
9
- it('should be able to require a local package', async function () {
10
- await _lib.node.requirePackage('chai').should.not.be.rejected;
11
- });
12
- it.skip('should be able to require a global package', async function () {
13
- await _lib.node.requirePackage('npm').should.not.be.rejected;
14
- });
15
- it('should fail to find uninstalled package', async function () {
16
- await _lib.node.requirePackage('appium-foo-driver').should.eventually.be.rejectedWith(/Unable to load package/);
17
- });
18
- });
19
- });require('source-map-support').install();
20
-
21
-
22
- //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRlc3Qvbm9kZS1lMmUtc3BlY3MuanMiXSwibmFtZXMiOlsiZGVzY3JpYmUiLCJpdCIsIm5vZGUiLCJyZXF1aXJlUGFja2FnZSIsInNob3VsZCIsIm5vdCIsImJlIiwicmVqZWN0ZWQiLCJza2lwIiwiZXZlbnR1YWxseSIsInJlamVjdGVkV2l0aCJdLCJtYXBwaW5ncyI6Ijs7OztBQUFBOztBQUlBQSxRQUFRLENBQUMsZ0JBQUQsRUFBbUIsWUFBWTtBQUNyQ0EsRUFBQUEsUUFBUSxDQUFDLGdCQUFELEVBQW1CLFlBQVk7QUFDckNDLElBQUFBLEVBQUUsQ0FBQywyQ0FBRCxFQUE4QyxrQkFBa0I7QUFDaEUsWUFBTUMsVUFBS0MsY0FBTCxDQUFvQixNQUFwQixFQUE0QkMsTUFBNUIsQ0FBbUNDLEdBQW5DLENBQXVDQyxFQUF2QyxDQUEwQ0MsUUFBaEQ7QUFDRCxLQUZDLENBQUY7QUFJQU4sSUFBQUEsRUFBRSxDQUFDTyxJQUFILENBQVEsNENBQVIsRUFBc0Qsa0JBQWtCO0FBQ3RFLFlBQU1OLFVBQUtDLGNBQUwsQ0FBb0IsS0FBcEIsRUFBMkJDLE1BQTNCLENBQWtDQyxHQUFsQyxDQUFzQ0MsRUFBdEMsQ0FBeUNDLFFBQS9DO0FBQ0QsS0FGRDtBQUdBTixJQUFBQSxFQUFFLENBQUMseUNBQUQsRUFBNEMsa0JBQWtCO0FBQzlELFlBQU1DLFVBQUtDLGNBQUwsQ0FBb0IsbUJBQXBCLEVBQXlDQyxNQUF6QyxDQUFnREssVUFBaEQsQ0FBMkRILEVBQTNELENBQThESSxZQUE5RCxDQUEyRSx3QkFBM0UsQ0FBTjtBQUNELEtBRkMsQ0FBRjtBQUdELEdBWE8sQ0FBUjtBQVlELENBYk8sQ0FBUiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IG5vZGUgfSBmcm9tICcuLi9saWInO1xuXG5cblxuZGVzY3JpYmUoJ25vZGUgdXRpbGl0aWVzJywgZnVuY3Rpb24gKCkge1xuICBkZXNjcmliZSgncmVxdWlyZVBhY2thZ2UnLCBmdW5jdGlvbiAoKSB7XG4gICAgaXQoJ3Nob3VsZCBiZSBhYmxlIHRvIHJlcXVpcmUgYSBsb2NhbCBwYWNrYWdlJywgYXN5bmMgZnVuY3Rpb24gKCkge1xuICAgICAgYXdhaXQgbm9kZS5yZXF1aXJlUGFja2FnZSgnY2hhaScpLnNob3VsZC5ub3QuYmUucmVqZWN0ZWQ7XG4gICAgfSk7XG4gICAgLy8gWFhYOiBzZWUgIzE1OTUxXG4gICAgaXQuc2tpcCgnc2hvdWxkIGJlIGFibGUgdG8gcmVxdWlyZSBhIGdsb2JhbCBwYWNrYWdlJywgYXN5bmMgZnVuY3Rpb24gKCkge1xuICAgICAgYXdhaXQgbm9kZS5yZXF1aXJlUGFja2FnZSgnbnBtJykuc2hvdWxkLm5vdC5iZS5yZWplY3RlZDtcbiAgICB9KTtcbiAgICBpdCgnc2hvdWxkIGZhaWwgdG8gZmluZCB1bmluc3RhbGxlZCBwYWNrYWdlJywgYXN5bmMgZnVuY3Rpb24gKCkge1xuICAgICAgYXdhaXQgbm9kZS5yZXF1aXJlUGFja2FnZSgnYXBwaXVtLWZvby1kcml2ZXInKS5zaG91bGQuZXZlbnR1YWxseS5iZS5yZWplY3RlZFdpdGgoL1VuYWJsZSB0byBsb2FkIHBhY2thZ2UvKTtcbiAgICB9KTtcbiAgfSk7XG59KTtcbiJdLCJmaWxlIjoidGVzdC9ub2RlLWUyZS1zcGVjcy5qcyIsInNvdXJjZVJvb3QiOiIuLi8uLiJ9
@@ -1,54 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- require("source-map-support/register");
6
-
7
- var _path = _interopRequireDefault(require("path"));
8
-
9
- var _index = require("../lib/index.js");
10
-
11
- const binaryPlistPath = _path.default.join(__dirname, 'assets', 'sample_binary.plist');
12
-
13
- const textPlistPath = _path.default.join(__dirname, 'assets', 'sample_text.plist');
14
-
15
- describe('plist', function () {
16
- it('should parse plist file as binary', async function () {
17
- let content = await _index.plist.parsePlistFile(binaryPlistPath);
18
- content.should.have.property('com.apple.locationd.bundle-/System/Library/PrivateFrameworks/Parsec.framework');
19
- });
20
- it(`should return an empty object if file doesn't exist and mustExist is set to false`, async function () {
21
- let mustExist = false;
22
- let content = await _index.plist.parsePlistFile('doesntExist.plist', mustExist);
23
- content.should.be.an('object');
24
- content.should.be.empty;
25
- });
26
- it('should write plist file as binary', async function () {
27
- let plistFile = _path.default.resolve(await _index.tempDir.openDir(), 'sample.plist');
28
-
29
- await _index.fs.copyFile(binaryPlistPath, plistFile);
30
- let updatedFields = {
31
- 'io.appium.test': true
32
- };
33
- await _index.plist.updatePlistFile(plistFile, updatedFields, true);
34
- let content = await _index.plist.parsePlistFile(plistFile);
35
- content.should.have.property('io.appium.test');
36
- });
37
- it('should read binary plist', async function () {
38
- const content = await _index.fs.readFile(binaryPlistPath);
39
-
40
- const object = _index.plist.parsePlist(content);
41
-
42
- object.should.have.property('com.apple.locationd.bundle-/System/Library/PrivateFrameworks/Parsec.framework');
43
- });
44
- it('should read text plist', async function () {
45
- const content = await _index.fs.readFile(textPlistPath);
46
-
47
- const object = _index.plist.parsePlist(content);
48
-
49
- object.should.have.property('com.apple.locationd.bundle-/System/Library/PrivateFrameworks/Parsec.framework');
50
- });
51
- });require('source-map-support').install();
52
-
53
-
54
- //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRlc3QvcGxpc3Qtc3BlY3MuanMiXSwibmFtZXMiOlsiYmluYXJ5UGxpc3RQYXRoIiwicGF0aCIsImpvaW4iLCJfX2Rpcm5hbWUiLCJ0ZXh0UGxpc3RQYXRoIiwiZGVzY3JpYmUiLCJpdCIsImNvbnRlbnQiLCJwbGlzdCIsInBhcnNlUGxpc3RGaWxlIiwic2hvdWxkIiwiaGF2ZSIsInByb3BlcnR5IiwibXVzdEV4aXN0IiwiYmUiLCJhbiIsImVtcHR5IiwicGxpc3RGaWxlIiwicmVzb2x2ZSIsInRlbXBEaXIiLCJvcGVuRGlyIiwiZnMiLCJjb3B5RmlsZSIsInVwZGF0ZWRGaWVsZHMiLCJ1cGRhdGVQbGlzdEZpbGUiLCJyZWFkRmlsZSIsIm9iamVjdCIsInBhcnNlUGxpc3QiXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBOztBQUNBOztBQUlBLE1BQU1BLGVBQWUsR0FBR0MsY0FBS0MsSUFBTCxDQUFVQyxTQUFWLEVBQXFCLFFBQXJCLEVBQStCLHFCQUEvQixDQUF4Qjs7QUFDQSxNQUFNQyxhQUFhLEdBQUdILGNBQUtDLElBQUwsQ0FBVUMsU0FBVixFQUFxQixRQUFyQixFQUErQixtQkFBL0IsQ0FBdEI7O0FBRUFFLFFBQVEsQ0FBQyxPQUFELEVBQVUsWUFBWTtBQUM1QkMsRUFBQUEsRUFBRSxDQUFDLG1DQUFELEVBQXNDLGtCQUFrQjtBQUN4RCxRQUFJQyxPQUFPLEdBQUcsTUFBTUMsYUFBTUMsY0FBTixDQUFxQlQsZUFBckIsQ0FBcEI7QUFDQU8sSUFBQUEsT0FBTyxDQUFDRyxNQUFSLENBQWVDLElBQWYsQ0FBb0JDLFFBQXBCLENBQTZCLCtFQUE3QjtBQUNELEdBSEMsQ0FBRjtBQUtBTixFQUFBQSxFQUFFLENBQUUsbUZBQUYsRUFBc0Ysa0JBQWtCO0FBQ3hHLFFBQUlPLFNBQVMsR0FBRyxLQUFoQjtBQUNBLFFBQUlOLE9BQU8sR0FBRyxNQUFNQyxhQUFNQyxjQUFOLENBQXFCLG1CQUFyQixFQUEwQ0ksU0FBMUMsQ0FBcEI7QUFDQU4sSUFBQUEsT0FBTyxDQUFDRyxNQUFSLENBQWVJLEVBQWYsQ0FBa0JDLEVBQWxCLENBQXFCLFFBQXJCO0FBQ0FSLElBQUFBLE9BQU8sQ0FBQ0csTUFBUixDQUFlSSxFQUFmLENBQWtCRSxLQUFsQjtBQUNELEdBTEMsQ0FBRjtBQU9BVixFQUFBQSxFQUFFLENBQUMsbUNBQUQsRUFBc0Msa0JBQWtCO0FBRXhELFFBQUlXLFNBQVMsR0FBR2hCLGNBQUtpQixPQUFMLENBQWEsTUFBTUMsZUFBUUMsT0FBUixFQUFuQixFQUFzQyxjQUF0QyxDQUFoQjs7QUFDQSxVQUFNQyxVQUFHQyxRQUFILENBQVl0QixlQUFaLEVBQTZCaUIsU0FBN0IsQ0FBTjtBQUdBLFFBQUlNLGFBQWEsR0FBRztBQUNsQix3QkFBa0I7QUFEQSxLQUFwQjtBQUdBLFVBQU1mLGFBQU1nQixlQUFOLENBQXNCUCxTQUF0QixFQUFpQ00sYUFBakMsRUFBZ0QsSUFBaEQsQ0FBTjtBQUdBLFFBQUloQixPQUFPLEdBQUcsTUFBTUMsYUFBTUMsY0FBTixDQUFxQlEsU0FBckIsQ0FBcEI7QUFDQVYsSUFBQUEsT0FBTyxDQUFDRyxNQUFSLENBQWVDLElBQWYsQ0FBb0JDLFFBQXBCLENBQTZCLGdCQUE3QjtBQUNELEdBZEMsQ0FBRjtBQWdCQU4sRUFBQUEsRUFBRSxDQUFDLDBCQUFELEVBQTZCLGtCQUFrQjtBQUMvQyxVQUFNQyxPQUFPLEdBQUcsTUFBTWMsVUFBR0ksUUFBSCxDQUFZekIsZUFBWixDQUF0Qjs7QUFDQSxVQUFNMEIsTUFBTSxHQUFHbEIsYUFBTW1CLFVBQU4sQ0FBaUJwQixPQUFqQixDQUFmOztBQUNBbUIsSUFBQUEsTUFBTSxDQUFDaEIsTUFBUCxDQUFjQyxJQUFkLENBQW1CQyxRQUFuQixDQUE0QiwrRUFBNUI7QUFDRCxHQUpDLENBQUY7QUFNQU4sRUFBQUEsRUFBRSxDQUFDLHdCQUFELEVBQTJCLGtCQUFrQjtBQUM3QyxVQUFNQyxPQUFPLEdBQUcsTUFBTWMsVUFBR0ksUUFBSCxDQUFZckIsYUFBWixDQUF0Qjs7QUFDQSxVQUFNc0IsTUFBTSxHQUFHbEIsYUFBTW1CLFVBQU4sQ0FBaUJwQixPQUFqQixDQUFmOztBQUNBbUIsSUFBQUEsTUFBTSxDQUFDaEIsTUFBUCxDQUFjQyxJQUFkLENBQW1CQyxRQUFuQixDQUE0QiwrRUFBNUI7QUFDRCxHQUpDLENBQUY7QUFLRCxDQXhDTyxDQUFSIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHBhdGggZnJvbSAncGF0aCc7XG5pbXBvcnQgeyBwbGlzdCwgdGVtcERpciwgZnMgfSBmcm9tICcuLi9saWIvaW5kZXguanMnO1xuXG5cblxuY29uc3QgYmluYXJ5UGxpc3RQYXRoID0gcGF0aC5qb2luKF9fZGlybmFtZSwgJ2Fzc2V0cycsICdzYW1wbGVfYmluYXJ5LnBsaXN0Jyk7XG5jb25zdCB0ZXh0UGxpc3RQYXRoID0gcGF0aC5qb2luKF9fZGlybmFtZSwgJ2Fzc2V0cycsICdzYW1wbGVfdGV4dC5wbGlzdCcpO1xuXG5kZXNjcmliZSgncGxpc3QnLCBmdW5jdGlvbiAoKSB7XG4gIGl0KCdzaG91bGQgcGFyc2UgcGxpc3QgZmlsZSBhcyBiaW5hcnknLCBhc3luYyBmdW5jdGlvbiAoKSB7XG4gICAgbGV0IGNvbnRlbnQgPSBhd2FpdCBwbGlzdC5wYXJzZVBsaXN0RmlsZShiaW5hcnlQbGlzdFBhdGgpO1xuICAgIGNvbnRlbnQuc2hvdWxkLmhhdmUucHJvcGVydHkoJ2NvbS5hcHBsZS5sb2NhdGlvbmQuYnVuZGxlLS9TeXN0ZW0vTGlicmFyeS9Qcml2YXRlRnJhbWV3b3Jrcy9QYXJzZWMuZnJhbWV3b3JrJyk7XG4gIH0pO1xuXG4gIGl0KGBzaG91bGQgcmV0dXJuIGFuIGVtcHR5IG9iamVjdCBpZiBmaWxlIGRvZXNuJ3QgZXhpc3QgYW5kIG11c3RFeGlzdCBpcyBzZXQgdG8gZmFsc2VgLCBhc3luYyBmdW5jdGlvbiAoKSB7XG4gICAgbGV0IG11c3RFeGlzdCA9IGZhbHNlO1xuICAgIGxldCBjb250ZW50ID0gYXdhaXQgcGxpc3QucGFyc2VQbGlzdEZpbGUoJ2RvZXNudEV4aXN0LnBsaXN0JywgbXVzdEV4aXN0KTtcbiAgICBjb250ZW50LnNob3VsZC5iZS5hbignb2JqZWN0Jyk7XG4gICAgY29udGVudC5zaG91bGQuYmUuZW1wdHk7XG4gIH0pO1xuXG4gIGl0KCdzaG91bGQgd3JpdGUgcGxpc3QgZmlsZSBhcyBiaW5hcnknLCBhc3luYyBmdW5jdGlvbiAoKSB7XG4gICAgLy8gY3JlYXRlIGEgdGVtcG9yYXJ5IGZpbGUsIHRvIHdoaWNoIHdlIHdpbGwgd3JpdGVcbiAgICBsZXQgcGxpc3RGaWxlID0gcGF0aC5yZXNvbHZlKGF3YWl0IHRlbXBEaXIub3BlbkRpcigpLCAnc2FtcGxlLnBsaXN0Jyk7XG4gICAgYXdhaXQgZnMuY29weUZpbGUoYmluYXJ5UGxpc3RQYXRoLCBwbGlzdEZpbGUpO1xuXG4gICAgLy8gd3JpdGUgc29tZSBkYXRhXG4gICAgbGV0IHVwZGF0ZWRGaWVsZHMgPSB7XG4gICAgICAnaW8uYXBwaXVtLnRlc3QnOiB0cnVlXG4gICAgfTtcbiAgICBhd2FpdCBwbGlzdC51cGRhdGVQbGlzdEZpbGUocGxpc3RGaWxlLCB1cGRhdGVkRmllbGRzLCB0cnVlKTtcblxuICAgIC8vIG1ha2Ugc3VyZSB0aGUgZGF0YSBpcyB0aGVyZVxuICAgIGxldCBjb250ZW50ID0gYXdhaXQgcGxpc3QucGFyc2VQbGlzdEZpbGUocGxpc3RGaWxlKTtcbiAgICBjb250ZW50LnNob3VsZC5oYXZlLnByb3BlcnR5KCdpby5hcHBpdW0udGVzdCcpO1xuICB9KTtcblxuICBpdCgnc2hvdWxkIHJlYWQgYmluYXJ5IHBsaXN0JywgYXN5bmMgZnVuY3Rpb24gKCkge1xuICAgIGNvbnN0IGNvbnRlbnQgPSBhd2FpdCBmcy5yZWFkRmlsZShiaW5hcnlQbGlzdFBhdGgpO1xuICAgIGNvbnN0IG9iamVjdCA9IHBsaXN0LnBhcnNlUGxpc3QoY29udGVudCk7XG4gICAgb2JqZWN0LnNob3VsZC5oYXZlLnByb3BlcnR5KCdjb20uYXBwbGUubG9jYXRpb25kLmJ1bmRsZS0vU3lzdGVtL0xpYnJhcnkvUHJpdmF0ZUZyYW1ld29ya3MvUGFyc2VjLmZyYW1ld29yaycpO1xuICB9KTtcblxuICBpdCgnc2hvdWxkIHJlYWQgdGV4dCBwbGlzdCcsIGFzeW5jIGZ1bmN0aW9uICgpIHtcbiAgICBjb25zdCBjb250ZW50ID0gYXdhaXQgZnMucmVhZEZpbGUodGV4dFBsaXN0UGF0aCk7XG4gICAgY29uc3Qgb2JqZWN0ID0gcGxpc3QucGFyc2VQbGlzdChjb250ZW50KTtcbiAgICBvYmplY3Quc2hvdWxkLmhhdmUucHJvcGVydHkoJ2NvbS5hcHBsZS5sb2NhdGlvbmQuYnVuZGxlLS9TeXN0ZW0vTGlicmFyeS9Qcml2YXRlRnJhbWV3b3Jrcy9QYXJzZWMuZnJhbWV3b3JrJyk7XG4gIH0pO1xufSk7XG4iXSwiZmlsZSI6InRlc3QvcGxpc3Qtc3BlY3MuanMiLCJzb3VyY2VSb290IjoiLi4vLi4ifQ==
@@ -1,104 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- require("source-map-support/register");
6
-
7
- var teenProcess = _interopRequireWildcard(require("teen_process"));
8
-
9
- var _sinon = _interopRequireDefault(require("sinon"));
10
-
11
- var _index = require("../lib/index.js");
12
-
13
- var _asyncbox = require("asyncbox");
14
-
15
- function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
16
-
17
- function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
18
-
19
- const SubProcess = teenProcess.SubProcess;
20
- describe('process', function () {
21
- describe('getProcessIds', function () {
22
- let proc;
23
- before(async function () {
24
- proc = new SubProcess('tail', ['-f', __filename]);
25
- await proc.start();
26
- });
27
- after(async function () {
28
- await proc.stop();
29
- });
30
- it('should get return an array for existing process', async function () {
31
- let pids = await _index.process.getProcessIds('tail');
32
- pids.should.be.an.instanceof(Array);
33
- });
34
- it('should get process identifiers for existing process', async function () {
35
- let pids = await _index.process.getProcessIds('tail');
36
- pids.should.have.length.at.least(1);
37
- });
38
- it('should get an empty array when the process does not exist', async function () {
39
- let pids = await _index.process.getProcessIds('sadfgasdfasdf');
40
- pids.should.have.length(0);
41
- });
42
- it('should throw an error if pgrep fails', async function () {
43
- let tpMock = _sinon.default.mock(teenProcess);
44
-
45
- tpMock.expects('exec').throws({
46
- message: 'Oops',
47
- code: 2
48
- });
49
- await _index.process.getProcessIds('tail').should.eventually.be.rejectedWith(/Oops/);
50
- tpMock.restore();
51
- });
52
- });
53
- describe('killProcess', function () {
54
- let proc;
55
- beforeEach(async function () {
56
- proc = new SubProcess('tail', ['-f', __filename]);
57
- await proc.start();
58
- });
59
- afterEach(async function () {
60
- if (proc.isRunning) {
61
- await proc.stop();
62
- }
63
- });
64
- it('should kill process that is running', async function () {
65
- proc.isRunning.should.be.true;
66
- await _index.process.killProcess('tail');
67
- await (0, _asyncbox.retryInterval)(10, 100, async () => {
68
- proc.isRunning.should.be.false;
69
- });
70
- });
71
- it('should do nothing if the process does not exist', async function () {
72
- proc.isRunning.should.be.true;
73
- await _index.process.killProcess('asdfasdfasdf');
74
- await (0, _asyncbox.retryInterval)(10, 100, async () => {
75
- proc.isRunning.should.be.false;
76
- }).should.eventually.be.rejected;
77
- });
78
- it('should throw an error if pgrep fails', async function () {
79
- let tpMock = _sinon.default.mock(teenProcess);
80
-
81
- tpMock.expects('exec').throws({
82
- message: 'Oops',
83
- code: 2
84
- });
85
- await _index.process.killProcess('tail').should.eventually.be.rejectedWith(/Oops/);
86
- tpMock.restore();
87
- });
88
- it('should throw an error if pkill fails', async function () {
89
- let tpMock = _sinon.default.mock(teenProcess);
90
-
91
- tpMock.expects('exec').twice().onFirstCall().returns({
92
- stdout: '42\n'
93
- }).onSecondCall().throws({
94
- message: 'Oops',
95
- code: 2
96
- });
97
- await _index.process.killProcess('tail').should.eventually.be.rejectedWith(/Oops/);
98
- tpMock.restore();
99
- });
100
- });
101
- });require('source-map-support').install();
102
-
103
-
104
- //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["test/process-specs.js"],"names":["SubProcess","teenProcess","describe","proc","before","__filename","start","after","stop","it","pids","process","getProcessIds","should","be","an","instanceof","Array","have","length","at","least","tpMock","sinon","mock","expects","throws","message","code","eventually","rejectedWith","restore","beforeEach","afterEach","isRunning","true","killProcess","false","rejected","twice","onFirstCall","returns","stdout","onSecondCall"],"mappings":";;;;;;AAAA;;AACA;;AACA;;AACA;;;;;;AAIA,MAAMA,UAAU,GAAGC,WAAW,CAACD,UAA/B;AAEAE,QAAQ,CAAC,SAAD,EAAY,YAAY;AAC9BA,EAAAA,QAAQ,CAAC,eAAD,EAAkB,YAAY;AACpC,QAAIC,IAAJ;AACAC,IAAAA,MAAM,CAAC,kBAAkB;AACvBD,MAAAA,IAAI,GAAG,IAAIH,UAAJ,CAAe,MAAf,EAAuB,CAAC,IAAD,EAAOK,UAAP,CAAvB,CAAP;AACA,YAAMF,IAAI,CAACG,KAAL,EAAN;AACD,KAHK,CAAN;AAIAC,IAAAA,KAAK,CAAC,kBAAkB;AACtB,YAAMJ,IAAI,CAACK,IAAL,EAAN;AACD,KAFI,CAAL;AAGAC,IAAAA,EAAE,CAAC,iDAAD,EAAoD,kBAAkB;AACtE,UAAIC,IAAI,GAAG,MAAMC,eAAQC,aAAR,CAAsB,MAAtB,CAAjB;AACAF,MAAAA,IAAI,CAACG,MAAL,CAAYC,EAAZ,CAAeC,EAAf,CAAkBC,UAAlB,CAA6BC,KAA7B;AACD,KAHC,CAAF;AAIAR,IAAAA,EAAE,CAAC,qDAAD,EAAwD,kBAAkB;AAC1E,UAAIC,IAAI,GAAG,MAAMC,eAAQC,aAAR,CAAsB,MAAtB,CAAjB;AACAF,MAAAA,IAAI,CAACG,MAAL,CAAYK,IAAZ,CAAiBC,MAAjB,CAAwBC,EAAxB,CAA2BC,KAA3B,CAAiC,CAAjC;AACD,KAHC,CAAF;AAIAZ,IAAAA,EAAE,CAAC,2DAAD,EAA8D,kBAAkB;AAChF,UAAIC,IAAI,GAAG,MAAMC,eAAQC,aAAR,CAAsB,eAAtB,CAAjB;AACAF,MAAAA,IAAI,CAACG,MAAL,CAAYK,IAAZ,CAAiBC,MAAjB,CAAwB,CAAxB;AACD,KAHC,CAAF;AAIAV,IAAAA,EAAE,CAAC,sCAAD,EAAyC,kBAAkB;AAC3D,UAAIa,MAAM,GAAGC,eAAMC,IAAN,CAAWvB,WAAX,CAAb;;AACAqB,MAAAA,MAAM,CAACG,OAAP,CAAe,MAAf,EAAuBC,MAAvB,CAA8B;AAACC,QAAAA,OAAO,EAAE,MAAV;AAAkBC,QAAAA,IAAI,EAAE;AAAxB,OAA9B;AAEA,YAAMjB,eAAQC,aAAR,CAAsB,MAAtB,EAA8BC,MAA9B,CAAqCgB,UAArC,CAAgDf,EAAhD,CAAmDgB,YAAnD,CAAgE,MAAhE,CAAN;AAEAR,MAAAA,MAAM,CAACS,OAAP;AACD,KAPC,CAAF;AAQD,GA7BO,CAAR;AA+BA7B,EAAAA,QAAQ,CAAC,aAAD,EAAgB,YAAY;AAClC,QAAIC,IAAJ;AACA6B,IAAAA,UAAU,CAAC,kBAAkB;AAC3B7B,MAAAA,IAAI,GAAG,IAAIH,UAAJ,CAAe,MAAf,EAAuB,CAAC,IAAD,EAAOK,UAAP,CAAvB,CAAP;AACA,YAAMF,IAAI,CAACG,KAAL,EAAN;AACD,KAHS,CAAV;AAIA2B,IAAAA,SAAS,CAAC,kBAAkB;AAC1B,UAAI9B,IAAI,CAAC+B,SAAT,EAAoB;AAClB,cAAM/B,IAAI,CAACK,IAAL,EAAN;AACD;AACF,KAJQ,CAAT;AAKAC,IAAAA,EAAE,CAAC,qCAAD,EAAwC,kBAAkB;AAC1DN,MAAAA,IAAI,CAAC+B,SAAL,CAAerB,MAAf,CAAsBC,EAAtB,CAAyBqB,IAAzB;AACA,YAAMxB,eAAQyB,WAAR,CAAoB,MAApB,CAAN;AAGA,YAAM,6BAAc,EAAd,EAAkB,GAAlB,EAAuB,YAAY;AACvCjC,QAAAA,IAAI,CAAC+B,SAAL,CAAerB,MAAf,CAAsBC,EAAtB,CAAyBuB,KAAzB;AACD,OAFK,CAAN;AAGD,KARC,CAAF;AASA5B,IAAAA,EAAE,CAAC,iDAAD,EAAoD,kBAAkB;AACtEN,MAAAA,IAAI,CAAC+B,SAAL,CAAerB,MAAf,CAAsBC,EAAtB,CAAyBqB,IAAzB;AACA,YAAMxB,eAAQyB,WAAR,CAAoB,cAApB,CAAN;AAEA,YAAM,6BAAc,EAAd,EAAkB,GAAlB,EAAuB,YAAY;AACvCjC,QAAAA,IAAI,CAAC+B,SAAL,CAAerB,MAAf,CAAsBC,EAAtB,CAAyBuB,KAAzB;AACD,OAFK,EAEHxB,MAFG,CAEIgB,UAFJ,CAEef,EAFf,CAEkBwB,QAFxB;AAGD,KAPC,CAAF;AAQA7B,IAAAA,EAAE,CAAC,sCAAD,EAAyC,kBAAkB;AAC3D,UAAIa,MAAM,GAAGC,eAAMC,IAAN,CAAWvB,WAAX,CAAb;;AACAqB,MAAAA,MAAM,CAACG,OAAP,CAAe,MAAf,EAAuBC,MAAvB,CAA8B;AAACC,QAAAA,OAAO,EAAE,MAAV;AAAkBC,QAAAA,IAAI,EAAE;AAAxB,OAA9B;AAEA,YAAMjB,eAAQyB,WAAR,CAAoB,MAApB,EAA4BvB,MAA5B,CAAmCgB,UAAnC,CAA8Cf,EAA9C,CAAiDgB,YAAjD,CAA8D,MAA9D,CAAN;AAEAR,MAAAA,MAAM,CAACS,OAAP;AACD,KAPC,CAAF;AAQAtB,IAAAA,EAAE,CAAC,sCAAD,EAAyC,kBAAkB;AAC3D,UAAIa,MAAM,GAAGC,eAAMC,IAAN,CAAWvB,WAAX,CAAb;;AACAqB,MAAAA,MAAM,CAACG,OAAP,CAAe,MAAf,EAAuBc,KAAvB,GACGC,WADH,GACiBC,OADjB,CACyB;AAACC,QAAAA,MAAM,EAAE;AAAT,OADzB,EAEGC,YAFH,GAEkBjB,MAFlB,CAEyB;AAACC,QAAAA,OAAO,EAAE,MAAV;AAAkBC,QAAAA,IAAI,EAAE;AAAxB,OAFzB;AAIA,YAAMjB,eAAQyB,WAAR,CAAoB,MAApB,EAA4BvB,MAA5B,CAAmCgB,UAAnC,CAA8Cf,EAA9C,CAAiDgB,YAAjD,CAA8D,MAA9D,CAAN;AAEAR,MAAAA,MAAM,CAACS,OAAP;AACD,KATC,CAAF;AAUD,GA9CO,CAAR;AA+CD,CA/EO,CAAR","sourcesContent":["import * as teenProcess from 'teen_process';\nimport sinon from 'sinon';\nimport { process } from '../lib/index.js';\nimport { retryInterval } from 'asyncbox';\n\n\n\nconst SubProcess = teenProcess.SubProcess;\n\ndescribe('process', function () {\n  describe('getProcessIds', function () {\n    let proc;\n    before(async function () {\n      proc = new SubProcess('tail', ['-f', __filename]);\n      await proc.start();\n    });\n    after(async function () {\n      await proc.stop();\n    });\n    it('should get return an array for existing process', async function () {\n      let pids = await process.getProcessIds('tail');\n      pids.should.be.an.instanceof(Array);\n    });\n    it('should get process identifiers for existing process', async function () {\n      let pids = await process.getProcessIds('tail');\n      pids.should.have.length.at.least(1);\n    });\n    it('should get an empty array when the process does not exist', async function () {\n      let pids = await process.getProcessIds('sadfgasdfasdf');\n      pids.should.have.length(0);\n    });\n    it('should throw an error if pgrep fails', async function () {\n      let tpMock = sinon.mock(teenProcess);\n      tpMock.expects('exec').throws({message: 'Oops', code: 2});\n\n      await process.getProcessIds('tail').should.eventually.be.rejectedWith(/Oops/);\n\n      tpMock.restore();\n    });\n  });\n\n  describe('killProcess', function () {\n    let proc;\n    beforeEach(async function () {\n      proc = new SubProcess('tail', ['-f', __filename]);\n      await proc.start();\n    });\n    afterEach(async function () {\n      if (proc.isRunning) {\n        await proc.stop();\n      }\n    });\n    it('should kill process that is running', async function () {\n      proc.isRunning.should.be.true;\n      await process.killProcess('tail');\n\n      // it may take a moment to actually be registered as killed\n      await retryInterval(10, 100, async () => { // eslint-disable-line require-await\n        proc.isRunning.should.be.false;\n      });\n    });\n    it('should do nothing if the process does not exist', async function () {\n      proc.isRunning.should.be.true;\n      await process.killProcess('asdfasdfasdf');\n\n      await retryInterval(10, 100, async () => { // eslint-disable-line require-await\n        proc.isRunning.should.be.false;\n      }).should.eventually.be.rejected;\n    });\n    it('should throw an error if pgrep fails', async function () {\n      let tpMock = sinon.mock(teenProcess);\n      tpMock.expects('exec').throws({message: 'Oops', code: 2});\n\n      await process.killProcess('tail').should.eventually.be.rejectedWith(/Oops/);\n\n      tpMock.restore();\n    });\n    it('should throw an error if pkill fails', async function () {\n      let tpMock = sinon.mock(teenProcess);\n      tpMock.expects('exec').twice()\n        .onFirstCall().returns({stdout: '42\\n'})\n        .onSecondCall().throws({message: 'Oops', code: 2});\n\n      await process.killProcess('tail').should.eventually.be.rejectedWith(/Oops/);\n\n      tpMock.restore();\n    });\n  });\n});\n"],"file":"test/process-specs.js","sourceRoot":"../.."}