@appium/support 2.55.2 → 2.56.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (55) hide show
  1. package/build/lib/env.js +102 -0
  2. package/build/lib/fs.js +74 -56
  3. package/build/lib/image-util.js +4 -332
  4. package/build/lib/index.js +18 -6
  5. package/build/lib/log-internal.js +2 -4
  6. package/build/lib/logger.js +2 -4
  7. package/build/lib/logging.js +2 -4
  8. package/build/lib/mjpeg.js +2 -4
  9. package/build/lib/mkdirp.js +7 -11
  10. package/build/lib/net.js +2 -4
  11. package/build/lib/node.js +99 -2
  12. package/build/lib/npm.js +240 -0
  13. package/build/lib/plist.js +2 -4
  14. package/build/lib/process.js +2 -4
  15. package/build/lib/system.js +2 -4
  16. package/build/lib/tempdir.js +2 -4
  17. package/build/lib/timing.js +2 -4
  18. package/build/lib/util.js +6 -8
  19. package/build/lib/zip.js +4 -8
  20. package/lib/env.js +162 -0
  21. package/lib/fs.js +193 -69
  22. package/lib/image-util.js +3 -570
  23. package/lib/index.js +8 -2
  24. package/lib/log-internal.js +2 -2
  25. package/lib/logging.js +1 -1
  26. package/lib/mkdirp.js +3 -6
  27. package/lib/net.js +4 -4
  28. package/lib/node.js +104 -1
  29. package/lib/npm.js +335 -0
  30. package/lib/tempdir.js +6 -6
  31. package/lib/util.js +28 -24
  32. package/lib/zip.js +7 -8
  33. package/package.json +20 -9
  34. package/build/test/assets/sample_binary.plist +0 -0
  35. package/build/test/assets/sample_text.plist +0 -28
  36. package/build/test/fs-specs.js +0 -264
  37. package/build/test/helpers.js +0 -35
  38. package/build/test/image-util-e2e-specs.js +0 -227
  39. package/build/test/index-specs.js +0 -49
  40. package/build/test/log-internals-specs.js +0 -97
  41. package/build/test/logger/helpers.js +0 -71
  42. package/build/test/logger/logger-force-specs.js +0 -41
  43. package/build/test/logger/logger-normal-specs.js +0 -113
  44. package/build/test/logger/logger-test-specs.js +0 -40
  45. package/build/test/mjpeg-e2e-specs.js +0 -96
  46. package/build/test/net-e2e-specs.js +0 -32
  47. package/build/test/node-e2e-specs.js +0 -22
  48. package/build/test/plist-specs.js +0 -54
  49. package/build/test/process-specs.js +0 -104
  50. package/build/test/system-specs.js +0 -136
  51. package/build/test/tempdir-specs.js +0 -86
  52. package/build/test/timing-specs.js +0 -125
  53. package/build/test/util-e2e-specs.js +0 -136
  54. package/build/test/util-specs.js +0 -537
  55. package/build/test/zip-e2e-specs.js +0 -233
@@ -1,233 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- require("source-map-support/register");
6
-
7
- var _path = _interopRequireDefault(require("path"));
8
-
9
- var zip = _interopRequireWildcard(require("../lib/zip"));
10
-
11
- var _index = require("../lib/index");
12
-
13
- var _helpers = require("./helpers");
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('#zip', function () {
20
- const optionMap = new Map([['native JS unzip', {}], ['system unzip', {
21
- useSystemUnzip: true
22
- }]]);
23
- optionMap.forEach((options, desc) => {
24
- describe(desc, function () {
25
- let assetsPath;
26
- let zippedFilePath;
27
- let tmpRoot;
28
- beforeEach(async function () {
29
- assetsPath = await _index.tempDir.openDir();
30
- tmpRoot = await _index.tempDir.openDir();
31
- const zippedBase64 = 'UEsDBAoAAAAAALlzk0oAAAAAAAAAAAAAAAAJABAAdW56aXBwZWQvVVgMANBO+VjO1vdY9QEUAFBLAwQKAAAAAADAc5NKAAAAAAAAAAAAAAAAEgAQAHVuemlwcGVkL3Rlc3QtZGlyL1VYDADQTvlY19b3WPUBFABQSwMEFAAIAAgAwnOTSgAAAAAAAAAAAAAAABcAEAB1bnppcHBlZC90ZXN0LWRpci9hLnR4dFVYDACDTvlY3Nb3WPUBFADzSM3JyVcIzy/KSQEAUEsHCFaxF0oNAAAACwAAAFBLAwQUAAgACADEc5NKAAAAAAAAAAAAAAAAFwAQAHVuemlwcGVkL3Rlc3QtZGlyL2IudHh0VVgMAINO+Vjf1vdY9QEUAHPLz1dwSiwCAFBLBwhIfrZJCQAAAAcAAABQSwECFQMKAAAAAAC5c5NKAAAAAAAAAAAAAAAACQAMAAAAAAAAAABA7UEAAAAAdW56aXBwZWQvVVgIANBO+VjO1vdYUEsBAhUDCgAAAAAAwHOTSgAAAAAAAAAAAAAAABIADAAAAAAAAAAAQO1BNwAAAHVuemlwcGVkL3Rlc3QtZGlyL1VYCADQTvlY19b3WFBLAQIVAxQACAAIAMJzk0pWsRdKDQAAAAsAAAAXAAwAAAAAAAAAAECkgXcAAAB1bnppcHBlZC90ZXN0LWRpci9hLnR4dFVYCACDTvlY3Nb3WFBLAQIVAxQACAAIAMRzk0pIfrZJCQAAAAcAAAAXAAwAAAAAAAAAAECkgdkAAAB1bnppcHBlZC90ZXN0LWRpci9iLnR4dFVYCACDTvlY39b3WFBLBQYAAAAABAAEADEBAAA3AQAAAAA=';
32
- zippedFilePath = _path.default.resolve(tmpRoot, 'zipped.zip');
33
- await _index.fs.writeFile(zippedFilePath, zippedBase64, 'base64');
34
- await zip.extractAllTo(zippedFilePath, assetsPath, options);
35
- });
36
- afterEach(async function () {
37
- for (const tmpPath of [assetsPath, tmpRoot]) {
38
- if (!(await _index.fs.exists(tmpPath))) {
39
- continue;
40
- }
41
-
42
- await _index.fs.rimraf(tmpPath);
43
- }
44
- });
45
- describe('extractAllTo()', function () {
46
- it('should extract contents of a .zip file to a directory', async function () {
47
- await _index.fs.readFile(_path.default.resolve(assetsPath, 'unzipped', 'test-dir', 'a.txt'), {
48
- encoding: 'utf8'
49
- }).should.eventually.equal('Hello World');
50
- await _index.fs.readFile(_path.default.resolve(assetsPath, 'unzipped', 'test-dir', 'b.txt'), {
51
- encoding: 'utf8'
52
- }).should.eventually.equal('Foo Bar');
53
- });
54
- });
55
- describe('assertValidZip', function () {
56
- it('should not throw an error if a valid ZIP file is passed', async function () {
57
- await zip.assertValidZip(zippedFilePath).should.eventually.be.fulfilled;
58
- });
59
- it('should throw an error if the file does not exist', async function () {
60
- await zip.assertValidZip('blabla').should.eventually.be.rejected;
61
- });
62
- it('should throw an error if the file is invalid', async function () {
63
- await zip.assertValidZip(_path.default.resolve(assetsPath, 'unzipped', 'test-dir', 'a.txt')).should.eventually.be.rejected;
64
- });
65
- });
66
- describe('readEntries()', function () {
67
- const expectedEntries = [{
68
- name: 'unzipped/'
69
- }, {
70
- name: 'unzipped/test-dir/'
71
- }, {
72
- name: 'unzipped/test-dir/a.txt',
73
- contents: 'Hello World'
74
- }, {
75
- name: 'unzipped/test-dir/b.txt',
76
- contents: 'Foo Bar'
77
- }];
78
- it('should iterate entries (directories and files) of zip file', async function () {
79
- let i = 0;
80
- await zip.readEntries(zippedFilePath, async ({
81
- entry,
82
- extractEntryTo
83
- }) => {
84
- entry.fileName.should.equal(expectedEntries[i].name);
85
-
86
- if (expectedEntries[i].contents) {
87
- await extractEntryTo(tmpRoot);
88
- await _index.fs.readFile(_path.default.resolve(tmpRoot, entry.fileName), {
89
- flags: 'r',
90
- encoding: 'utf8'
91
- }).should.eventually.equal(expectedEntries[i].contents);
92
- }
93
-
94
- i++;
95
- });
96
- });
97
- it('should stop iterating zipFile if onEntry callback returns false', async function () {
98
- let i = 0;
99
- await zip.readEntries(zippedFilePath, async () => {
100
- i++;
101
- return false;
102
- });
103
- i.should.equal(1);
104
- });
105
- it('should be rejected if it uses a non-zip file', async function () {
106
- let promise = zip.readEntries(_path.default.resolve(assetsPath, 'unzipped', 'test-dir', 'a.txt'), async () => {});
107
- await promise.should.eventually.be.rejected;
108
- });
109
- });
110
- describe('toInMemoryZip()', function () {
111
- it('should convert a local file to an in-memory zip buffer', async function () {
112
- const testFolder = _path.default.resolve(assetsPath, 'unzipped');
113
-
114
- const buffer = await zip.toInMemoryZip(testFolder);
115
- Buffer.isBuffer(buffer).should.be.true;
116
- await _index.fs.writeFile(_path.default.resolve(tmpRoot, 'test.zip'), buffer);
117
- await zip.extractAllTo(_path.default.resolve(tmpRoot, 'test.zip'), _path.default.resolve(tmpRoot, 'output'), {
118
- fileNamesEncoding: 'utf8'
119
- });
120
- await _index.fs.readFile(_path.default.resolve(tmpRoot, 'output', 'test-dir', 'a.txt'), {
121
- encoding: 'utf8'
122
- }).should.eventually.equal('Hello World');
123
- await _index.fs.readFile(_path.default.resolve(tmpRoot, 'output', 'test-dir', 'b.txt'), {
124
- encoding: 'utf8'
125
- }).should.eventually.equal('Foo Bar');
126
- });
127
- it('should convert a local folder to an in-memory base64-encoded zip buffer', async function () {
128
- const testFolder = _path.default.resolve(assetsPath, 'unzipped');
129
-
130
- const buffer = await zip.toInMemoryZip(testFolder, {
131
- encodeToBase64: true
132
- });
133
- await _index.fs.writeFile(_path.default.resolve(tmpRoot, 'test.zip'), Buffer.from(buffer.toString(), 'base64'));
134
- await zip.extractAllTo(_path.default.resolve(tmpRoot, 'test.zip'), _path.default.resolve(tmpRoot, 'output'));
135
- await _index.fs.readFile(_path.default.resolve(tmpRoot, 'output', 'test-dir', 'a.txt'), {
136
- encoding: 'utf8'
137
- }).should.eventually.equal('Hello World');
138
- await _index.fs.readFile(_path.default.resolve(tmpRoot, 'output', 'test-dir', 'b.txt'), {
139
- encoding: 'utf8'
140
- }).should.eventually.equal('Foo Bar');
141
- });
142
- it('should be rejected if use a bad path', async function () {
143
- await zip.toInMemoryZip(_path.default.resolve(assetsPath, 'bad_path')).should.be.rejectedWith(/no such/i);
144
- });
145
- it('should be rejected if max size is exceeded', async function () {
146
- const testFolder = _path.default.resolve(assetsPath, 'unzipped');
147
-
148
- await zip.toInMemoryZip(testFolder, {
149
- maxSize: 1
150
- }).should.be.rejectedWith(/must not be greater/);
151
- });
152
- });
153
- describe('_extractEntryTo()', function () {
154
- let entry, mockZipFile, mockZipStream;
155
- beforeEach(async function () {
156
- entry = {
157
- fileName: _path.default.resolve(await _index.tempDir.openDir(), 'temp', 'file')
158
- };
159
- mockZipStream = new _helpers.MockReadWriteStream();
160
- mockZipFile = {
161
- openReadStream: (entry, cb) => cb(null, mockZipStream)
162
- };
163
- });
164
- it('should be rejected if zip stream emits an error', async function () {
165
- mockZipStream.pipe = () => {
166
- mockZipStream.emit('error', new Error('zip stream error'));
167
- };
168
-
169
- await zip._extractEntryTo(mockZipFile, entry).should.be.rejectedWith('zip stream error');
170
- });
171
- it('should be rejected if write stream emits an error', async function () {
172
- mockZipStream.pipe = writeStream => {
173
- writeStream.emit('error', new Error('write stream error'));
174
- mockZipStream.end();
175
- writeStream.end();
176
- };
177
-
178
- await zip._extractEntryTo(mockZipFile, entry).should.be.rejectedWith('write stream error');
179
- });
180
- });
181
- describe('toArchive', function () {
182
- it('should zip all files into an archive', async function () {
183
- const testFolder = _path.default.resolve(assetsPath, 'unzipped');
184
-
185
- const dstPath = _path.default.resolve(tmpRoot, 'test.zip');
186
-
187
- await zip.toArchive(dstPath, {
188
- cwd: testFolder
189
- });
190
- await zip.extractAllTo(dstPath, _path.default.resolve(tmpRoot, 'output'));
191
- await _index.fs.readFile(_path.default.resolve(tmpRoot, 'output', 'test-dir', 'a.txt'), {
192
- encoding: 'utf8'
193
- }).should.eventually.equal('Hello World');
194
- await _index.fs.readFile(_path.default.resolve(tmpRoot, 'output', 'test-dir', 'b.txt'), {
195
- encoding: 'utf8'
196
- }).should.eventually.equal('Foo Bar');
197
- });
198
- });
199
- });
200
- });
201
- describe('unicode filename handling', function () {
202
- let zippedFilePath, assetsPath, tmpRoot;
203
- beforeEach(async function () {
204
- assetsPath = await _index.tempDir.openDir();
205
- tmpRoot = await _index.tempDir.openDir();
206
- const zippedBase64 = 'UEsDBBQACAAIABF8/EYAAAAAAAAAABoAAAATACAAa2Fuamkt5q2j5LiW5LiVLmFwcFVUDQAHAgO4VVpX+GBZV/hgdXgLAAEE9QEAAAQUAAAAK8nILFYAorz8EoWi1MScnEqFxDyFxIICLgBQSwcIR93jPhoAAAAaAAAAUEsBAhQDFAAIAAgAEXz8Rkfd4z4aAAAAGgAAABMAIAAAAAAAAAAAAKSBAAAAAGthbmppLeato+S4luS4lS5hcHBVVA0ABwIDuFVaV/hgWVf4YHV4CwABBPUBAAAEFAAAAFBLBQYAAAAAAQABAGEAAAB7AAAAAAA=';
207
- zippedFilePath = _path.default.resolve(tmpRoot, 'zipped.zip');
208
- await _index.fs.writeFile(zippedFilePath, zippedBase64, 'base64');
209
- await zip.extractAllTo(zippedFilePath, assetsPath, {
210
- useSystemUnzip: true
211
- });
212
- });
213
- afterEach(async function () {
214
- for (const tmpPath of [assetsPath, tmpRoot]) {
215
- if (!(await _index.fs.exists(tmpPath))) {
216
- continue;
217
- }
218
-
219
- await _index.fs.rimraf(tmpPath);
220
- }
221
- });
222
- it('should retain the proper filenames', async function () {
223
- const expectedPath = _path.default.join(assetsPath, 'kanji-正世丕.app');
224
-
225
- if (!(await _index.fs.exists(expectedPath))) {
226
- throw new chai.AssertionError(`Expected ${expectedPath} to exist, but it does not`);
227
- }
228
- });
229
- });
230
- });require('source-map-support').install();
231
-
232
-
233
- //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["test/zip-e2e-specs.js"],"names":["describe","optionMap","Map","useSystemUnzip","forEach","options","desc","assetsPath","zippedFilePath","tmpRoot","beforeEach","tempDir","openDir","zippedBase64","path","resolve","fs","writeFile","zip","extractAllTo","afterEach","tmpPath","exists","rimraf","it","readFile","encoding","should","eventually","equal","assertValidZip","be","fulfilled","rejected","expectedEntries","name","contents","i","readEntries","entry","extractEntryTo","fileName","flags","promise","testFolder","buffer","toInMemoryZip","Buffer","isBuffer","true","fileNamesEncoding","encodeToBase64","from","toString","rejectedWith","maxSize","mockZipFile","mockZipStream","MockReadWriteStream","openReadStream","cb","pipe","emit","Error","_extractEntryTo","writeStream","end","dstPath","toArchive","cwd","expectedPath","join","chai","AssertionError"],"mappings":"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","sourcesContent":["import path from 'path';\nimport * as zip from '../lib/zip';\nimport { tempDir, fs } from '../lib/index';\nimport { MockReadWriteStream } from './helpers';\n\n\ndescribe('#zip', function () {\n\n  const optionMap = new Map([['native JS unzip', {}], ['system unzip', {useSystemUnzip: true}]]);\n\n  optionMap.forEach((options, desc) => {\n    describe(desc, function () {\n      let assetsPath;\n      let zippedFilePath;\n      let tmpRoot;\n\n      beforeEach(async function () {\n        assetsPath = await tempDir.openDir();\n        tmpRoot = await tempDir.openDir();\n        const zippedBase64 = 'UEsDBAoAAAAAALlzk0oAAAAAAAAAAAAAAAAJABAAdW56aXBwZWQvVVgMANBO+VjO1vdY9QEUAFBLAwQKAAAAAADAc5NKAAAAAAAAAAAAAAAAEgAQAHVuemlwcGVkL3Rlc3QtZGlyL1VYDADQTvlY19b3WPUBFABQSwMEFAAIAAgAwnOTSgAAAAAAAAAAAAAAABcAEAB1bnppcHBlZC90ZXN0LWRpci9hLnR4dFVYDACDTvlY3Nb3WPUBFADzSM3JyVcIzy/KSQEAUEsHCFaxF0oNAAAACwAAAFBLAwQUAAgACADEc5NKAAAAAAAAAAAAAAAAFwAQAHVuemlwcGVkL3Rlc3QtZGlyL2IudHh0VVgMAINO+Vjf1vdY9QEUAHPLz1dwSiwCAFBLBwhIfrZJCQAAAAcAAABQSwECFQMKAAAAAAC5c5NKAAAAAAAAAAAAAAAACQAMAAAAAAAAAABA7UEAAAAAdW56aXBwZWQvVVgIANBO+VjO1vdYUEsBAhUDCgAAAAAAwHOTSgAAAAAAAAAAAAAAABIADAAAAAAAAAAAQO1BNwAAAHVuemlwcGVkL3Rlc3QtZGlyL1VYCADQTvlY19b3WFBLAQIVAxQACAAIAMJzk0pWsRdKDQAAAAsAAAAXAAwAAAAAAAAAAECkgXcAAAB1bnppcHBlZC90ZXN0LWRpci9hLnR4dFVYCACDTvlY3Nb3WFBLAQIVAxQACAAIAMRzk0pIfrZJCQAAAAcAAAAXAAwAAAAAAAAAAECkgdkAAAB1bnppcHBlZC90ZXN0LWRpci9iLnR4dFVYCACDTvlY39b3WFBLBQYAAAAABAAEADEBAAA3AQAAAAA=';\n        zippedFilePath = path.resolve(tmpRoot, 'zipped.zip');\n        await fs.writeFile(zippedFilePath, zippedBase64, 'base64');\n        await zip.extractAllTo(zippedFilePath, assetsPath, options);\n      });\n\n      afterEach(async function () {\n        for (const tmpPath of [assetsPath, tmpRoot]) {\n          if (!await fs.exists(tmpPath)) {\n            continue;\n          }\n          await fs.rimraf(tmpPath);\n        }\n      });\n\n      describe('extractAllTo()', function () {\n        it('should extract contents of a .zip file to a directory', async function () {\n          await fs.readFile(path.resolve(assetsPath, 'unzipped', 'test-dir', 'a.txt'), {encoding: 'utf8'}).should.eventually.equal('Hello World');\n          await fs.readFile(path.resolve(assetsPath, 'unzipped', 'test-dir', 'b.txt'), {encoding: 'utf8'}).should.eventually.equal('Foo Bar');\n        });\n      });\n\n      describe('assertValidZip', function () {\n        it('should not throw an error if a valid ZIP file is passed', async function () {\n          await zip.assertValidZip(zippedFilePath).should.eventually.be.fulfilled;\n        });\n        it('should throw an error if the file does not exist', async function () {\n          await zip.assertValidZip('blabla').should.eventually.be.rejected;\n        });\n        it('should throw an error if the file is invalid', async function () {\n          await zip.assertValidZip(path.resolve(assetsPath, 'unzipped', 'test-dir', 'a.txt')).should.eventually.be.rejected;\n        });\n      });\n\n      describe('readEntries()', function () {\n        const expectedEntries = [\n          {name: 'unzipped/'},\n          {name: 'unzipped/test-dir/'},\n          {name: 'unzipped/test-dir/a.txt', contents: 'Hello World'},\n          {name: 'unzipped/test-dir/b.txt', contents: 'Foo Bar'},\n        ];\n\n        it('should iterate entries (directories and files) of zip file', async function () {\n          let i = 0;\n          await zip.readEntries(zippedFilePath, async ({entry, extractEntryTo}) => {\n            entry.fileName.should.equal(expectedEntries[i].name);\n\n            // If it's a file, test that we can extract it to a temporary directory and that the contents are correct\n            if (expectedEntries[i].contents) {\n              await extractEntryTo(tmpRoot);\n              await fs.readFile(path.resolve(tmpRoot, entry.fileName), {\n                flags: 'r',\n                encoding: 'utf8'\n              }).should.eventually.equal(expectedEntries[i].contents);\n            }\n            i++;\n          });\n        });\n\n        it('should stop iterating zipFile if onEntry callback returns false', async function () {\n          let i = 0;\n          await zip.readEntries(zippedFilePath, async () => { // eslint-disable-line require-await\n            i++;\n            return false;\n          });\n          i.should.equal(1);\n        });\n\n        it('should be rejected if it uses a non-zip file', async function () {\n          let promise = zip.readEntries(path.resolve(assetsPath, 'unzipped', 'test-dir', 'a.txt'), async () => {});\n          await promise.should.eventually.be.rejected;\n        });\n      });\n\n      describe('toInMemoryZip()', function () {\n        it('should convert a local file to an in-memory zip buffer', async function () {\n          // Convert directory to in-memory buffer\n          const testFolder = path.resolve(assetsPath, 'unzipped');\n          const buffer = await zip.toInMemoryZip(testFolder);\n          Buffer.isBuffer(buffer).should.be.true;\n\n          // Write the buffer to a zip file\n          await fs.writeFile(path.resolve(tmpRoot, 'test.zip'), buffer);\n\n          // Unzip the file and test that it has the same contents as the directory that was zipped\n          await zip.extractAllTo(path.resolve(tmpRoot, 'test.zip'), path.resolve(tmpRoot, 'output'), {\n            fileNamesEncoding: 'utf8'\n          });\n          await fs.readFile(path.resolve(tmpRoot, 'output', 'test-dir', 'a.txt'), {\n            encoding: 'utf8'\n          }).should.eventually.equal('Hello World');\n          await fs.readFile(path.resolve(tmpRoot, 'output', 'test-dir', 'b.txt'), {\n            encoding: 'utf8'\n          }).should.eventually.equal('Foo Bar');\n        });\n\n        it('should convert a local folder to an in-memory base64-encoded zip buffer', async function () {\n          const testFolder = path.resolve(assetsPath, 'unzipped');\n          const buffer = await zip.toInMemoryZip(testFolder, {\n            encodeToBase64: true,\n          });\n\n          await fs.writeFile(path.resolve(tmpRoot, 'test.zip'), Buffer.from(buffer.toString(), 'base64'));\n\n          // Unzip the file and test that it has the same contents as the directory that was zipped\n          await zip.extractAllTo(path.resolve(tmpRoot, 'test.zip'), path.resolve(tmpRoot, 'output'));\n          await fs.readFile(path.resolve(tmpRoot, 'output', 'test-dir', 'a.txt'), {\n            encoding: 'utf8'\n          }).should.eventually.equal('Hello World');\n          await fs.readFile(path.resolve(tmpRoot, 'output', 'test-dir', 'b.txt'), {\n            encoding: 'utf8'\n          }).should.eventually.equal('Foo Bar');\n        });\n\n        it('should be rejected if use a bad path', async function () {\n          await zip.toInMemoryZip(path.resolve(assetsPath, 'bad_path'))\n            .should.be.rejectedWith(/no such/i);\n        });\n\n        it('should be rejected if max size is exceeded', async function () {\n          const testFolder = path.resolve(assetsPath, 'unzipped');\n          await zip.toInMemoryZip(testFolder, {\n            maxSize: 1,\n          }).should.be.rejectedWith(/must not be greater/);\n        });\n      });\n\n      describe('_extractEntryTo()', function () {\n        let entry, mockZipFile, mockZipStream;\n        beforeEach(async function () {\n          entry = {fileName: path.resolve(await tempDir.openDir(), 'temp', 'file')};\n          mockZipStream = new MockReadWriteStream();\n          mockZipFile = {\n            openReadStream: (entry, cb) => cb(null, mockZipStream), // eslint-disable-line promise/prefer-await-to-callbacks\n          };\n        });\n\n        it('should be rejected if zip stream emits an error', async function () {\n          mockZipStream.pipe = () => {\n            mockZipStream.emit('error', new Error('zip stream error'));\n          };\n          await zip._extractEntryTo(mockZipFile, entry).should.be.rejectedWith('zip stream error');\n        });\n\n        it('should be rejected if write stream emits an error', async function () {\n          mockZipStream.pipe = (writeStream) => {\n            writeStream.emit('error', new Error('write stream error'));\n            mockZipStream.end();\n            writeStream.end();\n          };\n          await zip._extractEntryTo(mockZipFile, entry).should.be.rejectedWith('write stream error');\n        });\n      });\n\n      describe('toArchive', function () {\n        it('should zip all files into an archive', async function () {\n          const testFolder = path.resolve(assetsPath, 'unzipped');\n          const dstPath = path.resolve(tmpRoot, 'test.zip');\n          await zip.toArchive(dstPath, {\n            cwd: testFolder,\n          });\n\n          // Unzip the file and test that it has the same contents as the directory that was zipped\n          await zip.extractAllTo(dstPath, path.resolve(tmpRoot, 'output'));\n          await fs.readFile(path.resolve(tmpRoot, 'output', 'test-dir', 'a.txt'), {\n            encoding: 'utf8'\n          }).should.eventually.equal('Hello World');\n          await fs.readFile(path.resolve(tmpRoot, 'output', 'test-dir', 'b.txt'), {\n            encoding: 'utf8'\n          }).should.eventually.equal('Foo Bar');\n        });\n      });\n\n\n    });\n  });\n\n  describe('unicode filename handling', function () {\n    let zippedFilePath, assetsPath, tmpRoot;\n\n    beforeEach(async function () {\n      assetsPath = await tempDir.openDir();\n      tmpRoot = await tempDir.openDir();\n\n      const zippedBase64 = 'UEsDBBQACAAIABF8/EYAAAAAAAAAABoAAAATACAAa2Fuamkt5q2j5LiW5LiVLmFwcFVUDQAHAgO4VVpX+GBZV/hgdXgLAAEE9QEAAAQUAAAAK8nILFYAorz8EoWi1MScnEqFxDyFxIICLgBQSwcIR93jPhoAAAAaAAAAUEsBAhQDFAAIAAgAEXz8Rkfd4z4aAAAAGgAAABMAIAAAAAAAAAAAAKSBAAAAAGthbmppLeato+S4luS4lS5hcHBVVA0ABwIDuFVaV/hgWVf4YHV4CwABBPUBAAAEFAAAAFBLBQYAAAAAAQABAGEAAAB7AAAAAAA=';\n      zippedFilePath = path.resolve(tmpRoot, 'zipped.zip');\n      await fs.writeFile(zippedFilePath, zippedBase64, 'base64');\n      await zip.extractAllTo(zippedFilePath, assetsPath, {useSystemUnzip: true});\n    });\n\n    afterEach(async function () {\n      for (const tmpPath of [assetsPath, tmpRoot]) {\n        if (!await fs.exists(tmpPath)) {\n          continue;\n        }\n        await fs.rimraf(tmpPath);\n      }\n    });\n\n    it('should retain the proper filenames', async function () {\n      const expectedPath = path.join(assetsPath, 'kanji-正世丕.app');\n      // we cannot use the `should` syntax because `fs.exists` resolves to a primitive (boolean)\n      if (!await fs.exists(expectedPath)) {\n        throw new chai.AssertionError(`Expected ${expectedPath} to exist, but it does not`);\n      }\n    });\n  });\n});\n"],"file":"test/zip-e2e-specs.js","sourceRoot":"../.."}