@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,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":";;;;;;AAAA;;AACA;;AACA;;AACA;;;;;;AAGAA,QAAQ,CAAC,OAAD,EAAU,YAAY;AAC5B,MAAIC,OAAJ;AACA,MAAIC,OAAJ;AACA,QAAMC,OAAO,GAAG,MAAhB;AAEAC,EAAAA,UAAU,CAAC,kBAAkB;AAC3BH,IAAAA,OAAO,GAAG,MAAMI,eAAQC,OAAR,EAAhB;AACAJ,IAAAA,OAAO,GAAGK,cAAKC,OAAL,CAAaP,OAAb,EAAsB,aAAtB,CAAV;AACA,UAAMQ,UAAGC,SAAH,CAAaR,OAAb,EAAsBC,OAAtB,EAA+B,MAA/B,CAAN;AACD,GAJS,CAAV;AAMAQ,EAAAA,SAAS,CAAC,kBAAkB;AAC1B,QAAIV,OAAJ,EAAa;AACX,YAAMQ,UAAGG,MAAH,CAAUX,OAAV,CAAN;AACD;;AACDA,IAAAA,OAAO,GAAG,IAAV;AACD,GALQ,CAAT;AAOAD,EAAAA,QAAQ,CAAC,oBAAD,EAAuB,YAAY;AACzCa,IAAAA,EAAE,CAAC,0CAAD,EAA6C,kBAAkB;AAC/D,YAAMC,IAAI,GAAG,MAAMC,IAAI,CAACC,gBAAL,CAAsBd,OAAtB,CAAnB;AACA,YAAMe,WAAW,GAAG,MAAMR,UAAGS,QAAH,CAAYhB,OAAZ,CAA1B;AACAY,MAAAA,IAAI,CAACK,QAAL,GAAgBC,MAAhB,CAAuBC,GAAvB,CAA2BJ,WAAW,CAACE,QAAZ,CAAqB,QAArB,CAA3B;AACD,KAJC,CAAF;AAKD,GANO,CAAR;AAQAnB,EAAAA,QAAQ,CAAC,oBAAD,EAAuB,YAAY;AACzC,QAAIC,OAAJ;AACA,QAAIqB,QAAJ;AACA,QAAIC,QAAJ;;AAEA,mBAAeC,eAAf,CAAgCC,IAAhC,EAAsCC,cAAtC,EAAsD;AACpD,YAAMC,kBAAEC,KAAF,CAAQF,cAAR,CAAN;AACA,YAAMjB,UAAGoB,UAAH,CAAcN,QAAd,EAAwBE,IAAxB,EAA8B,MAA9B,CAAN;AACA,aAAOA,IAAP;AACD;;AAED,mBAAeK,gBAAf,GAAmC;AACjC,aAAO,CAAC,MAAMrB,UAAGS,QAAH,CAAYK,QAAZ,CAAP,EAA8BJ,QAA9B,CAAuC,MAAvC,CAAP;AACD;;AAEDf,IAAAA,UAAU,CAAC,kBAAkB;AAC3BH,MAAAA,OAAO,GAAG,MAAMI,eAAQC,OAAR,EAAhB;AACAgB,MAAAA,QAAQ,GAAGf,cAAKC,OAAL,CAAaP,OAAb,EAAsB,WAAtB,CAAX;AACAsB,MAAAA,QAAQ,GAAGhB,cAAKC,OAAL,CAAaP,OAAb,EAAsB,MAAtB,CAAX;AACA,YAAMQ,UAAGC,SAAH,CAAaa,QAAb,EAAuB,GAAvB,EAA4B,MAA5B,CAAN;AACD,KALS,CAAV;AAOAZ,IAAAA,SAAS,CAAC,kBAAkB;AAC1B,UAAI;AACF,cAAMgB,kBAAEI,GAAF,CAAM,CAACT,QAAD,EAAWC,QAAX,EAAqBS,GAArB,CAA0BC,CAAD,IAAOxB,UAAGyB,MAAH,CAAUD,CAAV,CAAhC,CAAN,CAAN;AACD,OAFD,CAEE,OAAOE,GAAP,EAAY,CAAE;AACjB,KAJQ,CAAT;AAMAtB,IAAAA,EAAE,CAAC,8CAAD,EAAiD,kBAAkB;AACnE,YAAMuB,KAAK,GAAGrB,IAAI,CAACsB,gBAAL,CAAsBf,QAAtB,CAAd;AACA,YAAMc,KAAK,CAACE,KAAN,GAAclB,MAAd,CAAqBmB,UAArB,CAAgCC,EAAhC,CAAmCC,KAAzC;AACA,YAAMC,YAAY,GAAGN,KAAK,CAAC,YAAY,MAAMZ,eAAe,CAAC,GAAD,EAAM,GAAN,CAAlC,CAA1B;AACA,YAAMG,kBAAEC,KAAF,CAAQ,GAAR,CAAN;AACA,YAAMQ,KAAK,CAACE,KAAN,GAAclB,MAAd,CAAqBmB,UAArB,CAAgCC,EAAhC,CAAmCG,IAAzC;AACA,YAAMD,YAAN;AACA,YAAMN,KAAK,CAACE,KAAN,GAAclB,MAAd,CAAqBmB,UAArB,CAAgCC,EAAhC,CAAmCC,KAAzC;AACA,YAAMX,gBAAgB,GAAGV,MAAnB,CAA0BmB,UAA1B,CAAqClB,GAArC,CAAyC,IAAzC,CAAN;AACD,KATC,CAAF;AAWAR,IAAAA,EAAE,CAAC,mCAAD,EAAsC,kBAAkB;AACxD,YAAMJ,UAAGC,SAAH,CAAaY,QAAb,EAAuB,OAAvB,EAAgC,MAAhC,CAAN;AACA,YAAMc,KAAK,GAAGrB,IAAI,CAACsB,gBAAL,CAAsBf,QAAtB,EAAgC;AAC5CsB,QAAAA,OAAO,EAAE,CADmC;AAE5CC,QAAAA,WAAW,EAAE;AAF+B,OAAhC,CAAd;AAIA,YAAMT,KAAK,CAAC,YAAY,MAAMZ,eAAe,CAAC,GAAD,EAAM,GAAN,CAAlC,CAAX;AACA,YAAMY,KAAK,CAACE,KAAN,GAAclB,MAAd,CAAqBmB,UAArB,CAAgCC,EAAhC,CAAmCC,KAAzC;AACA,YAAMX,gBAAgB,GAAGV,MAAnB,CAA0BmB,UAA1B,CAAqClB,GAArC,CAAyC,IAAzC,CAAN;AACD,KATC,CAAF;AAWAR,IAAAA,EAAE,CAAC,wDAAD,EAA2D,kBAAkB;AAE7E,YAAMiB,gBAAgB,GAAGV,MAAnB,CAA0BmB,UAA1B,CAAqClB,GAArC,CAAyC,GAAzC,CAAN;AACA,YAAMyB,iBAAiB,GAAGtB,eAAe,CAAC,GAAD,EAAM,GAAN,CAAzC;AACA,YAAMuB,iBAAiB,GAAGvB,eAAe,CAAC,GAAD,EAAM,GAAN,CAAzC;AACA,YAAMsB,iBAAN;AACA,YAAMC,iBAAN;AACA,YAAMjB,gBAAgB,GAAGV,MAAnB,CAA0BmB,UAA1B,CAAqClB,GAArC,CAAyC,KAAzC,CAAN;AAGA,YAAMe,KAAK,GAAGrB,IAAI,CAACsB,gBAAL,CAAsBf,QAAtB,CAAd;AACA,YAAM0B,aAAa,GAAGZ,KAAK,CAAC,YAAY,MAAMZ,eAAe,CAAC,GAAD,EAAM,GAAN,CAAlC,CAA3B;AACA,YAAMyB,aAAa,GAAGb,KAAK,CAAC,YAAY,MAAMZ,eAAe,CAAC,GAAD,EAAM,GAAN,CAAlC,CAA3B;AACA,YAAMwB,aAAN;AACA,YAAMC,aAAN;AACA,YAAMnB,gBAAgB,GAAGV,MAAnB,CAA0BmB,UAA1B,CAAqClB,GAArC,CAAyC,OAAzC,CAAN;AACD,KAhBC,CAAF;AAkBAR,IAAAA,EAAE,CAAC,kDAAD,EAAqD,kBAAkB;AACvE,YAAMuB,KAAK,GAAGrB,IAAI,CAACsB,gBAAL,CAAsBf,QAAtB,CAAd;AACA,YAAM0B,aAAa,GAAGZ,KAAK,CAAC,YAAY,MAAMZ,eAAe,CAAC,OAAD,EAAU,GAAV,CAAlC,CAA3B;AACA,YAAMyB,aAAa,GAAGb,KAAK,CAAC,YAAY,MAAMZ,eAAe,CAAC,OAAD,EAAU,GAAV,CAAlC,CAA3B;AACA,YAAM0B,IAAI,GAAG,MAAMF,aAAnB;AACA,YAAMG,IAAI,GAAG,MAAMF,aAAnB;AACAC,MAAAA,IAAI,CAAC9B,MAAL,CAAYC,GAAZ,CAAgB,OAAhB;AACA8B,MAAAA,IAAI,CAAC/B,MAAL,CAAYC,GAAZ,CAAgB,OAAhB;AACD,KARC,CAAF;AAUAR,IAAAA,EAAE,CAAC,6CAAD,EAAgD,kBAAkB;AAClE,WAAK+B,OAAL,CAAa,IAAb;AACA,YAAMR,KAAK,GAAGrB,IAAI,CAACsB,gBAAL,CAAsBf,QAAtB,EAAgC;AAACsB,QAAAA,OAAO,EAAE;AAAV,OAAhC,CAAd;AACA,YAAMQ,EAAE,GAAGhB,KAAK,CAAC,YAAY,MAAMZ,eAAe,CAAC,OAAD,EAAU,IAAV,CAAlC,CAAhB;AACA,YAAM6B,EAAE,GAAGjB,KAAK,CAAC,YAAY,MAAMZ,eAAe,CAAC,OAAD,EAAU,EAAV,CAAlC,CAAhB;AACA,YAAM6B,EAAE,CAACjC,MAAH,CAAUmB,UAAV,CAAqBC,EAArB,CAAwBc,YAAxB,CAAqC,kBAArC,CAAN;AACA,YAAMF,EAAE,CAAChC,MAAH,CAAUmB,UAAV,CAAqBlB,GAArB,CAAyB,OAAzB,CAAN;AACD,KAPC,CAAF;AASAR,IAAAA,EAAE,CAAC,qDAAD,EAAwD,kBAAkB;AAC1E,WAAK+B,OAAL,CAAa,IAAb;AACA,YAAMR,KAAK,GAAGrB,IAAI,CAACsB,gBAAL,CAAsBf,QAAtB,CAAd;AACA,YAAM8B,EAAE,GAAGhB,KAAK,CAAC,YAAY;AAC3B,cAAMT,kBAAEC,KAAF,CAAQ,GAAR,CAAN;AACA,cAAM,IAAI2B,KAAJ,CAAU,KAAV,CAAN;AACD,OAHe,CAAhB;AAIA,YAAMF,EAAE,GAAGjB,KAAK,CAAC,YAAY,MAAMZ,eAAe,CAAC,OAAD,EAAU,GAAV,CAAlC,CAAhB;AACA,YAAM4B,EAAE,CAAChC,MAAH,CAAUmB,UAAV,CAAqBC,EAArB,CAAwBc,YAAxB,CAAqC,KAArC,CAAN;AACA,YAAMD,EAAE,CAACjC,MAAH,CAAUmB,UAAV,CAAqBlB,GAArB,CAAyB,OAAzB,CAAN;AACD,KAVC,CAAF;AAWD,GAlGO,CAAR;AAoGD,CA9HO,CAAR","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":"../.."}
|