@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.
- package/build/lib/env.js +102 -0
- package/build/lib/fs.js +74 -56
- package/build/lib/image-util.js +4 -332
- 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/image-util.js +3 -570
- 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 -9
- 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 -227
- 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,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":"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","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":"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","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":"../.."}
|
|
@@ -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 _bluebird = _interopRequireDefault(require("bluebird"));
|
|
8
|
-
|
|
9
|
-
var _path = _interopRequireDefault(require("path"));
|
|
10
|
-
|
|
11
|
-
var util = _interopRequireWildcard(require("../lib/util"));
|
|
12
|
-
|
|
13
|
-
var _index = require("../lib/index");
|
|
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
|
-
describe('#util', function () {
|
|
20
|
-
let tmpRoot;
|
|
21
|
-
let tmpFile;
|
|
22
|
-
const content = 'YOLO';
|
|
23
|
-
beforeEach(async function () {
|
|
24
|
-
tmpRoot = await _index.tempDir.openDir();
|
|
25
|
-
tmpFile = _path.default.resolve(tmpRoot, 'example.txt');
|
|
26
|
-
await _index.fs.writeFile(tmpFile, content, 'utf8');
|
|
27
|
-
});
|
|
28
|
-
afterEach(async function () {
|
|
29
|
-
if (tmpRoot) {
|
|
30
|
-
await _index.fs.rimraf(tmpRoot);
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
tmpRoot = null;
|
|
34
|
-
});
|
|
35
|
-
describe('toInMemoryBase64()', function () {
|
|
36
|
-
it('should convert a file to base64 encoding', async function () {
|
|
37
|
-
const data = await util.toInMemoryBase64(tmpFile);
|
|
38
|
-
const fileContent = await _index.fs.readFile(tmpFile);
|
|
39
|
-
data.toString().should.eql(fileContent.toString('base64'));
|
|
40
|
-
});
|
|
41
|
-
});
|
|
42
|
-
describe('getLockFileGuard()', function () {
|
|
43
|
-
let tmpRoot;
|
|
44
|
-
let lockFile;
|
|
45
|
-
let testFile;
|
|
46
|
-
|
|
47
|
-
async function guardedBehavior(text, msBeforeActing) {
|
|
48
|
-
await _bluebird.default.delay(msBeforeActing);
|
|
49
|
-
await _index.fs.appendFile(testFile, text, 'utf8');
|
|
50
|
-
return text;
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
async function testFileContents() {
|
|
54
|
-
return (await _index.fs.readFile(testFile)).toString('utf8');
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
beforeEach(async function () {
|
|
58
|
-
tmpRoot = await _index.tempDir.openDir();
|
|
59
|
-
lockFile = _path.default.resolve(tmpRoot, 'test.lock');
|
|
60
|
-
testFile = _path.default.resolve(tmpRoot, 'test');
|
|
61
|
-
await _index.fs.writeFile(testFile, 'a', 'utf8');
|
|
62
|
-
});
|
|
63
|
-
afterEach(async function () {
|
|
64
|
-
try {
|
|
65
|
-
await _bluebird.default.all([lockFile, testFile].map(p => _index.fs.unlink(p)));
|
|
66
|
-
} catch (ign) {}
|
|
67
|
-
});
|
|
68
|
-
it('should lock a file during the given behavior', async function () {
|
|
69
|
-
const guard = util.getLockFileGuard(lockFile);
|
|
70
|
-
await guard.check().should.eventually.be.false;
|
|
71
|
-
const guardPromise = guard(async () => await guardedBehavior('b', 500));
|
|
72
|
-
await _bluebird.default.delay(200);
|
|
73
|
-
await guard.check().should.eventually.be.true;
|
|
74
|
-
await guardPromise;
|
|
75
|
-
await guard.check().should.eventually.be.false;
|
|
76
|
-
await testFileContents().should.eventually.eql('ab');
|
|
77
|
-
});
|
|
78
|
-
it('should recover a broken lock file', async function () {
|
|
79
|
-
await _index.fs.writeFile(lockFile, 'dummy', 'utf8');
|
|
80
|
-
const guard = util.getLockFileGuard(lockFile, {
|
|
81
|
-
timeout: 3,
|
|
82
|
-
tryRecovery: true
|
|
83
|
-
});
|
|
84
|
-
await guard(async () => await guardedBehavior('b', 500));
|
|
85
|
-
await guard.check().should.eventually.be.false;
|
|
86
|
-
await testFileContents().should.eventually.eql('ab');
|
|
87
|
-
});
|
|
88
|
-
it('should block other behavior until the lock is released', async function () {
|
|
89
|
-
await testFileContents().should.eventually.eql('a');
|
|
90
|
-
const unguardedPromise1 = guardedBehavior('b', 500);
|
|
91
|
-
const unguardedPromise2 = guardedBehavior('c', 100);
|
|
92
|
-
await unguardedPromise1;
|
|
93
|
-
await unguardedPromise2;
|
|
94
|
-
await testFileContents().should.eventually.eql('acb');
|
|
95
|
-
const guard = util.getLockFileGuard(lockFile);
|
|
96
|
-
const guardPromise1 = guard(async () => await guardedBehavior('b', 500));
|
|
97
|
-
const guardPromise2 = guard(async () => await guardedBehavior('c', 100));
|
|
98
|
-
await guardPromise1;
|
|
99
|
-
await guardPromise2;
|
|
100
|
-
await testFileContents().should.eventually.eql('acbbc');
|
|
101
|
-
});
|
|
102
|
-
it('should return the result of the guarded behavior', async function () {
|
|
103
|
-
const guard = util.getLockFileGuard(lockFile);
|
|
104
|
-
const guardPromise1 = guard(async () => await guardedBehavior('hello', 500));
|
|
105
|
-
const guardPromise2 = guard(async () => await guardedBehavior('world', 100));
|
|
106
|
-
const ret1 = await guardPromise1;
|
|
107
|
-
const ret2 = await guardPromise2;
|
|
108
|
-
ret1.should.eql('hello');
|
|
109
|
-
ret2.should.eql('world');
|
|
110
|
-
});
|
|
111
|
-
it('should time out if the lock is not released', async function () {
|
|
112
|
-
this.timeout(5000);
|
|
113
|
-
const guard = util.getLockFileGuard(lockFile, {
|
|
114
|
-
timeout: 0.5
|
|
115
|
-
});
|
|
116
|
-
const p1 = guard(async () => await guardedBehavior('hello', 1200));
|
|
117
|
-
const p2 = guard(async () => await guardedBehavior('world', 10));
|
|
118
|
-
await p2.should.eventually.be.rejectedWith(/not acquire lock/);
|
|
119
|
-
await p1.should.eventually.eql('hello');
|
|
120
|
-
});
|
|
121
|
-
it('should still release lock if guarded behavior fails', async function () {
|
|
122
|
-
this.timeout(5000);
|
|
123
|
-
const guard = util.getLockFileGuard(lockFile);
|
|
124
|
-
const p1 = guard(async () => {
|
|
125
|
-
await _bluebird.default.delay(500);
|
|
126
|
-
throw new Error('bad');
|
|
127
|
-
});
|
|
128
|
-
const p2 = guard(async () => await guardedBehavior('world', 100));
|
|
129
|
-
await p1.should.eventually.be.rejectedWith(/bad/);
|
|
130
|
-
await p2.should.eventually.eql('world');
|
|
131
|
-
});
|
|
132
|
-
});
|
|
133
|
-
});require('source-map-support').install();
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["test/util-e2e-specs.js"],"names":["describe","tmpRoot","tmpFile","content","beforeEach","tempDir","openDir","path","resolve","fs","writeFile","afterEach","rimraf","it","data","util","toInMemoryBase64","fileContent","readFile","toString","should","eql","lockFile","testFile","guardedBehavior","text","msBeforeActing","B","delay","appendFile","testFileContents","all","map","p","unlink","ign","guard","getLockFileGuard","check","eventually","be","false","guardPromise","true","timeout","tryRecovery","unguardedPromise1","unguardedPromise2","guardPromise1","guardPromise2","ret1","ret2","p1","p2","rejectedWith","Error"],"mappings":"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","sourcesContent":["import B from 'bluebird';\nimport path from 'path';\nimport * as util from '../lib/util';\nimport { tempDir, fs } from '../lib/index';\n\n\ndescribe('#util', function () {\n  let tmpRoot;\n  let tmpFile;\n  const content = 'YOLO';\n\n  beforeEach(async function () {\n    tmpRoot = await tempDir.openDir();\n    tmpFile = path.resolve(tmpRoot, 'example.txt');\n    await fs.writeFile(tmpFile, content, 'utf8');\n  });\n\n  afterEach(async function () {\n    if (tmpRoot) {\n      await fs.rimraf(tmpRoot);\n    }\n    tmpRoot = null;\n  });\n\n  describe('toInMemoryBase64()', function () {\n    it('should convert a file to base64 encoding', async function () {\n      const data = await util.toInMemoryBase64(tmpFile);\n      const fileContent = await fs.readFile(tmpFile);\n      data.toString().should.eql(fileContent.toString('base64'));\n    });\n  });\n\n  describe('getLockFileGuard()', function () {\n    let tmpRoot;\n    let lockFile;\n    let testFile;\n\n    async function guardedBehavior (text, msBeforeActing) {\n      await B.delay(msBeforeActing);\n      await fs.appendFile(testFile, text, 'utf8');\n      return text;\n    }\n\n    async function testFileContents () {\n      return (await fs.readFile(testFile)).toString('utf8');\n    }\n\n    beforeEach(async function () {\n      tmpRoot = await tempDir.openDir();\n      lockFile = path.resolve(tmpRoot, 'test.lock');\n      testFile = path.resolve(tmpRoot, 'test');\n      await fs.writeFile(testFile, 'a', 'utf8');\n    });\n\n    afterEach(async function () {\n      try {\n        await B.all([lockFile, testFile].map((p) => fs.unlink(p)));\n      } catch (ign) {}\n    });\n\n    it('should lock a file during the given behavior', async function () {\n      const guard = util.getLockFileGuard(lockFile);\n      await guard.check().should.eventually.be.false;\n      const guardPromise = guard(async () => await guardedBehavior('b', 500));\n      await B.delay(200);\n      await guard.check().should.eventually.be.true;\n      await guardPromise;\n      await guard.check().should.eventually.be.false;\n      await testFileContents().should.eventually.eql('ab');\n    });\n\n    it('should recover a broken lock file', async function () {\n      await fs.writeFile(lockFile, 'dummy', 'utf8');\n      const guard = util.getLockFileGuard(lockFile, {\n        timeout: 3,\n        tryRecovery: true,\n      });\n      await guard(async () => await guardedBehavior('b', 500));\n      await guard.check().should.eventually.be.false;\n      await testFileContents().should.eventually.eql('ab');\n    });\n\n    it('should block other behavior until the lock is released', async function () {\n      // first prove that without a lock, we get races\n      await testFileContents().should.eventually.eql('a');\n      const unguardedPromise1 = guardedBehavior('b', 500);\n      const unguardedPromise2 = guardedBehavior('c', 100);\n      await unguardedPromise1;\n      await unguardedPromise2;\n      await testFileContents().should.eventually.eql('acb');\n\n      // now prove that with a lock, we don't get any interlopers\n      const guard = util.getLockFileGuard(lockFile);\n      const guardPromise1 = guard(async () => await guardedBehavior('b', 500));\n      const guardPromise2 = guard(async () => await guardedBehavior('c', 100));\n      await guardPromise1;\n      await guardPromise2;\n      await testFileContents().should.eventually.eql('acbbc');\n    });\n\n    it('should return the result of the guarded behavior', async function () {\n      const guard = util.getLockFileGuard(lockFile);\n      const guardPromise1 = guard(async () => await guardedBehavior('hello', 500));\n      const guardPromise2 = guard(async () => await guardedBehavior('world', 100));\n      const ret1 = await guardPromise1;\n      const ret2 = await guardPromise2;\n      ret1.should.eql('hello');\n      ret2.should.eql('world');\n    });\n\n    it('should time out if the lock is not released', async function () {\n      this.timeout(5000);\n      const guard = util.getLockFileGuard(lockFile, {timeout: 0.5});\n      const p1 = guard(async () => await guardedBehavior('hello', 1200));\n      const p2 = guard(async () => await guardedBehavior('world', 10));\n      await p2.should.eventually.be.rejectedWith(/not acquire lock/);\n      await p1.should.eventually.eql('hello');\n    });\n\n    it('should still release lock if guarded behavior fails', async function () {\n      this.timeout(5000);\n      const guard = util.getLockFileGuard(lockFile);\n      const p1 = guard(async () => {\n        await B.delay(500);\n        throw new Error('bad');\n      });\n      const p2 = guard(async () => await guardedBehavior('world', 100));\n      await p1.should.eventually.be.rejectedWith(/bad/);\n      await p2.should.eventually.eql('world');\n    });\n  });\n\n});\n"],"file":"test/util-e2e-specs.js","sourceRoot":"../.."}
|