@appium/support 2.55.4 → 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.
- package/build/lib/env.js +102 -0
- package/build/lib/fs.js +74 -56
- package/build/lib/image-util.js +2 -4
- package/build/lib/index.js +18 -6
- package/build/lib/log-internal.js +2 -4
- package/build/lib/logger.js +2 -4
- package/build/lib/logging.js +2 -4
- package/build/lib/mjpeg.js +2 -4
- package/build/lib/mkdirp.js +7 -11
- package/build/lib/net.js +2 -4
- package/build/lib/node.js +99 -2
- package/build/lib/npm.js +240 -0
- package/build/lib/plist.js +2 -4
- package/build/lib/process.js +2 -4
- package/build/lib/system.js +2 -4
- package/build/lib/tempdir.js +2 -4
- package/build/lib/timing.js +2 -4
- package/build/lib/util.js +6 -8
- package/build/lib/zip.js +4 -8
- package/lib/env.js +162 -0
- package/lib/fs.js +193 -69
- package/lib/index.js +8 -2
- package/lib/log-internal.js +2 -2
- package/lib/logging.js +1 -1
- package/lib/mkdirp.js +3 -6
- package/lib/net.js +4 -4
- package/lib/node.js +104 -1
- package/lib/npm.js +335 -0
- package/lib/tempdir.js +6 -6
- package/lib/util.js +28 -24
- package/lib/zip.js +7 -8
- package/package.json +20 -10
- package/build/test/assets/sample_binary.plist +0 -0
- package/build/test/assets/sample_text.plist +0 -28
- package/build/test/fs-specs.js +0 -264
- package/build/test/helpers.js +0 -35
- package/build/test/image-util-e2e-specs.js +0 -78
- package/build/test/index-specs.js +0 -49
- package/build/test/log-internals-specs.js +0 -97
- package/build/test/logger/helpers.js +0 -71
- package/build/test/logger/logger-force-specs.js +0 -41
- package/build/test/logger/logger-normal-specs.js +0 -113
- package/build/test/logger/logger-test-specs.js +0 -40
- package/build/test/mjpeg-e2e-specs.js +0 -96
- package/build/test/net-e2e-specs.js +0 -32
- package/build/test/node-e2e-specs.js +0 -22
- package/build/test/plist-specs.js +0 -54
- package/build/test/process-specs.js +0 -104
- package/build/test/system-specs.js +0 -136
- package/build/test/tempdir-specs.js +0 -86
- package/build/test/timing-specs.js +0 -125
- package/build/test/util-e2e-specs.js +0 -136
- package/build/test/util-specs.js +0 -537
- package/build/test/zip-e2e-specs.js +0 -233
|
@@ -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":"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","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":"../.."}
|
|
@@ -1,136 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
|
-
require("source-map-support/register");
|
|
6
|
-
|
|
7
|
-
var _index = require("../lib/index.js");
|
|
8
|
-
|
|
9
|
-
var _os = _interopRequireDefault(require("os"));
|
|
10
|
-
|
|
11
|
-
var _sinon = _interopRequireDefault(require("sinon"));
|
|
12
|
-
|
|
13
|
-
var teen_process = _interopRequireWildcard(require("teen_process"));
|
|
14
|
-
|
|
15
|
-
var _lodash = _interopRequireDefault(require("lodash"));
|
|
16
|
-
|
|
17
|
-
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); }
|
|
18
|
-
|
|
19
|
-
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; }
|
|
20
|
-
|
|
21
|
-
let sandbox,
|
|
22
|
-
tpMock,
|
|
23
|
-
osMock = null;
|
|
24
|
-
let SANDBOX = Symbol();
|
|
25
|
-
let mocks = {};
|
|
26
|
-
let libs = {
|
|
27
|
-
teen_process,
|
|
28
|
-
os: _os.default,
|
|
29
|
-
system: _index.system
|
|
30
|
-
};
|
|
31
|
-
describe('system', function () {
|
|
32
|
-
describe('isX functions', function () {
|
|
33
|
-
beforeEach(function () {
|
|
34
|
-
osMock = _sinon.default.mock(_os.default);
|
|
35
|
-
});
|
|
36
|
-
afterEach(function () {
|
|
37
|
-
osMock.verify();
|
|
38
|
-
});
|
|
39
|
-
it('should correctly return Windows System if it is a Windows', function () {
|
|
40
|
-
osMock.expects('type').returns('Windows_NT');
|
|
41
|
-
_index.system.isWindows().should.be.true;
|
|
42
|
-
});
|
|
43
|
-
it('should correctly return Mac if it is a Mac', function () {
|
|
44
|
-
osMock.expects('type').returns('Darwin');
|
|
45
|
-
_index.system.isMac().should.be.true;
|
|
46
|
-
});
|
|
47
|
-
it('should correctly return Linux if it is a Linux', function () {
|
|
48
|
-
osMock.expects('type').twice().returns('Linux');
|
|
49
|
-
_index.system.isLinux().should.be.true;
|
|
50
|
-
});
|
|
51
|
-
});
|
|
52
|
-
describe('mac OSX version', function () {
|
|
53
|
-
beforeEach(function () {
|
|
54
|
-
tpMock = _sinon.default.mock(teen_process);
|
|
55
|
-
});
|
|
56
|
-
afterEach(function () {
|
|
57
|
-
tpMock.verify();
|
|
58
|
-
});
|
|
59
|
-
it('should return correct version for 10.10.5', async function () {
|
|
60
|
-
tpMock.expects('exec').once().withExactArgs('sw_vers', ['-productVersion']).returns({
|
|
61
|
-
stdout: '10.10.5'
|
|
62
|
-
});
|
|
63
|
-
await _index.system.macOsxVersion().should.eventually.equal('10.10');
|
|
64
|
-
});
|
|
65
|
-
it('should return correct version for 10.12', async function () {
|
|
66
|
-
tpMock.expects('exec').once().withExactArgs('sw_vers', ['-productVersion']).returns({
|
|
67
|
-
stdout: '10.12.0'
|
|
68
|
-
});
|
|
69
|
-
await _index.system.macOsxVersion().should.eventually.equal('10.12');
|
|
70
|
-
});
|
|
71
|
-
it('should return correct version for 10.12 with newline', async function () {
|
|
72
|
-
tpMock.expects('exec').once().withExactArgs('sw_vers', ['-productVersion']).returns({
|
|
73
|
-
stdout: '10.12 \n'
|
|
74
|
-
});
|
|
75
|
-
await _index.system.macOsxVersion().should.eventually.equal('10.12');
|
|
76
|
-
});
|
|
77
|
-
it("should throw an error if OSX version can't be determined", async function () {
|
|
78
|
-
let invalidOsx = 'error getting operation system version blabla';
|
|
79
|
-
tpMock.expects('exec').once().withExactArgs('sw_vers', ['-productVersion']).returns({
|
|
80
|
-
stdout: invalidOsx
|
|
81
|
-
});
|
|
82
|
-
await _index.system.macOsxVersion().should.eventually.be.rejectedWith(new RegExp(_lodash.default.escapeRegExp(invalidOsx)));
|
|
83
|
-
});
|
|
84
|
-
});
|
|
85
|
-
describe('architecture', function () {
|
|
86
|
-
beforeEach(function () {
|
|
87
|
-
sandbox = _sinon.default.createSandbox();
|
|
88
|
-
mocks[SANDBOX] = sandbox;
|
|
89
|
-
|
|
90
|
-
for (let [key, value] of _lodash.default.toPairs(libs)) {
|
|
91
|
-
mocks[key] = sandbox.mock(value);
|
|
92
|
-
}
|
|
93
|
-
});
|
|
94
|
-
afterEach(function () {
|
|
95
|
-
sandbox.restore();
|
|
96
|
-
});
|
|
97
|
-
it('should return correct architecture if it is a 64 bit Mac/Linux', async function () {
|
|
98
|
-
mocks.os.expects('type').thrice().returns('Darwin');
|
|
99
|
-
mocks.teen_process.expects('exec').once().withExactArgs('uname', ['-m']).returns({
|
|
100
|
-
stdout: 'x86_64'
|
|
101
|
-
});
|
|
102
|
-
let arch = await _index.system.arch();
|
|
103
|
-
arch.should.equal('64');
|
|
104
|
-
mocks[SANDBOX].verify();
|
|
105
|
-
});
|
|
106
|
-
it('should return correct architecture if it is a 32 bit Mac/Linux', async function () {
|
|
107
|
-
mocks.os.expects('type').twice().returns('Linux');
|
|
108
|
-
mocks.teen_process.expects('exec').once().withExactArgs('uname', ['-m']).returns({
|
|
109
|
-
stdout: 'i686'
|
|
110
|
-
});
|
|
111
|
-
let arch = await _index.system.arch();
|
|
112
|
-
arch.should.equal('32');
|
|
113
|
-
mocks[SANDBOX].verify();
|
|
114
|
-
});
|
|
115
|
-
it('should return correct architecture if it is a 64 bit Windows', async function () {
|
|
116
|
-
mocks.os.expects('type').thrice().returns('Windows_NT');
|
|
117
|
-
mocks.system.expects('isOSWin64').once().returns(true);
|
|
118
|
-
let arch = await _index.system.arch();
|
|
119
|
-
arch.should.equal('64');
|
|
120
|
-
mocks[SANDBOX].verify();
|
|
121
|
-
});
|
|
122
|
-
it('should return correct architecture if it is a 32 bit Windows', async function () {
|
|
123
|
-
mocks.os.expects('type').thrice().returns('Windows_NT');
|
|
124
|
-
mocks.system.expects('isOSWin64').once().returns(false);
|
|
125
|
-
let arch = await _index.system.arch();
|
|
126
|
-
arch.should.equal('32');
|
|
127
|
-
mocks[SANDBOX].verify();
|
|
128
|
-
});
|
|
129
|
-
});
|
|
130
|
-
it('should know architecture', function () {
|
|
131
|
-
return _index.system.arch();
|
|
132
|
-
});
|
|
133
|
-
});require('source-map-support').install();
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["test/system-specs.js"],"names":["sandbox","tpMock","osMock","SANDBOX","Symbol","mocks","libs","teen_process","os","system","describe","beforeEach","sinon","mock","afterEach","verify","it","expects","returns","isWindows","should","be","true","isMac","twice","isLinux","once","withExactArgs","stdout","macOsxVersion","eventually","equal","invalidOsx","rejectedWith","RegExp","_","escapeRegExp","createSandbox","key","value","toPairs","restore","thrice","arch"],"mappings":"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","sourcesContent":["\nimport { system } from '../lib/index.js';\nimport os from 'os';\nimport sinon from 'sinon';\nimport * as teen_process from 'teen_process';\nimport _ from 'lodash';\n\n\nlet sandbox, tpMock, osMock = null;\nlet SANDBOX = Symbol();\nlet mocks = {};\nlet libs = {teen_process, os, system};\n\ndescribe('system', function () {\n  describe('isX functions', function () {\n    beforeEach(function () {\n      osMock = sinon.mock(os);\n    });\n    afterEach(function () {\n      osMock.verify();\n    });\n\n    it('should correctly return Windows System if it is a Windows', function () {\n      osMock.expects('type').returns('Windows_NT');\n      system.isWindows().should.be.true;\n    });\n\n    it('should correctly return Mac if it is a Mac', function () {\n      osMock.expects('type').returns('Darwin');\n      system.isMac().should.be.true;\n    });\n\n    it('should correctly return Linux if it is a Linux', function () {\n      osMock.expects('type').twice().returns('Linux');\n      system.isLinux().should.be.true;\n    });\n  });\n\n  describe('mac OSX version', function () {\n    beforeEach(function () {\n      tpMock = sinon.mock(teen_process);\n    });\n    afterEach(function () {\n      tpMock.verify();\n    });\n\n    it('should return correct version for 10.10.5', async function () {\n      tpMock.expects('exec').once().withExactArgs('sw_vers', ['-productVersion']).returns({stdout: '10.10.5'});\n      await system.macOsxVersion().should.eventually.equal('10.10');\n    });\n\n    it('should return correct version for 10.12', async function () {\n      tpMock.expects('exec').once().withExactArgs('sw_vers', ['-productVersion']).returns({stdout: '10.12.0'});\n      await system.macOsxVersion().should.eventually.equal('10.12');\n    });\n\n    it('should return correct version for 10.12 with newline', async function () {\n      tpMock.expects('exec').once().withExactArgs('sw_vers', ['-productVersion']).returns({stdout: '10.12   \\n'});\n      await system.macOsxVersion().should.eventually.equal('10.12');\n    });\n\n    it(\"should throw an error if OSX version can't be determined\", async function () {\n      let invalidOsx = 'error getting operation system version blabla';\n      tpMock.expects('exec').once().withExactArgs('sw_vers', ['-productVersion']).returns({stdout: invalidOsx});\n      await system.macOsxVersion().should.eventually.be.rejectedWith(new RegExp(_.escapeRegExp(invalidOsx)));\n    });\n  });\n\n  describe('architecture', function () {\n    beforeEach(function () {\n      sandbox = sinon.createSandbox();\n      mocks[SANDBOX] = sandbox;\n      for (let [key, value] of _.toPairs(libs)) {\n        mocks[key] = sandbox.mock(value);\n      }\n    });\n\n    afterEach(function () {\n      sandbox.restore();\n    });\n\n    it('should return correct architecture if it is a 64 bit Mac/Linux', async function () {\n      mocks.os.expects('type').thrice().returns('Darwin');\n      mocks.teen_process.expects('exec').once().withExactArgs('uname', ['-m']).returns({stdout: 'x86_64'});\n      let arch = await system.arch();\n      arch.should.equal('64');\n      mocks[SANDBOX].verify();\n    });\n\n    it('should return correct architecture if it is a 32 bit Mac/Linux', async function () {\n      mocks.os.expects('type').twice().returns('Linux');\n      mocks.teen_process.expects('exec').once().withExactArgs('uname', ['-m']).returns({stdout: 'i686'});\n      let arch = await system.arch();\n      arch.should.equal('32');\n      mocks[SANDBOX].verify();\n    });\n\n    it('should return correct architecture if it is a 64 bit Windows', async function () {\n      mocks.os.expects('type').thrice().returns('Windows_NT');\n      mocks.system.expects('isOSWin64').once().returns(true);\n      let arch = await system.arch();\n      arch.should.equal('64');\n      mocks[SANDBOX].verify();\n    });\n\n    it('should return correct architecture if it is a 32 bit Windows', async function () {\n      mocks.os.expects('type').thrice().returns('Windows_NT');\n      mocks.system.expects('isOSWin64').once().returns(false);\n      let arch = await system.arch();\n      arch.should.equal('32');\n      mocks[SANDBOX].verify();\n    });\n  });\n\n  it('should know architecture', function () {\n    return system.arch();\n  });\n});\n"],"file":"test/system-specs.js","sourceRoot":"../.."}
|
|
@@ -1,86 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
require("source-map-support/register");
|
|
4
|
-
|
|
5
|
-
var _index = require("../lib/index.js");
|
|
6
|
-
|
|
7
|
-
describe('tempdir', function () {
|
|
8
|
-
afterEach(function () {
|
|
9
|
-
delete process.env.APPIUM_TMP_DIR;
|
|
10
|
-
});
|
|
11
|
-
it('should be able to generate a path', async function () {
|
|
12
|
-
const path = await _index.tempDir.path({
|
|
13
|
-
prefix: 'myfile',
|
|
14
|
-
suffix: '.tmp'
|
|
15
|
-
});
|
|
16
|
-
path.should.exist;
|
|
17
|
-
path.should.include('myfile.tmp');
|
|
18
|
-
});
|
|
19
|
-
it('should be able to generate a path with process.env.APPIUM_TMP_DIR', async function () {
|
|
20
|
-
const preRootDirPath = await _index.tempDir.openDir();
|
|
21
|
-
process.env.APPIUM_TMP_DIR = preRootDirPath;
|
|
22
|
-
const path = await _index.tempDir.path({
|
|
23
|
-
prefix: 'myfile',
|
|
24
|
-
suffix: '.tmp'
|
|
25
|
-
});
|
|
26
|
-
path.should.exist;
|
|
27
|
-
path.should.include(preRootDirPath);
|
|
28
|
-
path.should.include('myfile.tmp');
|
|
29
|
-
});
|
|
30
|
-
it('should be able to create a temp file', async function () {
|
|
31
|
-
let res = await _index.tempDir.open({
|
|
32
|
-
prefix: 'my-test-file',
|
|
33
|
-
suffix: '.zip'
|
|
34
|
-
});
|
|
35
|
-
res.should.exist;
|
|
36
|
-
res.path.should.exist;
|
|
37
|
-
res.path.should.include('my-test-file.zip');
|
|
38
|
-
res.fd.should.exist;
|
|
39
|
-
await _index.fs.exists(res.path).should.eventually.be.ok;
|
|
40
|
-
});
|
|
41
|
-
it('should be able to create a temp file with process.env.APPIUM_TMP_DIR', async function () {
|
|
42
|
-
const preRootDirPath = await _index.tempDir.openDir();
|
|
43
|
-
process.env.APPIUM_TMP_DIR = preRootDirPath;
|
|
44
|
-
let res = await _index.tempDir.open({
|
|
45
|
-
prefix: 'my-test-file',
|
|
46
|
-
suffix: '.zip'
|
|
47
|
-
});
|
|
48
|
-
res.should.exist;
|
|
49
|
-
res.path.should.exist;
|
|
50
|
-
res.path.should.include(preRootDirPath);
|
|
51
|
-
res.path.should.include('my-test-file.zip');
|
|
52
|
-
res.fd.should.exist;
|
|
53
|
-
await _index.fs.exists(res.path).should.eventually.be.ok;
|
|
54
|
-
});
|
|
55
|
-
it('should generate a random temp dir', async function () {
|
|
56
|
-
let res = await _index.tempDir.openDir();
|
|
57
|
-
res.should.be.a('string');
|
|
58
|
-
await _index.fs.exists(res).should.eventually.be.ok;
|
|
59
|
-
let res2 = await _index.tempDir.openDir();
|
|
60
|
-
await _index.fs.exists(res2).should.eventually.be.ok;
|
|
61
|
-
res.should.not.equal(res2);
|
|
62
|
-
});
|
|
63
|
-
it('should generate a random temp dir, but the same with process.env.APPIUM_TMP_DIR', async function () {
|
|
64
|
-
const preRootDirPath = await _index.tempDir.openDir();
|
|
65
|
-
process.env.APPIUM_TMP_DIR = preRootDirPath;
|
|
66
|
-
const res = await _index.tempDir.openDir();
|
|
67
|
-
res.should.be.a('string');
|
|
68
|
-
await _index.fs.exists(res).should.eventually.be.ok;
|
|
69
|
-
const res2 = await _index.tempDir.openDir();
|
|
70
|
-
await _index.fs.exists(res2).should.eventually.be.ok;
|
|
71
|
-
res.should.include(preRootDirPath);
|
|
72
|
-
res2.should.include(preRootDirPath);
|
|
73
|
-
res.should.not.equal(res2);
|
|
74
|
-
});
|
|
75
|
-
it('should generate one temp dir used for the life of the process', async function () {
|
|
76
|
-
let res = await _index.tempDir.staticDir();
|
|
77
|
-
res.should.be.a('string');
|
|
78
|
-
await _index.fs.exists(res).should.eventually.be.ok;
|
|
79
|
-
let res2 = await _index.tempDir.staticDir();
|
|
80
|
-
await _index.fs.exists(res2).should.eventually.be.ok;
|
|
81
|
-
res.should.equal(res2);
|
|
82
|
-
});
|
|
83
|
-
});require('source-map-support').install();
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["test/tempdir-specs.js"],"names":["describe","afterEach","process","env","APPIUM_TMP_DIR","it","path","tempDir","prefix","suffix","should","exist","include","preRootDirPath","openDir","res","open","fd","fs","exists","eventually","be","ok","a","res2","not","equal","staticDir"],"mappings":";;;;AACA;;AAGAA,QAAQ,CAAC,SAAD,EAAY,YAAY;AAC9BC,EAAAA,SAAS,CAAC,YAAY;AAEpB,WAAOC,OAAO,CAACC,GAAR,CAAYC,cAAnB;AACD,GAHQ,CAAT;AAKAC,EAAAA,EAAE,CAAC,mCAAD,EAAsC,kBAAkB;AACxD,UAAMC,IAAI,GAAG,MAAMC,eAAQD,IAAR,CAAa;AAACE,MAAAA,MAAM,EAAE,QAAT;AAAmBC,MAAAA,MAAM,EAAE;AAA3B,KAAb,CAAnB;AACAH,IAAAA,IAAI,CAACI,MAAL,CAAYC,KAAZ;AACAL,IAAAA,IAAI,CAACI,MAAL,CAAYE,OAAZ,CAAoB,YAApB;AACD,GAJC,CAAF;AAMAP,EAAAA,EAAE,CAAC,mEAAD,EAAsE,kBAAkB;AACxF,UAAMQ,cAAc,GAAG,MAAMN,eAAQO,OAAR,EAA7B;AACAZ,IAAAA,OAAO,CAACC,GAAR,CAAYC,cAAZ,GAA6BS,cAA7B;AAEA,UAAMP,IAAI,GAAG,MAAMC,eAAQD,IAAR,CAAa;AAACE,MAAAA,MAAM,EAAE,QAAT;AAAmBC,MAAAA,MAAM,EAAE;AAA3B,KAAb,CAAnB;AACAH,IAAAA,IAAI,CAACI,MAAL,CAAYC,KAAZ;AACAL,IAAAA,IAAI,CAACI,MAAL,CAAYE,OAAZ,CAAoBC,cAApB;AACAP,IAAAA,IAAI,CAACI,MAAL,CAAYE,OAAZ,CAAoB,YAApB;AACD,GARC,CAAF;AAUAP,EAAAA,EAAE,CAAC,sCAAD,EAAyC,kBAAkB;AAC3D,QAAIU,GAAG,GAAG,MAAMR,eAAQS,IAAR,CAAa;AAACR,MAAAA,MAAM,EAAE,cAAT;AAAyBC,MAAAA,MAAM,EAAE;AAAjC,KAAb,CAAhB;AACAM,IAAAA,GAAG,CAACL,MAAJ,CAAWC,KAAX;AACAI,IAAAA,GAAG,CAACT,IAAJ,CAASI,MAAT,CAAgBC,KAAhB;AACAI,IAAAA,GAAG,CAACT,IAAJ,CAASI,MAAT,CAAgBE,OAAhB,CAAwB,kBAAxB;AACAG,IAAAA,GAAG,CAACE,EAAJ,CAAOP,MAAP,CAAcC,KAAd;AACA,UAAMO,UAAGC,MAAH,CAAUJ,GAAG,CAACT,IAAd,EAAoBI,MAApB,CAA2BU,UAA3B,CAAsCC,EAAtC,CAAyCC,EAA/C;AACD,GAPC,CAAF;AASAjB,EAAAA,EAAE,CAAC,sEAAD,EAAyE,kBAAkB;AAC3F,UAAMQ,cAAc,GAAG,MAAMN,eAAQO,OAAR,EAA7B;AACAZ,IAAAA,OAAO,CAACC,GAAR,CAAYC,cAAZ,GAA6BS,cAA7B;AAEA,QAAIE,GAAG,GAAG,MAAMR,eAAQS,IAAR,CAAa;AAACR,MAAAA,MAAM,EAAE,cAAT;AAAyBC,MAAAA,MAAM,EAAE;AAAjC,KAAb,CAAhB;AACAM,IAAAA,GAAG,CAACL,MAAJ,CAAWC,KAAX;AACAI,IAAAA,GAAG,CAACT,IAAJ,CAASI,MAAT,CAAgBC,KAAhB;AACAI,IAAAA,GAAG,CAACT,IAAJ,CAASI,MAAT,CAAgBE,OAAhB,CAAwBC,cAAxB;AACAE,IAAAA,GAAG,CAACT,IAAJ,CAASI,MAAT,CAAgBE,OAAhB,CAAwB,kBAAxB;AACAG,IAAAA,GAAG,CAACE,EAAJ,CAAOP,MAAP,CAAcC,KAAd;AACA,UAAMO,UAAGC,MAAH,CAAUJ,GAAG,CAACT,IAAd,EAAoBI,MAApB,CAA2BU,UAA3B,CAAsCC,EAAtC,CAAyCC,EAA/C;AACD,GAXC,CAAF;AAaAjB,EAAAA,EAAE,CAAC,mCAAD,EAAsC,kBAAkB;AACxD,QAAIU,GAAG,GAAG,MAAMR,eAAQO,OAAR,EAAhB;AACAC,IAAAA,GAAG,CAACL,MAAJ,CAAWW,EAAX,CAAcE,CAAd,CAAgB,QAAhB;AACA,UAAML,UAAGC,MAAH,CAAUJ,GAAV,EAAeL,MAAf,CAAsBU,UAAtB,CAAiCC,EAAjC,CAAoCC,EAA1C;AACA,QAAIE,IAAI,GAAG,MAAMjB,eAAQO,OAAR,EAAjB;AACA,UAAMI,UAAGC,MAAH,CAAUK,IAAV,EAAgBd,MAAhB,CAAuBU,UAAvB,CAAkCC,EAAlC,CAAqCC,EAA3C;AACAP,IAAAA,GAAG,CAACL,MAAJ,CAAWe,GAAX,CAAeC,KAAf,CAAqBF,IAArB;AACD,GAPC,CAAF;AASAnB,EAAAA,EAAE,CAAC,iFAAD,EAAoF,kBAAkB;AACtG,UAAMQ,cAAc,GAAG,MAAMN,eAAQO,OAAR,EAA7B;AACAZ,IAAAA,OAAO,CAACC,GAAR,CAAYC,cAAZ,GAA6BS,cAA7B;AAEA,UAAME,GAAG,GAAG,MAAMR,eAAQO,OAAR,EAAlB;AACAC,IAAAA,GAAG,CAACL,MAAJ,CAAWW,EAAX,CAAcE,CAAd,CAAgB,QAAhB;AACA,UAAML,UAAGC,MAAH,CAAUJ,GAAV,EAAeL,MAAf,CAAsBU,UAAtB,CAAiCC,EAAjC,CAAoCC,EAA1C;AACA,UAAME,IAAI,GAAG,MAAMjB,eAAQO,OAAR,EAAnB;AACA,UAAMI,UAAGC,MAAH,CAAUK,IAAV,EAAgBd,MAAhB,CAAuBU,UAAvB,CAAkCC,EAAlC,CAAqCC,EAA3C;AACAP,IAAAA,GAAG,CAACL,MAAJ,CAAWE,OAAX,CAAmBC,cAAnB;AACAW,IAAAA,IAAI,CAACd,MAAL,CAAYE,OAAZ,CAAoBC,cAApB;AACAE,IAAAA,GAAG,CAACL,MAAJ,CAAWe,GAAX,CAAeC,KAAf,CAAqBF,IAArB;AACD,GAZC,CAAF;AAcAnB,EAAAA,EAAE,CAAC,+DAAD,EAAkE,kBAAkB;AACpF,QAAIU,GAAG,GAAG,MAAMR,eAAQoB,SAAR,EAAhB;AACAZ,IAAAA,GAAG,CAACL,MAAJ,CAAWW,EAAX,CAAcE,CAAd,CAAgB,QAAhB;AACA,UAAML,UAAGC,MAAH,CAAUJ,GAAV,EAAeL,MAAf,CAAsBU,UAAtB,CAAiCC,EAAjC,CAAoCC,EAA1C;AACA,QAAIE,IAAI,GAAG,MAAMjB,eAAQoB,SAAR,EAAjB;AACA,UAAMT,UAAGC,MAAH,CAAUK,IAAV,EAAgBd,MAAhB,CAAuBU,UAAvB,CAAkCC,EAAlC,CAAqCC,EAA3C;AACAP,IAAAA,GAAG,CAACL,MAAJ,CAAWgB,KAAX,CAAiBF,IAAjB;AACD,GAPC,CAAF;AAQD,CA3EO,CAAR","sourcesContent":["\nimport { tempDir, fs } from '../lib/index.js';\n\n\ndescribe('tempdir', function () {\n  afterEach(function () {\n    // set the process env as undefiend\n    delete process.env.APPIUM_TMP_DIR;\n  });\n\n  it('should be able to generate a path', async function () {\n    const path = await tempDir.path({prefix: 'myfile', suffix: '.tmp'});\n    path.should.exist;\n    path.should.include('myfile.tmp');\n  });\n\n  it('should be able to generate a path with process.env.APPIUM_TMP_DIR', async function () {\n    const preRootDirPath = await tempDir.openDir();\n    process.env.APPIUM_TMP_DIR = preRootDirPath;\n\n    const path = await tempDir.path({prefix: 'myfile', suffix: '.tmp'});\n    path.should.exist;\n    path.should.include(preRootDirPath);\n    path.should.include('myfile.tmp');\n  });\n\n  it('should be able to create a temp file', async function () {\n    let res = await tempDir.open({prefix: 'my-test-file', suffix: '.zip'});\n    res.should.exist;\n    res.path.should.exist;\n    res.path.should.include('my-test-file.zip');\n    res.fd.should.exist;\n    await fs.exists(res.path).should.eventually.be.ok;\n  });\n\n  it('should be able to create a temp file with process.env.APPIUM_TMP_DIR', async function () {\n    const preRootDirPath = await tempDir.openDir();\n    process.env.APPIUM_TMP_DIR = preRootDirPath;\n\n    let res = await tempDir.open({prefix: 'my-test-file', suffix: '.zip'});\n    res.should.exist;\n    res.path.should.exist;\n    res.path.should.include(preRootDirPath);\n    res.path.should.include('my-test-file.zip');\n    res.fd.should.exist;\n    await fs.exists(res.path).should.eventually.be.ok;\n  });\n\n  it('should generate a random temp dir', async function () {\n    let res = await tempDir.openDir();\n    res.should.be.a('string');\n    await fs.exists(res).should.eventually.be.ok;\n    let res2 = await tempDir.openDir();\n    await fs.exists(res2).should.eventually.be.ok;\n    res.should.not.equal(res2);\n  });\n\n  it('should generate a random temp dir, but the same with process.env.APPIUM_TMP_DIR', async function () {\n    const preRootDirPath = await tempDir.openDir();\n    process.env.APPIUM_TMP_DIR = preRootDirPath;\n\n    const res = await tempDir.openDir();\n    res.should.be.a('string');\n    await fs.exists(res).should.eventually.be.ok;\n    const res2 = await tempDir.openDir();\n    await fs.exists(res2).should.eventually.be.ok;\n    res.should.include(preRootDirPath);\n    res2.should.include(preRootDirPath);\n    res.should.not.equal(res2);\n  });\n\n  it('should generate one temp dir used for the life of the process', async function () {\n    let res = await tempDir.staticDir();\n    res.should.be.a('string');\n    await fs.exists(res).should.eventually.be.ok;\n    let res2 = await tempDir.staticDir();\n    await fs.exists(res2).should.eventually.be.ok;\n    res.should.equal(res2);\n  });\n});\n"],"file":"test/tempdir-specs.js","sourceRoot":"../.."}
|
|
@@ -1,125 +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 _sinon = _interopRequireDefault(require("sinon"));
|
|
10
|
-
|
|
11
|
-
var _lib = require("../lib");
|
|
12
|
-
|
|
13
|
-
const expect = chai.expect;
|
|
14
|
-
describe('timing', function () {
|
|
15
|
-
let processMock;
|
|
16
|
-
afterEach(function () {
|
|
17
|
-
processMock.verify();
|
|
18
|
-
});
|
|
19
|
-
describe('no bigint', function () {
|
|
20
|
-
const bigintFn = process.hrtime.bigint;
|
|
21
|
-
before(function () {
|
|
22
|
-
if (_lodash.default.isFunction(bigintFn)) {
|
|
23
|
-
delete process.hrtime.bigint;
|
|
24
|
-
}
|
|
25
|
-
});
|
|
26
|
-
beforeEach(function () {
|
|
27
|
-
processMock = _sinon.default.mock(process);
|
|
28
|
-
});
|
|
29
|
-
after(function () {
|
|
30
|
-
if (_lodash.default.isFunction(bigintFn)) {
|
|
31
|
-
process.hrtime.bigint = bigintFn;
|
|
32
|
-
}
|
|
33
|
-
});
|
|
34
|
-
it('should get a start time as array', function () {
|
|
35
|
-
const timer = new _lib.timing.Timer().start();
|
|
36
|
-
_lodash.default.isArray(timer.startTime).should.be.true;
|
|
37
|
-
});
|
|
38
|
-
it('should get a duration', function () {
|
|
39
|
-
const timer = new _lib.timing.Timer().start();
|
|
40
|
-
const duration = timer.getDuration();
|
|
41
|
-
_lodash.default.isNumber(duration.nanos).should.be.true;
|
|
42
|
-
});
|
|
43
|
-
it('should get correct seconds', function () {
|
|
44
|
-
processMock.expects('hrtime').twice().onFirstCall().returns([12, 12345]).onSecondCall().returns([13, 54321]);
|
|
45
|
-
const timer = new _lib.timing.Timer().start();
|
|
46
|
-
const duration = timer.getDuration();
|
|
47
|
-
duration.asSeconds.should.eql(13.000054321);
|
|
48
|
-
});
|
|
49
|
-
it('should get correct milliseconds', function () {
|
|
50
|
-
processMock.expects('hrtime').twice().onFirstCall().returns([12, 12345]).onSecondCall().returns([13, 54321]);
|
|
51
|
-
const timer = new _lib.timing.Timer().start();
|
|
52
|
-
const duration = timer.getDuration();
|
|
53
|
-
duration.asMilliSeconds.should.eql(13000.054321);
|
|
54
|
-
});
|
|
55
|
-
it('should get correct nanoseconds', function () {
|
|
56
|
-
processMock.expects('hrtime').twice().onFirstCall().returns([12, 12345]).onSecondCall().returns([13, 54321]);
|
|
57
|
-
const timer = new _lib.timing.Timer().start();
|
|
58
|
-
const duration = timer.getDuration();
|
|
59
|
-
duration.asNanoSeconds.should.eql(13000054321);
|
|
60
|
-
});
|
|
61
|
-
it('should error if the timer was not started', function () {
|
|
62
|
-
const timer = new _lib.timing.Timer();
|
|
63
|
-
expect(() => timer.getDuration()).to.throw('Unable to get duration');
|
|
64
|
-
});
|
|
65
|
-
it('should error if start time is a number', function () {
|
|
66
|
-
const timer = new _lib.timing.Timer();
|
|
67
|
-
timer._startTime = 12345;
|
|
68
|
-
expect(() => timer.getDuration()).to.throw('Unable to get duration');
|
|
69
|
-
});
|
|
70
|
-
});
|
|
71
|
-
describe('bigint', function () {
|
|
72
|
-
beforeEach(function () {
|
|
73
|
-
if (!_lodash.default.isFunction(process.hrtime.bigint)) {
|
|
74
|
-
return this.skip();
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
processMock = _sinon.default.mock(process.hrtime);
|
|
78
|
-
});
|
|
79
|
-
|
|
80
|
-
function setupMocks(once = false) {
|
|
81
|
-
if (once) {
|
|
82
|
-
processMock.expects('bigint').once().onFirstCall().returns(BigInt(1172941153404030));
|
|
83
|
-
} else {
|
|
84
|
-
processMock.expects('bigint').twice().onFirstCall().returns(BigInt(1172941153404030)).onSecondCall().returns(BigInt(1172951164887132));
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
it('should get a duration', function () {
|
|
89
|
-
setupMocks();
|
|
90
|
-
const timer = new _lib.timing.Timer().start();
|
|
91
|
-
const duration = timer.getDuration();
|
|
92
|
-
_lodash.default.isNumber(duration.nanos).should.be.true;
|
|
93
|
-
});
|
|
94
|
-
it('should get correct seconds', function () {
|
|
95
|
-
setupMocks();
|
|
96
|
-
const timer = new _lib.timing.Timer().start();
|
|
97
|
-
const duration = timer.getDuration();
|
|
98
|
-
duration.asSeconds.should.be.eql(10.011483102);
|
|
99
|
-
});
|
|
100
|
-
it('should get correct milliseconds', function () {
|
|
101
|
-
setupMocks();
|
|
102
|
-
const timer = new _lib.timing.Timer().start();
|
|
103
|
-
const duration = timer.getDuration();
|
|
104
|
-
duration.asMilliSeconds.should.be.eql(10011.483102);
|
|
105
|
-
});
|
|
106
|
-
it('should get correct nanoseconds', function () {
|
|
107
|
-
setupMocks();
|
|
108
|
-
const timer = new _lib.timing.Timer().start();
|
|
109
|
-
const duration = timer.getDuration();
|
|
110
|
-
duration.asNanoSeconds.should.be.eql(10011483102);
|
|
111
|
-
});
|
|
112
|
-
it('should error if the timer was not started', function () {
|
|
113
|
-
const timer = new _lib.timing.Timer();
|
|
114
|
-
expect(() => timer.getDuration()).to.throw('Unable to get duration');
|
|
115
|
-
});
|
|
116
|
-
it('should error if passing in a non-bigint', function () {
|
|
117
|
-
const timer = new _lib.timing.Timer();
|
|
118
|
-
timer._startTime = 12345;
|
|
119
|
-
expect(() => timer.getDuration()).to.throw('Unable to get duration');
|
|
120
|
-
});
|
|
121
|
-
});
|
|
122
|
-
});require('source-map-support').install();
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["test/timing-specs.js"],"names":["expect","chai","describe","processMock","afterEach","verify","bigintFn","process","hrtime","bigint","before","_","isFunction","beforeEach","sinon","mock","after","it","timer","timing","Timer","start","isArray","startTime","should","be","true","duration","getDuration","isNumber","nanos","expects","twice","onFirstCall","returns","onSecondCall","asSeconds","eql","asMilliSeconds","asNanoSeconds","to","throw","_startTime","skip","setupMocks","once","BigInt"],"mappings":";;;;;;AAAA;;AACA;;AACA;;AAGA,MAAMA,MAAM,GAAGC,IAAI,CAACD,MAApB;AAEAE,QAAQ,CAAC,QAAD,EAAW,YAAY;AAC7B,MAAIC,WAAJ;AACAC,EAAAA,SAAS,CAAC,YAAY;AACpBD,IAAAA,WAAW,CAACE,MAAZ;AACD,GAFQ,CAAT;AAIAH,EAAAA,QAAQ,CAAC,WAAD,EAAc,YAAY;AAChC,UAAMI,QAAQ,GAAGC,OAAO,CAACC,MAAR,CAAeC,MAAhC;AACAC,IAAAA,MAAM,CAAC,YAAY;AAEjB,UAAIC,gBAAEC,UAAF,CAAaN,QAAb,CAAJ,EAA4B;AAC1B,eAAOC,OAAO,CAACC,MAAR,CAAeC,MAAtB;AACD;AACF,KALK,CAAN;AAMAI,IAAAA,UAAU,CAAC,YAAY;AACrBV,MAAAA,WAAW,GAAGW,eAAMC,IAAN,CAAWR,OAAX,CAAd;AACD,KAFS,CAAV;AAGAS,IAAAA,KAAK,CAAC,YAAY;AAChB,UAAIL,gBAAEC,UAAF,CAAaN,QAAb,CAAJ,EAA4B;AAC1BC,QAAAA,OAAO,CAACC,MAAR,CAAeC,MAAf,GAAwBH,QAAxB;AACD;AACF,KAJI,CAAL;AAKAW,IAAAA,EAAE,CAAC,kCAAD,EAAqC,YAAY;AACjD,YAAMC,KAAK,GAAG,IAAIC,YAAOC,KAAX,GAAmBC,KAAnB,EAAd;AACAV,sBAAEW,OAAF,CAAUJ,KAAK,CAACK,SAAhB,EAA2BC,MAA3B,CAAkCC,EAAlC,CAAqCC,IAArC;AACD,KAHC,CAAF;AAIAT,IAAAA,EAAE,CAAC,uBAAD,EAA0B,YAAY;AACtC,YAAMC,KAAK,GAAG,IAAIC,YAAOC,KAAX,GAAmBC,KAAnB,EAAd;AACA,YAAMM,QAAQ,GAAGT,KAAK,CAACU,WAAN,EAAjB;AACAjB,sBAAEkB,QAAF,CAAWF,QAAQ,CAACG,KAApB,EAA2BN,MAA3B,CAAkCC,EAAlC,CAAqCC,IAArC;AACD,KAJC,CAAF;AAKAT,IAAAA,EAAE,CAAC,4BAAD,EAA+B,YAAY;AAC3Cd,MAAAA,WAAW,CAAC4B,OAAZ,CAAoB,QAApB,EAA8BC,KAA9B,GACGC,WADH,GACiBC,OADjB,CACyB,CAAC,EAAD,EAAK,KAAL,CADzB,EAEGC,YAFH,GAEkBD,OAFlB,CAE0B,CAAC,EAAD,EAAK,KAAL,CAF1B;AAIA,YAAMhB,KAAK,GAAG,IAAIC,YAAOC,KAAX,GAAmBC,KAAnB,EAAd;AACA,YAAMM,QAAQ,GAAGT,KAAK,CAACU,WAAN,EAAjB;AACAD,MAAAA,QAAQ,CAACS,SAAT,CAAmBZ,MAAnB,CAA0Ba,GAA1B,CAA8B,YAA9B;AACD,KARC,CAAF;AASApB,IAAAA,EAAE,CAAC,iCAAD,EAAoC,YAAY;AAChDd,MAAAA,WAAW,CAAC4B,OAAZ,CAAoB,QAApB,EAA8BC,KAA9B,GACGC,WADH,GACiBC,OADjB,CACyB,CAAC,EAAD,EAAK,KAAL,CADzB,EAEGC,YAFH,GAEkBD,OAFlB,CAE0B,CAAC,EAAD,EAAK,KAAL,CAF1B;AAIA,YAAMhB,KAAK,GAAG,IAAIC,YAAOC,KAAX,GAAmBC,KAAnB,EAAd;AACA,YAAMM,QAAQ,GAAGT,KAAK,CAACU,WAAN,EAAjB;AACAD,MAAAA,QAAQ,CAACW,cAAT,CAAwBd,MAAxB,CAA+Ba,GAA/B,CAAmC,YAAnC;AACD,KARC,CAAF;AASApB,IAAAA,EAAE,CAAC,gCAAD,EAAmC,YAAY;AAC/Cd,MAAAA,WAAW,CAAC4B,OAAZ,CAAoB,QAApB,EAA8BC,KAA9B,GACGC,WADH,GACiBC,OADjB,CACyB,CAAC,EAAD,EAAK,KAAL,CADzB,EAEGC,YAFH,GAEkBD,OAFlB,CAE0B,CAAC,EAAD,EAAK,KAAL,CAF1B;AAIA,YAAMhB,KAAK,GAAG,IAAIC,YAAOC,KAAX,GAAmBC,KAAnB,EAAd;AACA,YAAMM,QAAQ,GAAGT,KAAK,CAACU,WAAN,EAAjB;AACAD,MAAAA,QAAQ,CAACY,aAAT,CAAuBf,MAAvB,CAA8Ba,GAA9B,CAAkC,WAAlC;AACD,KARC,CAAF;AASApB,IAAAA,EAAE,CAAC,2CAAD,EAA8C,YAAY;AAC1D,YAAMC,KAAK,GAAG,IAAIC,YAAOC,KAAX,EAAd;AACApB,MAAAA,MAAM,CAAC,MAAMkB,KAAK,CAACU,WAAN,EAAP,CAAN,CACGY,EADH,CACMC,KADN,CACY,wBADZ;AAED,KAJC,CAAF;AAKAxB,IAAAA,EAAE,CAAC,wCAAD,EAA2C,YAAY;AACvD,YAAMC,KAAK,GAAG,IAAIC,YAAOC,KAAX,EAAd;AACAF,MAAAA,KAAK,CAACwB,UAAN,GAAmB,KAAnB;AACA1C,MAAAA,MAAM,CAAC,MAAMkB,KAAK,CAACU,WAAN,EAAP,CAAN,CACGY,EADH,CACMC,KADN,CACY,wBADZ;AAED,KALC,CAAF;AAMD,GA/DO,CAAR;AAgEAvC,EAAAA,QAAQ,CAAC,QAAD,EAAW,YAAY;AAC7BW,IAAAA,UAAU,CAAC,YAAY;AAKrB,UAAI,CAACF,gBAAEC,UAAF,CAAaL,OAAO,CAACC,MAAR,CAAeC,MAA5B,CAAL,EAA0C;AACxC,eAAO,KAAKkC,IAAL,EAAP;AACD;;AACDxC,MAAAA,WAAW,GAAGW,eAAMC,IAAN,CAAWR,OAAO,CAACC,MAAnB,CAAd;AACD,KATS,CAAV;;AAWA,aAASoC,UAAT,CAAqBC,IAAI,GAAG,KAA5B,EAAmC;AACjC,UAAIA,IAAJ,EAAU;AACR1C,QAAAA,WAAW,CAAC4B,OAAZ,CAAoB,QAApB,EAA8Bc,IAA9B,GACGZ,WADH,GACiBC,OADjB,CACyBY,MAAM,CAAC,gBAAD,CAD/B;AAED,OAHD,MAGO;AACL3C,QAAAA,WAAW,CAAC4B,OAAZ,CAAoB,QAApB,EAA8BC,KAA9B,GACGC,WADH,GACiBC,OADjB,CACyBY,MAAM,CAAC,gBAAD,CAD/B,EAEGX,YAFH,GAEkBD,OAFlB,CAE0BY,MAAM,CAAC,gBAAD,CAFhC;AAGD;AACF;;AAED7B,IAAAA,EAAE,CAAC,uBAAD,EAA0B,YAAY;AACtC2B,MAAAA,UAAU;AAEV,YAAM1B,KAAK,GAAG,IAAIC,YAAOC,KAAX,GAAmBC,KAAnB,EAAd;AACA,YAAMM,QAAQ,GAAGT,KAAK,CAACU,WAAN,EAAjB;AACAjB,sBAAEkB,QAAF,CAAWF,QAAQ,CAACG,KAApB,EAA2BN,MAA3B,CAAkCC,EAAlC,CAAqCC,IAArC;AACD,KANC,CAAF;AAOAT,IAAAA,EAAE,CAAC,4BAAD,EAA+B,YAAY;AAC3C2B,MAAAA,UAAU;AAEV,YAAM1B,KAAK,GAAG,IAAIC,YAAOC,KAAX,GAAmBC,KAAnB,EAAd;AACA,YAAMM,QAAQ,GAAGT,KAAK,CAACU,WAAN,EAAjB;AACAD,MAAAA,QAAQ,CAACS,SAAT,CAAmBZ,MAAnB,CAA0BC,EAA1B,CAA6BY,GAA7B,CAAiC,YAAjC;AACD,KANC,CAAF;AAOApB,IAAAA,EAAE,CAAC,iCAAD,EAAoC,YAAY;AAChD2B,MAAAA,UAAU;AAEV,YAAM1B,KAAK,GAAG,IAAIC,YAAOC,KAAX,GAAmBC,KAAnB,EAAd;AACA,YAAMM,QAAQ,GAAGT,KAAK,CAACU,WAAN,EAAjB;AACAD,MAAAA,QAAQ,CAACW,cAAT,CAAwBd,MAAxB,CAA+BC,EAA/B,CAAkCY,GAAlC,CAAsC,YAAtC;AACD,KANC,CAAF;AAOApB,IAAAA,EAAE,CAAC,gCAAD,EAAmC,YAAY;AAC/C2B,MAAAA,UAAU;AAEV,YAAM1B,KAAK,GAAG,IAAIC,YAAOC,KAAX,GAAmBC,KAAnB,EAAd;AACA,YAAMM,QAAQ,GAAGT,KAAK,CAACU,WAAN,EAAjB;AACAD,MAAAA,QAAQ,CAACY,aAAT,CAAuBf,MAAvB,CAA8BC,EAA9B,CAAiCY,GAAjC,CAAqC,WAArC;AACD,KANC,CAAF;AAOApB,IAAAA,EAAE,CAAC,2CAAD,EAA8C,YAAY;AAC1D,YAAMC,KAAK,GAAG,IAAIC,YAAOC,KAAX,EAAd;AACApB,MAAAA,MAAM,CAAC,MAAMkB,KAAK,CAACU,WAAN,EAAP,CAAN,CACGY,EADH,CACMC,KADN,CACY,wBADZ;AAED,KAJC,CAAF;AAKAxB,IAAAA,EAAE,CAAC,yCAAD,EAA4C,YAAY;AACxD,YAAMC,KAAK,GAAG,IAAIC,YAAOC,KAAX,EAAd;AACAF,MAAAA,KAAK,CAACwB,UAAN,GAAmB,KAAnB;AACA1C,MAAAA,MAAM,CAAC,MAAMkB,KAAK,CAACU,WAAN,EAAP,CAAN,CACGY,EADH,CACMC,KADN,CACY,wBADZ;AAED,KALC,CAAF;AAMD,GA9DO,CAAR;AA+DD,CArIO,CAAR","sourcesContent":["import _ from 'lodash';\nimport sinon from 'sinon';\nimport { timing } from '../lib';\n\n\nconst expect = chai.expect;\n\ndescribe('timing', function () {\n  let processMock;\n  afterEach(function () {\n    processMock.verify();\n  });\n\n  describe('no bigint', function () {\n    const bigintFn = process.hrtime.bigint;\n    before(function () {\n      // if the system has BigInt support, remove it\n      if (_.isFunction(bigintFn)) {\n        delete process.hrtime.bigint;\n      }\n    });\n    beforeEach(function () {\n      processMock = sinon.mock(process);\n    });\n    after(function () {\n      if (_.isFunction(bigintFn)) {\n        process.hrtime.bigint = bigintFn;\n      }\n    });\n    it('should get a start time as array', function () {\n      const timer = new timing.Timer().start();\n      _.isArray(timer.startTime).should.be.true;\n    });\n    it('should get a duration', function () {\n      const timer = new timing.Timer().start();\n      const duration = timer.getDuration();\n      _.isNumber(duration.nanos).should.be.true;\n    });\n    it('should get correct seconds', function () {\n      processMock.expects('hrtime').twice()\n        .onFirstCall().returns([12, 12345])\n        .onSecondCall().returns([13, 54321]);\n\n      const timer = new timing.Timer().start();\n      const duration = timer.getDuration();\n      duration.asSeconds.should.eql(13.000054321);\n    });\n    it('should get correct milliseconds', function () {\n      processMock.expects('hrtime').twice()\n        .onFirstCall().returns([12, 12345])\n        .onSecondCall().returns([13, 54321]);\n\n      const timer = new timing.Timer().start();\n      const duration = timer.getDuration();\n      duration.asMilliSeconds.should.eql(13000.054321);\n    });\n    it('should get correct nanoseconds', function () {\n      processMock.expects('hrtime').twice()\n        .onFirstCall().returns([12, 12345])\n        .onSecondCall().returns([13, 54321]);\n\n      const timer = new timing.Timer().start();\n      const duration = timer.getDuration();\n      duration.asNanoSeconds.should.eql(13000054321);\n    });\n    it('should error if the timer was not started', function () {\n      const timer = new timing.Timer();\n      expect(() => timer.getDuration())\n        .to.throw('Unable to get duration');\n    });\n    it('should error if start time is a number', function () {\n      const timer = new timing.Timer();\n      timer._startTime = 12345;\n      expect(() => timer.getDuration())\n        .to.throw('Unable to get duration');\n    });\n  });\n  describe('bigint', function () {\n    beforeEach(function () {\n      // the non-mocked test cannot run if BigInt does not exist,\n      // and it cannot be mocked. Luckily support was added in Node 10.4.0,\n      // so it should not be a case where we are testing without this,\n      // though it still can be a test that Appium is _used_ without it.\n      if (!_.isFunction(process.hrtime.bigint)) {\n        return this.skip();\n      }\n      processMock = sinon.mock(process.hrtime);\n    });\n\n    function setupMocks (once = false) {\n      if (once) {\n        processMock.expects('bigint').once()\n          .onFirstCall().returns(BigInt(1172941153404030));\n      } else {\n        processMock.expects('bigint').twice()\n          .onFirstCall().returns(BigInt(1172941153404030))\n          .onSecondCall().returns(BigInt(1172951164887132));\n      }\n    }\n\n    it('should get a duration', function () {\n      setupMocks();\n\n      const timer = new timing.Timer().start();\n      const duration = timer.getDuration();\n      _.isNumber(duration.nanos).should.be.true;\n    });\n    it('should get correct seconds', function () {\n      setupMocks();\n\n      const timer = new timing.Timer().start();\n      const duration = timer.getDuration();\n      duration.asSeconds.should.be.eql(10.011483102);\n    });\n    it('should get correct milliseconds', function () {\n      setupMocks();\n\n      const timer = new timing.Timer().start();\n      const duration = timer.getDuration();\n      duration.asMilliSeconds.should.be.eql(10011.483102);\n    });\n    it('should get correct nanoseconds', function () {\n      setupMocks();\n\n      const timer = new timing.Timer().start();\n      const duration = timer.getDuration();\n      duration.asNanoSeconds.should.be.eql(10011483102);\n    });\n    it('should error if the timer was not started', function () {\n      const timer = new timing.Timer();\n      expect(() => timer.getDuration())\n        .to.throw('Unable to get duration');\n    });\n    it('should error if passing in a non-bigint', function () {\n      const timer = new timing.Timer();\n      timer._startTime = 12345;\n      expect(() => timer.getDuration())\n        .to.throw('Unable to get duration');\n    });\n  });\n});\n"],"file":"test/timing-specs.js","sourceRoot":"../.."}
|