@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,28 +0,0 @@
|
|
|
1
|
-
<?xml version="1.0" encoding="UTF-8"?>
|
|
2
|
-
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
|
3
|
-
<plist version="1.0">
|
|
4
|
-
<dict>
|
|
5
|
-
<key>com.apple.locationd.bundle-/System/Library/PrivateFrameworks/Parsec.framework</key>
|
|
6
|
-
<dict>
|
|
7
|
-
<key>Whitelisted</key>
|
|
8
|
-
<false/>
|
|
9
|
-
<key>Executable</key>
|
|
10
|
-
<string></string>
|
|
11
|
-
<key>BundlePath</key>
|
|
12
|
-
<string>/System/Library/PrivateFrameworks/Parsec.framework</string>
|
|
13
|
-
<key>Registered</key>
|
|
14
|
-
<string></string>
|
|
15
|
-
</dict>
|
|
16
|
-
<key>com.apple.locationd.bundle-/System/Library/PrivateFrameworks/WirelessDiagnostics.framework</key>
|
|
17
|
-
<dict>
|
|
18
|
-
<key>Whitelisted</key>
|
|
19
|
-
<false/>
|
|
20
|
-
<key>Executable</key>
|
|
21
|
-
<string></string>
|
|
22
|
-
<key>BundlePath</key>
|
|
23
|
-
<string>/System/Library/PrivateFrameworks/WirelessDiagnostics.framework</string>
|
|
24
|
-
<key>Registered</key>
|
|
25
|
-
<string></string>
|
|
26
|
-
</dict>
|
|
27
|
-
</dict>
|
|
28
|
-
</plist>
|
package/build/test/fs-specs.js
DELETED
|
@@ -1,264 +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 _path = _interopRequireDefault(require("path"));
|
|
10
|
-
|
|
11
|
-
var _teen_process = require("teen_process");
|
|
12
|
-
|
|
13
|
-
var _bluebird = _interopRequireDefault(require("bluebird"));
|
|
14
|
-
|
|
15
|
-
var _lodash = _interopRequireDefault(require("lodash"));
|
|
16
|
-
|
|
17
|
-
const MOCHA_TIMEOUT = 20000;
|
|
18
|
-
describe('fs', function () {
|
|
19
|
-
this.timeout(MOCHA_TIMEOUT);
|
|
20
|
-
|
|
21
|
-
const existingPath = _path.default.resolve(__dirname, 'fs-specs.js');
|
|
22
|
-
|
|
23
|
-
it('should have expected methods', function () {
|
|
24
|
-
should.exist(_index.fs.open);
|
|
25
|
-
should.exist(_index.fs.close);
|
|
26
|
-
should.exist(_index.fs.access);
|
|
27
|
-
should.exist(_index.fs.mkdir);
|
|
28
|
-
should.exist(_index.fs.readlink);
|
|
29
|
-
should.exist(_index.fs.exists);
|
|
30
|
-
should.exist(_index.fs.rimraf);
|
|
31
|
-
should.exist(_index.fs.rimrafSync);
|
|
32
|
-
should.exist(_index.fs.readFile);
|
|
33
|
-
should.exist(_index.fs.writeFile);
|
|
34
|
-
should.exist(_index.fs.lstat);
|
|
35
|
-
should.exist(_index.fs.mv);
|
|
36
|
-
});
|
|
37
|
-
describe('mkdir', function () {
|
|
38
|
-
let dirName = _path.default.resolve(__dirname, 'tmp');
|
|
39
|
-
|
|
40
|
-
it('should make a directory that does not exist', async function () {
|
|
41
|
-
await _index.fs.rimraf(dirName);
|
|
42
|
-
await _index.fs.mkdir(dirName);
|
|
43
|
-
let exists = await _index.fs.hasAccess(dirName);
|
|
44
|
-
exists.should.be.true;
|
|
45
|
-
});
|
|
46
|
-
it('should not complain if the dir already exists', async function () {
|
|
47
|
-
let exists = await _index.fs.hasAccess(dirName);
|
|
48
|
-
exists.should.be.true;
|
|
49
|
-
await _index.fs.mkdir(dirName);
|
|
50
|
-
});
|
|
51
|
-
it('should still throw an error if something else goes wrong', async function () {
|
|
52
|
-
await _index.fs.mkdir('/bin/foo').should.be.rejected;
|
|
53
|
-
});
|
|
54
|
-
});
|
|
55
|
-
it('hasAccess', async function () {
|
|
56
|
-
(await _index.fs.exists(existingPath)).should.be.ok;
|
|
57
|
-
|
|
58
|
-
let nonExistingPath = _path.default.resolve(__dirname, 'wrong-specs.js');
|
|
59
|
-
|
|
60
|
-
(await _index.fs.hasAccess(nonExistingPath)).should.not.be.ok;
|
|
61
|
-
});
|
|
62
|
-
it('exists', async function () {
|
|
63
|
-
(await _index.fs.exists(existingPath)).should.be.ok;
|
|
64
|
-
|
|
65
|
-
let nonExistingPath = _path.default.resolve(__dirname, 'wrong-specs.js');
|
|
66
|
-
|
|
67
|
-
(await _index.fs.exists(nonExistingPath)).should.not.be.ok;
|
|
68
|
-
});
|
|
69
|
-
it('readFile', async function () {
|
|
70
|
-
(await _index.fs.readFile(existingPath, 'utf8')).should.contain('readFile');
|
|
71
|
-
});
|
|
72
|
-
describe('copyFile', function () {
|
|
73
|
-
it('should be able to copy a file', async function () {
|
|
74
|
-
let newPath = _path.default.resolve(await _index.tempDir.openDir(), 'fs-specs.js');
|
|
75
|
-
|
|
76
|
-
await _index.fs.copyFile(existingPath, newPath);
|
|
77
|
-
(await _index.fs.readFile(newPath, 'utf8')).should.contain('readFile');
|
|
78
|
-
});
|
|
79
|
-
it('should throw an error if the source does not exist', async function () {
|
|
80
|
-
await _index.fs.copyFile('/sdfsdfsdfsdf', '/tmp/bla').should.eventually.be.rejected;
|
|
81
|
-
});
|
|
82
|
-
});
|
|
83
|
-
it('rimraf', async function () {
|
|
84
|
-
let newPath = _path.default.resolve(await _index.tempDir.openDir(), 'fs-specs.js');
|
|
85
|
-
|
|
86
|
-
await _index.fs.copyFile(existingPath, newPath);
|
|
87
|
-
(await _index.fs.exists(newPath)).should.be.true;
|
|
88
|
-
await _index.fs.rimraf(newPath);
|
|
89
|
-
(await _index.fs.exists(newPath)).should.be.false;
|
|
90
|
-
});
|
|
91
|
-
it('sanitizeName', function () {
|
|
92
|
-
_index.fs.sanitizeName(':file?.txt', {
|
|
93
|
-
replacement: '-'
|
|
94
|
-
}).should.eql('-file-.txt');
|
|
95
|
-
});
|
|
96
|
-
it('rimrafSync', async function () {
|
|
97
|
-
let newPath = _path.default.resolve(await _index.tempDir.openDir(), 'fs-specs.js');
|
|
98
|
-
|
|
99
|
-
await _index.fs.copyFile(existingPath, newPath);
|
|
100
|
-
(await _index.fs.exists(newPath)).should.be.true;
|
|
101
|
-
|
|
102
|
-
_index.fs.rimrafSync(newPath);
|
|
103
|
-
|
|
104
|
-
(await _index.fs.exists(newPath)).should.be.false;
|
|
105
|
-
});
|
|
106
|
-
describe('md5', function () {
|
|
107
|
-
this.timeout(1200000);
|
|
108
|
-
let smallFilePath;
|
|
109
|
-
let bigFilePath;
|
|
110
|
-
before(async function () {
|
|
111
|
-
smallFilePath = existingPath;
|
|
112
|
-
bigFilePath = _path.default.resolve(await _index.tempDir.openDir(), 'enormous.txt');
|
|
113
|
-
let file = await _index.fs.open(bigFilePath, 'w');
|
|
114
|
-
let fileData = '';
|
|
115
|
-
|
|
116
|
-
for (let i = 0; i < 4096; i++) {
|
|
117
|
-
fileData += '1';
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
for (let i = 0; i < 40000; i++) {
|
|
121
|
-
await _index.fs.write(file, fileData);
|
|
122
|
-
}
|
|
123
|
-
|
|
124
|
-
await _index.fs.close(file);
|
|
125
|
-
});
|
|
126
|
-
after(async function () {
|
|
127
|
-
await _index.fs.unlink(bigFilePath);
|
|
128
|
-
});
|
|
129
|
-
it('should calculate hash of correct length', async function () {
|
|
130
|
-
(await _index.fs.md5(smallFilePath)).should.have.length(32);
|
|
131
|
-
});
|
|
132
|
-
it('should be able to run on huge file', async function () {
|
|
133
|
-
(await _index.fs.md5(bigFilePath)).should.have.length(32);
|
|
134
|
-
});
|
|
135
|
-
});
|
|
136
|
-
describe('hash', function () {
|
|
137
|
-
it('should calculate sha1 hash', async function () {
|
|
138
|
-
(await _index.fs.hash(existingPath, 'sha1')).should.have.length(40);
|
|
139
|
-
});
|
|
140
|
-
it('should calculate md5 hash', async function () {
|
|
141
|
-
(await _index.fs.hash(existingPath, 'md5')).should.have.length(32);
|
|
142
|
-
});
|
|
143
|
-
});
|
|
144
|
-
it('stat', async function () {
|
|
145
|
-
let stat = await _index.fs.stat(existingPath);
|
|
146
|
-
stat.should.have.property('atime');
|
|
147
|
-
});
|
|
148
|
-
describe('which', function () {
|
|
149
|
-
it('should find correct executable', async function () {
|
|
150
|
-
let systemNpmPath = (await (0, _teen_process.exec)('which', ['npm'])).stdout.trim();
|
|
151
|
-
let npmPath = await _index.fs.which('npm');
|
|
152
|
-
npmPath.should.equal(systemNpmPath);
|
|
153
|
-
});
|
|
154
|
-
it('should fail gracefully', async function () {
|
|
155
|
-
await _index.fs.which('something_that_does_not_exist').should.eventually.be.rejected;
|
|
156
|
-
});
|
|
157
|
-
});
|
|
158
|
-
it('glob', async function () {
|
|
159
|
-
let glob = '*-specs.js';
|
|
160
|
-
let tests = await _index.fs.glob(glob, {
|
|
161
|
-
cwd: __dirname
|
|
162
|
-
});
|
|
163
|
-
tests.should.be.an('array');
|
|
164
|
-
tests.should.have.length.above(2);
|
|
165
|
-
});
|
|
166
|
-
describe('walkDir', function () {
|
|
167
|
-
it('walkDir recursive', async function () {
|
|
168
|
-
let inCallback = 0;
|
|
169
|
-
const filePath = await _index.fs.walkDir(__dirname, true, async item => {
|
|
170
|
-
if (item.endsWith('logger/helpers.js')) {
|
|
171
|
-
++inCallback;
|
|
172
|
-
await _bluebird.default.delay(500);
|
|
173
|
-
--inCallback;
|
|
174
|
-
return true;
|
|
175
|
-
}
|
|
176
|
-
});
|
|
177
|
-
inCallback.should.equal(0);
|
|
178
|
-
filePath.should.not.be.null;
|
|
179
|
-
});
|
|
180
|
-
it('should walk all elements recursive', async function () {
|
|
181
|
-
let inCallback = 0;
|
|
182
|
-
const filePath = await _index.fs.walkDir(__dirname, true, async () => {
|
|
183
|
-
++inCallback;
|
|
184
|
-
await _bluebird.default.delay(500);
|
|
185
|
-
--inCallback;
|
|
186
|
-
});
|
|
187
|
-
inCallback.should.equal(0);
|
|
188
|
-
_lodash.default.isNil(filePath).should.be.true;
|
|
189
|
-
});
|
|
190
|
-
it('should throw error through callback', async function () {
|
|
191
|
-
let processed = 0;
|
|
192
|
-
await chai.expect(_index.fs.walkDir(__dirname, true, () => {
|
|
193
|
-
++processed;
|
|
194
|
-
throw 'Callback error';
|
|
195
|
-
})).to.be.rejectedWith('Callback error');
|
|
196
|
-
processed.should.equal(1);
|
|
197
|
-
});
|
|
198
|
-
it('should traverse non-recursively', async function () {
|
|
199
|
-
const filePath = await _index.fs.walkDir(__dirname, false, item => item.endsWith('logger/helpers.js'));
|
|
200
|
-
_lodash.default.isNil(filePath).should.be.true;
|
|
201
|
-
});
|
|
202
|
-
});
|
|
203
|
-
describe('findRoot()', function () {
|
|
204
|
-
describe('when not provided an argument', function () {
|
|
205
|
-
it('should throw', function () {
|
|
206
|
-
(() => _index.fs.findRoot()).should.throw(TypeError);
|
|
207
|
-
});
|
|
208
|
-
});
|
|
209
|
-
describe('when provided a relative path', function () {
|
|
210
|
-
it('should throw', function () {
|
|
211
|
-
(() => _index.fs.findRoot('./foo')).should.throw(TypeError);
|
|
212
|
-
});
|
|
213
|
-
});
|
|
214
|
-
describe('when provided an empty string', function () {
|
|
215
|
-
it('should throw', function () {
|
|
216
|
-
(() => _index.fs.findRoot('')).should.throw(TypeError);
|
|
217
|
-
});
|
|
218
|
-
});
|
|
219
|
-
describe('when provided an absolute path', function () {
|
|
220
|
-
describe('when the path has a parent `package.json`', function () {
|
|
221
|
-
it('should locate the dir with the closest `package.json`', function () {
|
|
222
|
-
_index.fs.findRoot(__dirname).should.be.a('string');
|
|
223
|
-
});
|
|
224
|
-
});
|
|
225
|
-
describe('when the path does not have a parent `package.json`', function () {
|
|
226
|
-
it('should throw', function () {
|
|
227
|
-
(() => _index.fs.findRoot('/')).should.throw(Error);
|
|
228
|
-
});
|
|
229
|
-
});
|
|
230
|
-
});
|
|
231
|
-
});
|
|
232
|
-
describe('readPackageJsonFrom()', function () {
|
|
233
|
-
describe('when not provided an argument', function () {
|
|
234
|
-
it('should throw', function () {
|
|
235
|
-
(() => _index.fs.readPackageJsonFrom()).should.throw(TypeError, /non-empty, absolute path/);
|
|
236
|
-
});
|
|
237
|
-
});
|
|
238
|
-
describe('when provided a relative path', function () {
|
|
239
|
-
it('should throw', function () {
|
|
240
|
-
(() => _index.fs.readPackageJsonFrom('./foo')).should.throw(TypeError);
|
|
241
|
-
});
|
|
242
|
-
});
|
|
243
|
-
describe('when provided an empty string', function () {
|
|
244
|
-
it('should throw', function () {
|
|
245
|
-
(() => _index.fs.readPackageJsonFrom('')).should.throw(TypeError);
|
|
246
|
-
});
|
|
247
|
-
});
|
|
248
|
-
describe('when provided an absolute path', function () {
|
|
249
|
-
describe('when the path does not have a parent `package.json`', function () {
|
|
250
|
-
it('should throw', function () {
|
|
251
|
-
(() => _index.fs.readPackageJsonFrom('/')).should.throw(Error);
|
|
252
|
-
});
|
|
253
|
-
});
|
|
254
|
-
describe('when the path has a parent `package.json`', function () {
|
|
255
|
-
it('should read the `package.json` found in the root dir', function () {
|
|
256
|
-
_index.fs.readPackageJsonFrom(__dirname).should.be.an('object');
|
|
257
|
-
});
|
|
258
|
-
});
|
|
259
|
-
});
|
|
260
|
-
});
|
|
261
|
-
});require('source-map-support').install();
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["test/fs-specs.js"],"names":["MOCHA_TIMEOUT","describe","timeout","existingPath","path","resolve","__dirname","it","should","exist","fs","open","close","access","mkdir","readlink","exists","rimraf","rimrafSync","readFile","writeFile","lstat","mv","dirName","hasAccess","be","true","rejected","ok","nonExistingPath","not","contain","newPath","tempDir","openDir","copyFile","eventually","false","sanitizeName","replacement","eql","smallFilePath","bigFilePath","before","file","fileData","i","write","after","unlink","md5","have","length","hash","stat","property","systemNpmPath","stdout","trim","npmPath","which","equal","glob","tests","cwd","an","above","inCallback","filePath","walkDir","item","endsWith","B","delay","null","_","isNil","processed","chai","expect","to","rejectedWith","findRoot","throw","TypeError","a","Error","readPackageJsonFrom"],"mappings":"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","sourcesContent":["import { fs, tempDir } from '../lib/index.js';\nimport path from 'path';\nimport { exec } from 'teen_process';\nimport B from 'bluebird';\nimport _ from 'lodash';\n\n\nconst MOCHA_TIMEOUT = 20000;\n\ndescribe('fs', function () {\n  this.timeout(MOCHA_TIMEOUT);\n\n  const existingPath = path.resolve(__dirname, 'fs-specs.js');\n\n  it('should have expected methods', function () {\n    should.exist(fs.open);\n    should.exist(fs.close);\n    should.exist(fs.access);\n    should.exist(fs.mkdir);\n    should.exist(fs.readlink);\n    should.exist(fs.exists);\n    should.exist(fs.rimraf);\n    should.exist(fs.rimrafSync);\n    should.exist(fs.readFile);\n    should.exist(fs.writeFile);\n    should.exist(fs.lstat);\n    should.exist(fs.mv);\n  });\n\n  describe('mkdir', function () {\n    let dirName = path.resolve(__dirname, 'tmp');\n\n    it('should make a directory that does not exist', async function () {\n      await fs.rimraf(dirName);\n      await fs.mkdir(dirName);\n      let exists = await fs.hasAccess(dirName);\n      exists.should.be.true;\n    });\n\n    it('should not complain if the dir already exists', async function () {\n      let exists = await fs.hasAccess(dirName);\n      exists.should.be.true;\n      await fs.mkdir(dirName);\n    });\n\n    it('should still throw an error if something else goes wrong', async function () {\n      await fs.mkdir('/bin/foo').should.be.rejected;\n    });\n  });\n\n  it('hasAccess', async function () {\n    (await fs.exists(existingPath)).should.be.ok;\n    let nonExistingPath = path.resolve(__dirname, 'wrong-specs.js');\n    (await fs.hasAccess(nonExistingPath)).should.not.be.ok;\n  });\n  it('exists', async function () {\n    (await fs.exists(existingPath)).should.be.ok;\n    let nonExistingPath = path.resolve(__dirname, 'wrong-specs.js');\n    (await fs.exists(nonExistingPath)).should.not.be.ok;\n  });\n  it('readFile', async function () {\n    (await fs.readFile(existingPath, 'utf8')).should.contain('readFile');\n  });\n\n  describe('copyFile', function () {\n    it('should be able to copy a file', async function () {\n      let newPath = path.resolve(await tempDir.openDir(), 'fs-specs.js');\n      await fs.copyFile(existingPath, newPath);\n      (await fs.readFile(newPath, 'utf8')).should.contain('readFile');\n    });\n\n    it('should throw an error if the source does not exist', async function () {\n      await fs.copyFile('/sdfsdfsdfsdf', '/tmp/bla').should.eventually.be.rejected;\n    });\n  });\n\n  it('rimraf', async function () {\n    let newPath = path.resolve(await tempDir.openDir(), 'fs-specs.js');\n    await fs.copyFile(existingPath, newPath);\n    (await fs.exists(newPath)).should.be.true;\n    await fs.rimraf(newPath);\n    (await fs.exists(newPath)).should.be.false;\n  });\n  it('sanitizeName', function () {\n    fs.sanitizeName(':file?.txt', {\n      replacement: '-',\n    }).should.eql('-file-.txt');\n  });\n  it('rimrafSync', async function () {\n    let newPath = path.resolve(await tempDir.openDir(), 'fs-specs.js');\n    await fs.copyFile(existingPath, newPath);\n    (await fs.exists(newPath)).should.be.true;\n    fs.rimrafSync(newPath);\n    (await fs.exists(newPath)).should.be.false;\n  });\n  describe('md5', function () {\n    this.timeout(1200000);\n    let smallFilePath;\n    let bigFilePath;\n    before(async function () {\n      // get the path of a small file (this source file)\n      smallFilePath = existingPath;\n\n      // create a large file to test, about 163840000 bytes\n      bigFilePath = path.resolve(await tempDir.openDir(), 'enormous.txt');\n      let file = await fs.open(bigFilePath, 'w');\n      let fileData = '';\n      for (let i = 0; i < 4096; i++) {\n        fileData += '1';\n      }\n      for (let i = 0; i < 40000; i++) {\n        await fs.write(file, fileData);\n      }\n      await fs.close(file);\n    });\n    after(async function () {\n      await fs.unlink(bigFilePath);\n    });\n    it('should calculate hash of correct length', async function () {\n      (await fs.md5(smallFilePath)).should.have.length(32);\n    });\n    it('should be able to run on huge file', async function () {\n      (await fs.md5(bigFilePath)).should.have.length(32);\n    });\n  });\n  describe('hash', function () {\n    it('should calculate sha1 hash', async function () {\n      (await fs.hash(existingPath, 'sha1')).should.have.length(40);\n    });\n    it('should calculate md5 hash', async function () {\n      (await fs.hash(existingPath, 'md5')).should.have.length(32);\n    });\n  });\n  it('stat', async function () {\n    let stat = await fs.stat(existingPath);\n    stat.should.have.property('atime');\n  });\n  describe('which', function () {\n    it('should find correct executable', async function () {\n      let systemNpmPath = (await exec('which', ['npm'])).stdout.trim();\n      let npmPath = await fs.which('npm');\n      npmPath.should.equal(systemNpmPath);\n    });\n    it('should fail gracefully', async function () {\n      await fs.which('something_that_does_not_exist')\n        .should.eventually.be.rejected;\n    });\n  });\n  it('glob', async function () {\n    let glob = '*-specs.js';\n    let tests = await fs.glob(glob, {cwd: __dirname});\n    tests.should.be.an('array');\n    tests.should.have.length.above(2);\n  });\n  describe('walkDir', function () {\n    it('walkDir recursive', async function () {\n      let inCallback = 0;\n      const filePath = await fs.walkDir(__dirname, true, async (item) => {\n        if (item.endsWith('logger/helpers.js')) {\n          ++inCallback;\n          // This is to verify proper await functionality of the\n          // callback invocation inside the file system walker\n          await B.delay(500);\n          --inCallback;\n          return true;\n        }\n      });\n      inCallback.should.equal(0);\n      filePath.should.not.be.null;\n    });\n    it('should walk all elements recursive', async function () {\n      let inCallback = 0;\n      const filePath = await fs.walkDir(__dirname, true, async () => {\n        ++inCallback;\n        await B.delay(500);\n        --inCallback;\n\n      });\n      inCallback.should.equal(0);\n      _.isNil(filePath).should.be.true;\n    });\n    it('should throw error through callback', async function () {\n      let processed = 0;\n      await chai.expect(fs.walkDir(__dirname, true,\n        () => {\n          ++processed;\n          throw 'Callback error';\n        })).to.be.rejectedWith('Callback error');\n      processed.should.equal(1);\n    });\n    it('should traverse non-recursively', async function () {\n      const filePath = await fs.walkDir(__dirname, false, (item) => item.endsWith('logger/helpers.js'));\n      _.isNil(filePath).should.be.true;\n    });\n  });\n\n  describe('findRoot()', function () {\n    describe('when not provided an argument', function () {\n      it('should throw', function () {\n        (() => fs.findRoot()).should.throw(TypeError);\n      });\n    });\n\n    describe('when provided a relative path', function () {\n      it('should throw', function () {\n        (() => fs.findRoot('./foo')).should.throw(TypeError);\n      });\n    });\n\n    describe('when provided an empty string', function () {\n      it('should throw', function () {\n        (() => fs.findRoot('')).should.throw(TypeError);\n      });\n    });\n\n    describe('when provided an absolute path', function () {\n      describe('when the path has a parent `package.json`', function () {\n        it('should locate the dir with the closest `package.json`', function () {\n          fs.findRoot(__dirname).should.be.a('string');\n        });\n      });\n\n      describe('when the path does not have a parent `package.json`', function () {\n        it('should throw', function () {\n          (() => fs.findRoot('/')).should.throw(Error);\n        });\n      });\n    });\n  });\n\n  describe('readPackageJsonFrom()', function () {\n    describe('when not provided an argument', function () {\n      it('should throw', function () {\n        (() => fs.readPackageJsonFrom()).should.throw(TypeError, /non-empty, absolute path/);\n      });\n    });\n\n    describe('when provided a relative path', function () {\n      it('should throw', function () {\n        (() => fs.readPackageJsonFrom('./foo')).should.throw(TypeError);\n      });\n    });\n\n    describe('when provided an empty string', function () {\n      it('should throw', function () {\n        (() => fs.readPackageJsonFrom('')).should.throw(TypeError);\n      });\n    });\n\n    describe('when provided an absolute path', function () {\n      describe('when the path does not have a parent `package.json`', function () {\n        it('should throw', function () {\n          (() => fs.readPackageJsonFrom('/')).should.throw(Error);\n        });\n      });\n\n      describe('when the path has a parent `package.json`', function () {\n        it('should read the `package.json` found in the root dir', function () {\n          fs.readPackageJsonFrom(__dirname).should.be.an('object');\n        });\n      });\n    });\n  });\n});\n"],"file":"test/fs-specs.js","sourceRoot":"../.."}
|
package/build/test/helpers.js
DELETED
|
@@ -1,35 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.MockReadWriteStream = void 0;
|
|
7
|
-
|
|
8
|
-
require("source-map-support/register");
|
|
9
|
-
|
|
10
|
-
var _events = require("events");
|
|
11
|
-
|
|
12
|
-
class MockReadWriteStream extends _events.EventEmitter {
|
|
13
|
-
resume() {}
|
|
14
|
-
|
|
15
|
-
pause() {}
|
|
16
|
-
|
|
17
|
-
setEncoding() {}
|
|
18
|
-
|
|
19
|
-
flush() {}
|
|
20
|
-
|
|
21
|
-
write(msg) {
|
|
22
|
-
this.emit('data', msg);
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
end() {
|
|
26
|
-
this.emit('end');
|
|
27
|
-
this.emit('finish');
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
exports.MockReadWriteStream = MockReadWriteStream;require('source-map-support').install();
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRlc3QvaGVscGVycy5qcyJdLCJuYW1lcyI6WyJNb2NrUmVhZFdyaXRlU3RyZWFtIiwiRXZlbnRFbWl0dGVyIiwicmVzdW1lIiwicGF1c2UiLCJzZXRFbmNvZGluZyIsImZsdXNoIiwid3JpdGUiLCJtc2ciLCJlbWl0IiwiZW5kIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBQTs7QUFFQSxNQUFNQSxtQkFBTixTQUFrQ0Msb0JBQWxDLENBQStDO0FBQzdDQyxFQUFBQSxNQUFNLEdBQUksQ0FBRTs7QUFFWkMsRUFBQUEsS0FBSyxHQUFJLENBQUU7O0FBRVhDLEVBQUFBLFdBQVcsR0FBSSxDQUFFOztBQUVqQkMsRUFBQUEsS0FBSyxHQUFJLENBQUU7O0FBRVhDLEVBQUFBLEtBQUssQ0FBRUMsR0FBRixFQUFPO0FBQ1YsU0FBS0MsSUFBTCxDQUFVLE1BQVYsRUFBa0JELEdBQWxCO0FBQ0Q7O0FBRURFLEVBQUFBLEdBQUcsR0FBSTtBQUNMLFNBQUtELElBQUwsQ0FBVSxLQUFWO0FBQ0EsU0FBS0EsSUFBTCxDQUFVLFFBQVY7QUFDRDs7QUFoQjRDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRXZlbnRFbWl0dGVyIH0gZnJvbSAnZXZlbnRzJztcblxuY2xhc3MgTW9ja1JlYWRXcml0ZVN0cmVhbSBleHRlbmRzIEV2ZW50RW1pdHRlciB7XG4gIHJlc3VtZSAoKSB7fVxuXG4gIHBhdXNlICgpIHt9XG5cbiAgc2V0RW5jb2RpbmcgKCkge31cblxuICBmbHVzaCAoKSB7fVxuXG4gIHdyaXRlIChtc2cpIHtcbiAgICB0aGlzLmVtaXQoJ2RhdGEnLCBtc2cpO1xuICB9XG5cbiAgZW5kICgpIHtcbiAgICB0aGlzLmVtaXQoJ2VuZCcpO1xuICAgIHRoaXMuZW1pdCgnZmluaXNoJyk7XG4gIH1cbn1cblxuZXhwb3J0IHsgTW9ja1JlYWRXcml0ZVN0cmVhbSB9O1xuIl0sImZpbGUiOiJ0ZXN0L2hlbHBlcnMuanMiLCJzb3VyY2VSb290IjoiLi4vLi4ifQ==
|
|
@@ -1,78 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
|
-
require("source-map-support/register");
|
|
6
|
-
|
|
7
|
-
var _imageUtil = require("../lib/image-util");
|
|
8
|
-
|
|
9
|
-
var _path = _interopRequireDefault(require("path"));
|
|
10
|
-
|
|
11
|
-
var _lodash = _interopRequireDefault(require("lodash"));
|
|
12
|
-
|
|
13
|
-
var _lib = require("../lib");
|
|
14
|
-
|
|
15
|
-
const FIXTURES_ROOT = _path.default.resolve(__dirname, '..', '..', 'test', 'images');
|
|
16
|
-
|
|
17
|
-
async function getImage(name) {
|
|
18
|
-
const imagePath = _path.default.resolve(FIXTURES_ROOT, name);
|
|
19
|
-
|
|
20
|
-
return await _lib.fs.readFile(imagePath, 'utf8');
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
describe('image-util', function () {
|
|
24
|
-
describe('cropBase64Image', function () {
|
|
25
|
-
let originalImage = null;
|
|
26
|
-
before(async function () {
|
|
27
|
-
const originalImage64 = await getImage('full-image.b64');
|
|
28
|
-
originalImage = await (0, _imageUtil.base64ToImage)(originalImage64);
|
|
29
|
-
originalImage.width.should.be.equal(640, 'unexpected width');
|
|
30
|
-
originalImage.height.should.be.equal(1136, 'unexpected height');
|
|
31
|
-
});
|
|
32
|
-
it('should verify that an image is cropped correctly', async function () {
|
|
33
|
-
const croppedImage = await (0, _imageUtil.cropImage)(originalImage, {
|
|
34
|
-
left: 35,
|
|
35
|
-
top: 107,
|
|
36
|
-
width: 323,
|
|
37
|
-
height: 485
|
|
38
|
-
});
|
|
39
|
-
croppedImage.width.should.be.equal(323, 'unexpected width');
|
|
40
|
-
croppedImage.height.should.be.equal(485, 'unexpected height');
|
|
41
|
-
const croppedImageShouldBe = await getImage('cropped-image.b64');
|
|
42
|
-
const croppedImage64 = await (0, _imageUtil.imageToBase64)(croppedImage);
|
|
43
|
-
croppedImage64.should.be.equal(croppedImageShouldBe);
|
|
44
|
-
});
|
|
45
|
-
});
|
|
46
|
-
describe('Jimp helpers', function () {
|
|
47
|
-
it('should get a jimp object using image buffer', async function () {
|
|
48
|
-
const base64Image = await getImage('cropped-image.b64');
|
|
49
|
-
const imageBuffer = Buffer.from(base64Image, 'base64');
|
|
50
|
-
const jimpImg = await (0, _imageUtil.getJimpImage)(imageBuffer);
|
|
51
|
-
jimpImg.hash().should.eql('80000000000');
|
|
52
|
-
jimpImg.bitmap.height.should.eql(485);
|
|
53
|
-
jimpImg.bitmap.width.should.eql(323);
|
|
54
|
-
});
|
|
55
|
-
it('should get a jimp object using b64 string', async function () {
|
|
56
|
-
const base64Image = await getImage('cropped-image.b64');
|
|
57
|
-
const jimpImg = await (0, _imageUtil.getJimpImage)(base64Image);
|
|
58
|
-
jimpImg.hash().should.eql('80000000000');
|
|
59
|
-
jimpImg.bitmap.height.should.eql(485);
|
|
60
|
-
jimpImg.bitmap.width.should.eql(323);
|
|
61
|
-
});
|
|
62
|
-
it('should error with incorrect data type', async function () {
|
|
63
|
-
await (0, _imageUtil.getJimpImage)(1234).should.eventually.be.rejectedWith(/string or buffer/);
|
|
64
|
-
});
|
|
65
|
-
it('should error with incorrect image data', async function () {
|
|
66
|
-
await (0, _imageUtil.getJimpImage)('foo').should.eventually.be.rejectedWith(/Could not find MIME for Buffer/);
|
|
67
|
-
});
|
|
68
|
-
it('should get an image buffer via the overridden getBuffer method', async function () {
|
|
69
|
-
const base64Image = await getImage('cropped-image.b64');
|
|
70
|
-
const jimpImg = await (0, _imageUtil.getJimpImage)(base64Image);
|
|
71
|
-
const buf = await jimpImg.getBuffer(_imageUtil.MIME_PNG);
|
|
72
|
-
_lodash.default.isBuffer(buf).should.be.true;
|
|
73
|
-
});
|
|
74
|
-
});
|
|
75
|
-
});require('source-map-support').install();
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["test/image-util-e2e-specs.js"],"names":["FIXTURES_ROOT","path","resolve","__dirname","getImage","name","imagePath","fs","readFile","describe","originalImage","before","originalImage64","width","should","be","equal","height","it","croppedImage","left","top","croppedImageShouldBe","croppedImage64","base64Image","imageBuffer","Buffer","from","jimpImg","hash","eql","bitmap","eventually","rejectedWith","buf","getBuffer","MIME_PNG","_","isBuffer","true"],"mappings":";;;;;;AAAA;;AAIA;;AACA;;AACA;;AAGA,MAAMA,aAAa,GAAGC,cAAKC,OAAL,CAAaC,SAAb,EAAwB,IAAxB,EAA8B,IAA9B,EAAoC,MAApC,EAA4C,QAA5C,CAAtB;;AAEA,eAAeC,QAAf,CAAyBC,IAAzB,EAA+B;AAC7B,QAAMC,SAAS,GAAGL,cAAKC,OAAL,CAAaF,aAAb,EAA4BK,IAA5B,CAAlB;;AACA,SAAO,MAAME,QAAGC,QAAH,CAAYF,SAAZ,EAAuB,MAAvB,CAAb;AACD;;AAEDG,QAAQ,CAAC,YAAD,EAAe,YAAY;AAEjCA,EAAAA,QAAQ,CAAC,iBAAD,EAAoB,YAAY;AACtC,QAAIC,aAAa,GAAG,IAApB;AAEAC,IAAAA,MAAM,CAAC,kBAAkB;AACvB,YAAMC,eAAe,GAAG,MAAMR,QAAQ,CAAC,gBAAD,CAAtC;AACAM,MAAAA,aAAa,GAAG,MAAM,8BAAcE,eAAd,CAAtB;AAGAF,MAAAA,aAAa,CAACG,KAAd,CAAoBC,MAApB,CAA2BC,EAA3B,CAA8BC,KAA9B,CAAoC,GAApC,EAAyC,kBAAzC;AACAN,MAAAA,aAAa,CAACO,MAAd,CAAqBH,MAArB,CAA4BC,EAA5B,CAA+BC,KAA/B,CAAqC,IAArC,EAA2C,mBAA3C;AACD,KAPK,CAAN;AASAE,IAAAA,EAAE,CAAC,kDAAD,EAAqD,kBAAkB;AACvE,YAAMC,YAAY,GAAG,MAAM,0BAAUT,aAAV,EAAyB;AAACU,QAAAA,IAAI,EAAE,EAAP;AAAWC,QAAAA,GAAG,EAAE,GAAhB;AAAqBR,QAAAA,KAAK,EAAE,GAA5B;AAAiCI,QAAAA,MAAM,EAAE;AAAzC,OAAzB,CAA3B;AAGAE,MAAAA,YAAY,CAACN,KAAb,CAAmBC,MAAnB,CAA0BC,EAA1B,CAA6BC,KAA7B,CAAmC,GAAnC,EAAwC,kBAAxC;AACAG,MAAAA,YAAY,CAACF,MAAb,CAAoBH,MAApB,CAA2BC,EAA3B,CAA8BC,KAA9B,CAAoC,GAApC,EAAyC,mBAAzC;AAGA,YAAMM,oBAAoB,GAAG,MAAMlB,QAAQ,CAAC,mBAAD,CAA3C;AACA,YAAMmB,cAAc,GAAG,MAAM,8BAAcJ,YAAd,CAA7B;AACAI,MAAAA,cAAc,CAACT,MAAf,CAAsBC,EAAtB,CAAyBC,KAAzB,CAA+BM,oBAA/B;AACD,KAXC,CAAF;AAYD,GAxBO,CAAR;AA0BAb,EAAAA,QAAQ,CAAC,cAAD,EAAiB,YAAY;AACnCS,IAAAA,EAAE,CAAC,6CAAD,EAAgD,kBAAkB;AAClE,YAAMM,WAAW,GAAG,MAAMpB,QAAQ,CAAC,mBAAD,CAAlC;AACA,YAAMqB,WAAW,GAAGC,MAAM,CAACC,IAAP,CAAYH,WAAZ,EAAyB,QAAzB,CAApB;AACA,YAAMI,OAAO,GAAG,MAAM,6BAAaH,WAAb,CAAtB;AACAG,MAAAA,OAAO,CAACC,IAAR,GAAef,MAAf,CAAsBgB,GAAtB,CAA0B,aAA1B;AACAF,MAAAA,OAAO,CAACG,MAAR,CAAed,MAAf,CAAsBH,MAAtB,CAA6BgB,GAA7B,CAAiC,GAAjC;AACAF,MAAAA,OAAO,CAACG,MAAR,CAAelB,KAAf,CAAqBC,MAArB,CAA4BgB,GAA5B,CAAgC,GAAhC;AACD,KAPC,CAAF;AAQAZ,IAAAA,EAAE,CAAC,2CAAD,EAA8C,kBAAkB;AAChE,YAAMM,WAAW,GAAG,MAAMpB,QAAQ,CAAC,mBAAD,CAAlC;AACA,YAAMwB,OAAO,GAAG,MAAM,6BAAaJ,WAAb,CAAtB;AACAI,MAAAA,OAAO,CAACC,IAAR,GAAef,MAAf,CAAsBgB,GAAtB,CAA0B,aAA1B;AACAF,MAAAA,OAAO,CAACG,MAAR,CAAed,MAAf,CAAsBH,MAAtB,CAA6BgB,GAA7B,CAAiC,GAAjC;AACAF,MAAAA,OAAO,CAACG,MAAR,CAAelB,KAAf,CAAqBC,MAArB,CAA4BgB,GAA5B,CAAgC,GAAhC;AACD,KANC,CAAF;AAOAZ,IAAAA,EAAE,CAAC,uCAAD,EAA0C,kBAAkB;AAC5D,YAAM,6BAAa,IAAb,EAAmBJ,MAAnB,CAA0BkB,UAA1B,CAAqCjB,EAArC,CAAwCkB,YAAxC,CAAqD,kBAArD,CAAN;AACD,KAFC,CAAF;AAGAf,IAAAA,EAAE,CAAC,wCAAD,EAA2C,kBAAkB;AAC7D,YAAM,6BAAa,KAAb,EAAoBJ,MAApB,CAA2BkB,UAA3B,CAAsCjB,EAAtC,CAAyCkB,YAAzC,CAAsD,gCAAtD,CAAN;AACD,KAFC,CAAF;AAGAf,IAAAA,EAAE,CAAC,gEAAD,EAAmE,kBAAkB;AACrF,YAAMM,WAAW,GAAG,MAAMpB,QAAQ,CAAC,mBAAD,CAAlC;AACA,YAAMwB,OAAO,GAAG,MAAM,6BAAaJ,WAAb,CAAtB;AACA,YAAMU,GAAG,GAAG,MAAMN,OAAO,CAACO,SAAR,CAAkBC,mBAAlB,CAAlB;AACAC,sBAAEC,QAAF,CAAWJ,GAAX,EAAgBpB,MAAhB,CAAuBC,EAAvB,CAA0BwB,IAA1B;AACD,KALC,CAAF;AAMD,GA5BO,CAAR;AA6BD,CAzDO,CAAR","sourcesContent":["import {\n  base64ToImage, imageToBase64, cropImage,\n  getJimpImage, MIME_PNG,\n} from '../lib/image-util';\nimport path from 'path';\nimport _ from 'lodash';\nimport { fs } from '../lib';\n\n\nconst FIXTURES_ROOT = path.resolve(__dirname, '..', '..', 'test', 'images');\n\nasync function getImage (name) {\n  const imagePath = path.resolve(FIXTURES_ROOT, name);\n  return await fs.readFile(imagePath, 'utf8');\n}\n\ndescribe('image-util', function () {\n\n  describe('cropBase64Image', function () {\n    let originalImage = null;\n\n    before(async function () {\n      const originalImage64 = await getImage('full-image.b64');\n      originalImage = await base64ToImage(originalImage64);\n\n      // verify original image size, to be sure that original image is correct\n      originalImage.width.should.be.equal(640, 'unexpected width');\n      originalImage.height.should.be.equal(1136, 'unexpected height');\n    });\n\n    it('should verify that an image is cropped correctly', async function () {\n      const croppedImage = await cropImage(originalImage, {left: 35, top: 107, width: 323, height: 485});\n\n      // verify cropped image size, it should be less than original image according to crop region\n      croppedImage.width.should.be.equal(323, 'unexpected width');\n      croppedImage.height.should.be.equal(485, 'unexpected height');\n\n      // verify that image cropped, compare base64 representation\n      const croppedImageShouldBe = await getImage('cropped-image.b64');\n      const croppedImage64 = await imageToBase64(croppedImage);\n      croppedImage64.should.be.equal(croppedImageShouldBe);\n    });\n  });\n\n  describe('Jimp helpers', function () {\n    it('should get a jimp object using image buffer', async function () {\n      const base64Image = await getImage('cropped-image.b64');\n      const imageBuffer = Buffer.from(base64Image, 'base64');\n      const jimpImg = await getJimpImage(imageBuffer);\n      jimpImg.hash().should.eql('80000000000');\n      jimpImg.bitmap.height.should.eql(485);\n      jimpImg.bitmap.width.should.eql(323);\n    });\n    it('should get a jimp object using b64 string', async function () {\n      const base64Image = await getImage('cropped-image.b64');\n      const jimpImg = await getJimpImage(base64Image);\n      jimpImg.hash().should.eql('80000000000');\n      jimpImg.bitmap.height.should.eql(485);\n      jimpImg.bitmap.width.should.eql(323);\n    });\n    it('should error with incorrect data type', async function () {\n      await getJimpImage(1234).should.eventually.be.rejectedWith(/string or buffer/);\n    });\n    it('should error with incorrect image data', async function () {\n      await getJimpImage('foo').should.eventually.be.rejectedWith(/Could not find MIME for Buffer/);\n    });\n    it('should get an image buffer via the overridden getBuffer method', async function () {\n      const base64Image = await getImage('cropped-image.b64');\n      const jimpImg = await getJimpImage(base64Image);\n      const buf = await jimpImg.getBuffer(MIME_PNG);\n      _.isBuffer(buf).should.be.true;\n    });\n  });\n});\n"],"file":"test/image-util-e2e-specs.js","sourceRoot":"../.."}
|
|
@@ -1,49 +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 = _interopRequireDefault(require("../lib/index.js"));
|
|
8
|
-
|
|
9
|
-
let {
|
|
10
|
-
system,
|
|
11
|
-
tempDir,
|
|
12
|
-
util
|
|
13
|
-
} = _index.default;
|
|
14
|
-
describe('index', function () {
|
|
15
|
-
describe('default', function () {
|
|
16
|
-
it('should expose an object', function () {
|
|
17
|
-
_index.default.should.exist;
|
|
18
|
-
|
|
19
|
-
_index.default.should.be.an.instanceof(Object);
|
|
20
|
-
});
|
|
21
|
-
it('should expose system object', function () {
|
|
22
|
-
_index.default.system.should.exist;
|
|
23
|
-
|
|
24
|
-
_index.default.system.should.be.an.instanceof(Object);
|
|
25
|
-
});
|
|
26
|
-
it('should expose tempDir object', function () {
|
|
27
|
-
_index.default.tempDir.should.exist;
|
|
28
|
-
|
|
29
|
-
_index.default.tempDir.should.be.an.instanceof(Object);
|
|
30
|
-
});
|
|
31
|
-
it('should expose util object', function () {
|
|
32
|
-
_index.default.util.should.exist;
|
|
33
|
-
|
|
34
|
-
_index.default.util.should.be.an.instanceof(Object);
|
|
35
|
-
});
|
|
36
|
-
});
|
|
37
|
-
it('should expose an object as "system" ', function () {
|
|
38
|
-
system.should.be.an.instanceof(Object);
|
|
39
|
-
});
|
|
40
|
-
it('should expose an object as "tempDir" ', function () {
|
|
41
|
-
tempDir.should.be.an.instanceof(Object);
|
|
42
|
-
});
|
|
43
|
-
it('should expose an object as "util" ', function () {
|
|
44
|
-
util.should.be.an.instanceof(Object);
|
|
45
|
-
});
|
|
46
|
-
});require('source-map-support').install();
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRlc3QvaW5kZXgtc3BlY3MuanMiXSwibmFtZXMiOlsic3lzdGVtIiwidGVtcERpciIsInV0aWwiLCJBcHBpdW1TdXBwb3J0IiwiZGVzY3JpYmUiLCJpdCIsInNob3VsZCIsImV4aXN0IiwiYmUiLCJhbiIsImluc3RhbmNlb2YiLCJPYmplY3QiXSwibWFwcGluZ3MiOiI7Ozs7OztBQUNBOztBQUVBLElBQUk7QUFBRUEsRUFBQUEsTUFBRjtBQUFVQyxFQUFBQSxPQUFWO0FBQW1CQyxFQUFBQTtBQUFuQixJQUE0QkMsY0FBaEM7QUFFQUMsUUFBUSxDQUFDLE9BQUQsRUFBVSxZQUFZO0FBQzVCQSxFQUFBQSxRQUFRLENBQUMsU0FBRCxFQUFZLFlBQVk7QUFDOUJDLElBQUFBLEVBQUUsQ0FBQyx5QkFBRCxFQUE0QixZQUFZO0FBQ3hDRixxQkFBY0csTUFBZCxDQUFxQkMsS0FBckI7O0FBQ0FKLHFCQUFjRyxNQUFkLENBQXFCRSxFQUFyQixDQUF3QkMsRUFBeEIsQ0FBMkJDLFVBQTNCLENBQXNDQyxNQUF0QztBQUNELEtBSEMsQ0FBRjtBQUlBTixJQUFBQSxFQUFFLENBQUMsNkJBQUQsRUFBZ0MsWUFBWTtBQUM1Q0YscUJBQWNILE1BQWQsQ0FBcUJNLE1BQXJCLENBQTRCQyxLQUE1Qjs7QUFDQUoscUJBQWNILE1BQWQsQ0FBcUJNLE1BQXJCLENBQTRCRSxFQUE1QixDQUErQkMsRUFBL0IsQ0FBa0NDLFVBQWxDLENBQTZDQyxNQUE3QztBQUNELEtBSEMsQ0FBRjtBQUlBTixJQUFBQSxFQUFFLENBQUMsOEJBQUQsRUFBaUMsWUFBWTtBQUM3Q0YscUJBQWNGLE9BQWQsQ0FBc0JLLE1BQXRCLENBQTZCQyxLQUE3Qjs7QUFDQUoscUJBQWNGLE9BQWQsQ0FBc0JLLE1BQXRCLENBQTZCRSxFQUE3QixDQUFnQ0MsRUFBaEMsQ0FBbUNDLFVBQW5DLENBQThDQyxNQUE5QztBQUNELEtBSEMsQ0FBRjtBQUlBTixJQUFBQSxFQUFFLENBQUMsMkJBQUQsRUFBOEIsWUFBWTtBQUMxQ0YscUJBQWNELElBQWQsQ0FBbUJJLE1BQW5CLENBQTBCQyxLQUExQjs7QUFDQUoscUJBQWNELElBQWQsQ0FBbUJJLE1BQW5CLENBQTBCRSxFQUExQixDQUE2QkMsRUFBN0IsQ0FBZ0NDLFVBQWhDLENBQTJDQyxNQUEzQztBQUNELEtBSEMsQ0FBRjtBQUlELEdBakJPLENBQVI7QUFtQkFOLEVBQUFBLEVBQUUsQ0FBQyxzQ0FBRCxFQUF5QyxZQUFZO0FBQ3JETCxJQUFBQSxNQUFNLENBQUNNLE1BQVAsQ0FBY0UsRUFBZCxDQUFpQkMsRUFBakIsQ0FBb0JDLFVBQXBCLENBQStCQyxNQUEvQjtBQUNELEdBRkMsQ0FBRjtBQUlBTixFQUFBQSxFQUFFLENBQUMsdUNBQUQsRUFBMEMsWUFBWTtBQUN0REosSUFBQUEsT0FBTyxDQUFDSyxNQUFSLENBQWVFLEVBQWYsQ0FBa0JDLEVBQWxCLENBQXFCQyxVQUFyQixDQUFnQ0MsTUFBaEM7QUFDRCxHQUZDLENBQUY7QUFJQU4sRUFBQUEsRUFBRSxDQUFDLG9DQUFELEVBQXVDLFlBQVk7QUFDbkRILElBQUFBLElBQUksQ0FBQ0ksTUFBTCxDQUFZRSxFQUFaLENBQWVDLEVBQWYsQ0FBa0JDLFVBQWxCLENBQTZCQyxNQUE3QjtBQUNELEdBRkMsQ0FBRjtBQUdELENBL0JPLENBQVIiLCJzb3VyY2VzQ29udGVudCI6WyJcbmltcG9ydCBBcHBpdW1TdXBwb3J0IGZyb20gJy4uL2xpYi9pbmRleC5qcyc7XG5cbmxldCB7IHN5c3RlbSwgdGVtcERpciwgdXRpbCB9ID0gQXBwaXVtU3VwcG9ydDtcblxuZGVzY3JpYmUoJ2luZGV4JywgZnVuY3Rpb24gKCkge1xuICBkZXNjcmliZSgnZGVmYXVsdCcsIGZ1bmN0aW9uICgpIHtcbiAgICBpdCgnc2hvdWxkIGV4cG9zZSBhbiBvYmplY3QnLCBmdW5jdGlvbiAoKSB7XG4gICAgICBBcHBpdW1TdXBwb3J0LnNob3VsZC5leGlzdDtcbiAgICAgIEFwcGl1bVN1cHBvcnQuc2hvdWxkLmJlLmFuLmluc3RhbmNlb2YoT2JqZWN0KTtcbiAgICB9KTtcbiAgICBpdCgnc2hvdWxkIGV4cG9zZSBzeXN0ZW0gb2JqZWN0JywgZnVuY3Rpb24gKCkge1xuICAgICAgQXBwaXVtU3VwcG9ydC5zeXN0ZW0uc2hvdWxkLmV4aXN0O1xuICAgICAgQXBwaXVtU3VwcG9ydC5zeXN0ZW0uc2hvdWxkLmJlLmFuLmluc3RhbmNlb2YoT2JqZWN0KTtcbiAgICB9KTtcbiAgICBpdCgnc2hvdWxkIGV4cG9zZSB0ZW1wRGlyIG9iamVjdCcsIGZ1bmN0aW9uICgpIHtcbiAgICAgIEFwcGl1bVN1cHBvcnQudGVtcERpci5zaG91bGQuZXhpc3Q7XG4gICAgICBBcHBpdW1TdXBwb3J0LnRlbXBEaXIuc2hvdWxkLmJlLmFuLmluc3RhbmNlb2YoT2JqZWN0KTtcbiAgICB9KTtcbiAgICBpdCgnc2hvdWxkIGV4cG9zZSB1dGlsIG9iamVjdCcsIGZ1bmN0aW9uICgpIHtcbiAgICAgIEFwcGl1bVN1cHBvcnQudXRpbC5zaG91bGQuZXhpc3Q7XG4gICAgICBBcHBpdW1TdXBwb3J0LnV0aWwuc2hvdWxkLmJlLmFuLmluc3RhbmNlb2YoT2JqZWN0KTtcbiAgICB9KTtcbiAgfSk7XG5cbiAgaXQoJ3Nob3VsZCBleHBvc2UgYW4gb2JqZWN0IGFzIFwic3lzdGVtXCIgJywgZnVuY3Rpb24gKCkge1xuICAgIHN5c3RlbS5zaG91bGQuYmUuYW4uaW5zdGFuY2VvZihPYmplY3QpO1xuICB9KTtcblxuICBpdCgnc2hvdWxkIGV4cG9zZSBhbiBvYmplY3QgYXMgXCJ0ZW1wRGlyXCIgJywgZnVuY3Rpb24gKCkge1xuICAgIHRlbXBEaXIuc2hvdWxkLmJlLmFuLmluc3RhbmNlb2YoT2JqZWN0KTtcbiAgfSk7XG5cbiAgaXQoJ3Nob3VsZCBleHBvc2UgYW4gb2JqZWN0IGFzIFwidXRpbFwiICcsIGZ1bmN0aW9uICgpIHtcbiAgICB1dGlsLnNob3VsZC5iZS5hbi5pbnN0YW5jZW9mKE9iamVjdCk7XG4gIH0pO1xufSk7XG4iXSwiZmlsZSI6InRlc3QvaW5kZXgtc3BlY3MuanMiLCJzb3VyY2VSb290IjoiLi4vLi4ifQ==
|
|
@@ -1,97 +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");
|
|
8
|
-
|
|
9
|
-
var _os = _interopRequireDefault(require("os"));
|
|
10
|
-
|
|
11
|
-
var _path = _interopRequireDefault(require("path"));
|
|
12
|
-
|
|
13
|
-
var _logInternal = require("../lib/log-internal");
|
|
14
|
-
|
|
15
|
-
const CONFIG_PATH = _path.default.resolve(_os.default.tmpdir(), 'rules.json');
|
|
16
|
-
|
|
17
|
-
describe('Log Internals', function () {
|
|
18
|
-
let preprocessor;
|
|
19
|
-
beforeEach(function () {
|
|
20
|
-
preprocessor = new _logInternal.SecureValuesPreprocessor();
|
|
21
|
-
});
|
|
22
|
-
it('should preprocess a string and make replacements', async function () {
|
|
23
|
-
const issues = await preprocessor.loadRules(['yolo']);
|
|
24
|
-
issues.length.should.eql(0);
|
|
25
|
-
preprocessor.rules.length.should.eql(1);
|
|
26
|
-
const replacer = preprocessor.rules[0].replacer;
|
|
27
|
-
preprocessor.preprocess(':yolo" yo Yolo yyolo').should.eql(`:${replacer}" yo Yolo yyolo`);
|
|
28
|
-
});
|
|
29
|
-
it('should preprocess a string and make replacements with multiple simple rules', async function () {
|
|
30
|
-
const issues = await preprocessor.loadRules(['yolo', 'yo']);
|
|
31
|
-
issues.length.should.eql(0);
|
|
32
|
-
preprocessor.rules.length.should.eql(2);
|
|
33
|
-
const replacer = preprocessor.rules[0].replacer;
|
|
34
|
-
preprocessor.preprocess(':yolo" yo Yolo yyolo').should.eql(`:${replacer}" ${replacer} Yolo yyolo`);
|
|
35
|
-
});
|
|
36
|
-
it('should preprocess a string and make replacements with multiple complex rules', async function () {
|
|
37
|
-
const replacer2 = '***';
|
|
38
|
-
const issues = await preprocessor.loadRules([{
|
|
39
|
-
text: 'yolo',
|
|
40
|
-
flags: 'i'
|
|
41
|
-
}, {
|
|
42
|
-
pattern: '^:',
|
|
43
|
-
replacer: replacer2
|
|
44
|
-
}]);
|
|
45
|
-
issues.length.should.eql(0);
|
|
46
|
-
preprocessor.rules.length.should.eql(2);
|
|
47
|
-
const replacer = preprocessor.rules[0].replacer;
|
|
48
|
-
preprocessor.preprocess(':yolo" yo Yolo yyolo').should.eql(`${replacer2}${replacer}" yo ${replacer} yyolo`);
|
|
49
|
-
});
|
|
50
|
-
it(`should preprocess a string and apply a rule where 'pattern' has priority over 'text'`, async function () {
|
|
51
|
-
const replacer = '***';
|
|
52
|
-
const issues = await preprocessor.loadRules([{
|
|
53
|
-
pattern: '^:',
|
|
54
|
-
text: 'yo',
|
|
55
|
-
replacer
|
|
56
|
-
}]);
|
|
57
|
-
issues.length.should.eql(0);
|
|
58
|
-
preprocessor.rules.length.should.eql(1);
|
|
59
|
-
preprocessor.preprocess(':yolo" yo Yolo yyolo').should.eql(`${replacer}yolo" yo Yolo yyolo`);
|
|
60
|
-
});
|
|
61
|
-
it('should preprocess a string and make replacements with multiple complex rules and issues', async function () {
|
|
62
|
-
const replacer2 = '***';
|
|
63
|
-
const issues = await preprocessor.loadRules([{
|
|
64
|
-
text: 'yolo',
|
|
65
|
-
flags: 'i'
|
|
66
|
-
}, {
|
|
67
|
-
pattern: '^:(',
|
|
68
|
-
replacer: replacer2
|
|
69
|
-
}]);
|
|
70
|
-
issues.length.should.eql(1);
|
|
71
|
-
preprocessor.rules.length.should.eql(1);
|
|
72
|
-
const replacer = preprocessor.rules[0].replacer;
|
|
73
|
-
preprocessor.preprocess(':yolo" yo Yolo yyolo').should.eql(`:${replacer}" yo ${replacer} yyolo`);
|
|
74
|
-
});
|
|
75
|
-
it('should leave the string unchanged if all rules have issues', async function () {
|
|
76
|
-
const replacer2 = '***';
|
|
77
|
-
const issues = await preprocessor.loadRules([null, {
|
|
78
|
-
flags: 'i'
|
|
79
|
-
}, {
|
|
80
|
-
pattern: '^:(',
|
|
81
|
-
replacer: replacer2
|
|
82
|
-
}]);
|
|
83
|
-
issues.length.should.eql(3);
|
|
84
|
-
preprocessor.rules.length.should.eql(0);
|
|
85
|
-
preprocessor.preprocess(':yolo" yo Yolo yyolo').should.eql(':yolo" yo Yolo yyolo');
|
|
86
|
-
});
|
|
87
|
-
it('should fail if rules cannot be accessed', async function () {
|
|
88
|
-
await preprocessor.loadRules('bla').should.eventually.be.rejected;
|
|
89
|
-
});
|
|
90
|
-
it('should fail if rules JSON cannot be parsed', async function () {
|
|
91
|
-
await _index.fs.writeFile(CONFIG_PATH, 'blabla', 'utf8');
|
|
92
|
-
await preprocessor.loadRules(CONFIG_PATH).should.eventually.be.rejected;
|
|
93
|
-
});
|
|
94
|
-
});require('source-map-support').install();
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["test/log-internals-specs.js"],"names":["CONFIG_PATH","path","resolve","os","tmpdir","describe","preprocessor","beforeEach","SecureValuesPreprocessor","it","issues","loadRules","length","should","eql","rules","replacer","preprocess","replacer2","text","flags","pattern","eventually","be","rejected","fs","writeFile"],"mappings":"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","sourcesContent":["import { fs } from '../lib/index';\nimport os from 'os';\nimport path from 'path';\nimport { SecureValuesPreprocessor } from '../lib/log-internal';\n\n\nconst CONFIG_PATH = path.resolve(os.tmpdir(), 'rules.json');\n\n\n\n\ndescribe('Log Internals', function () {\n  let preprocessor;\n\n  beforeEach(function () {\n    preprocessor = new SecureValuesPreprocessor();\n  });\n\n  it('should preprocess a string and make replacements', async function () {\n    const issues = await preprocessor.loadRules([\n      'yolo',\n    ]);\n    issues.length.should.eql(0);\n    preprocessor.rules.length.should.eql(1);\n    const replacer = preprocessor.rules[0].replacer;\n    preprocessor.preprocess(':yolo\" yo Yolo yyolo').should.eql(`:${replacer}\" yo Yolo yyolo`);\n  });\n\n  it('should preprocess a string and make replacements with multiple simple rules', async function () {\n    const issues = await preprocessor.loadRules([\n      'yolo',\n      'yo',\n    ]);\n    issues.length.should.eql(0);\n    preprocessor.rules.length.should.eql(2);\n    const replacer = preprocessor.rules[0].replacer;\n    preprocessor.preprocess(':yolo\" yo Yolo yyolo').should.eql(`:${replacer}\" ${replacer} Yolo yyolo`);\n  });\n\n  it('should preprocess a string and make replacements with multiple complex rules', async function () {\n    const replacer2 = '***';\n    const issues = await preprocessor.loadRules([\n      { text: 'yolo', flags: 'i' },\n      { pattern: '^:', replacer: replacer2 },\n    ]);\n    issues.length.should.eql(0);\n    preprocessor.rules.length.should.eql(2);\n    const replacer = preprocessor.rules[0].replacer;\n    preprocessor.preprocess(':yolo\" yo Yolo yyolo').should.eql(`${replacer2}${replacer}\" yo ${replacer} yyolo`);\n  });\n\n  it(`should preprocess a string and apply a rule where 'pattern' has priority over 'text'`, async function () {\n    const replacer = '***';\n    const issues = await preprocessor.loadRules([\n      { pattern: '^:', text: 'yo', replacer },\n    ]);\n    issues.length.should.eql(0);\n    preprocessor.rules.length.should.eql(1);\n    preprocessor.preprocess(':yolo\" yo Yolo yyolo').should.eql(`${replacer}yolo\" yo Yolo yyolo`);\n  });\n\n  it('should preprocess a string and make replacements with multiple complex rules and issues', async function () {\n    const replacer2 = '***';\n    const issues = await preprocessor.loadRules([\n      { text: 'yolo', flags: 'i' },\n      { pattern: '^:(', replacer: replacer2 },\n    ]);\n    issues.length.should.eql(1);\n    preprocessor.rules.length.should.eql(1);\n    const replacer = preprocessor.rules[0].replacer;\n    preprocessor.preprocess(':yolo\" yo Yolo yyolo').should.eql(`:${replacer}\" yo ${replacer} yyolo`);\n  });\n\n  it('should leave the string unchanged if all rules have issues', async function () {\n    const replacer2 = '***';\n    const issues = await preprocessor.loadRules([\n      null,\n      { flags: 'i' },\n      { pattern: '^:(', replacer: replacer2 },\n    ]);\n    issues.length.should.eql(3);\n    preprocessor.rules.length.should.eql(0);\n    preprocessor.preprocess(':yolo\" yo Yolo yyolo').should.eql(':yolo\" yo Yolo yyolo');\n  });\n\n  it('should fail if rules cannot be accessed', async function () {\n    await preprocessor.loadRules('bla').should.eventually.be.rejected;\n  });\n\n  it('should fail if rules JSON cannot be parsed', async function () {\n    await fs.writeFile(CONFIG_PATH, 'blabla', 'utf8');\n    await preprocessor.loadRules(CONFIG_PATH).should.eventually.be.rejected;\n  });\n});\n"],"file":"test/log-internals-specs.js","sourceRoot":"../.."}
|