summaryrefslogtreecommitdiff
path: root/tests/node_compat/test/parallel/test-zlib-convenience-methods.js
diff options
context:
space:
mode:
Diffstat (limited to 'tests/node_compat/test/parallel/test-zlib-convenience-methods.js')
-rw-r--r--tests/node_compat/test/parallel/test-zlib-convenience-methods.js144
1 files changed, 144 insertions, 0 deletions
diff --git a/tests/node_compat/test/parallel/test-zlib-convenience-methods.js b/tests/node_compat/test/parallel/test-zlib-convenience-methods.js
new file mode 100644
index 000000000..cf6694b1f
--- /dev/null
+++ b/tests/node_compat/test/parallel/test-zlib-convenience-methods.js
@@ -0,0 +1,144 @@
+// deno-fmt-ignore-file
+// deno-lint-ignore-file
+
+// Copyright Joyent and Node contributors. All rights reserved. MIT license.
+// Taken from Node 16.13.0
+// This file is automatically generated by "node/_tools/setup.ts". Do not modify this file manually
+
+// Copyright Joyent, Inc. and other Node contributors.
+//
+// Permission is hereby granted, free of charge, to any person obtaining a
+// copy of this software and associated documentation files (the
+// "Software"), to deal in the Software without restriction, including
+// without limitation the rights to use, copy, modify, merge, publish,
+// distribute, sublicense, and/or sell copies of the Software, and to permit
+// persons to whom the Software is furnished to do so, subject to the
+// following conditions:
+//
+// The above copyright notice and this permission notice shall be included
+// in all copies or substantial portions of the Software.
+//
+// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
+// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
+// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
+// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
+// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
+// USE OR OTHER DEALINGS IN THE SOFTWARE.
+
+'use strict';
+// Test convenience methods with and without options supplied
+
+const common = require('../common');
+const assert = require('assert');
+const zlib = require('zlib');
+
+// Must be a multiple of 4 characters in total to test all ArrayBufferView
+// types.
+const expectStr = 'blah'.repeat(8);
+const expectBuf = Buffer.from(expectStr);
+
+const opts = {
+ level: 9,
+ chunkSize: 1024,
+};
+
+const optsInfo = {
+ info: true
+};
+
+for (const [type, expect] of [
+ ['string', expectStr],
+ ['Buffer', expectBuf],
+ // FIXME(bartlomieju):
+ // ...common.getBufferSources(expectBuf).map((obj) =>
+ // [obj[Symbol.toStringTag], obj]
+ // ),
+]) {
+ for (const method of [
+ ['gzip', 'gunzip', 'Gzip', 'Gunzip'],
+ ['gzip', 'unzip', 'Gzip', 'Unzip'],
+ ['deflate', 'inflate', 'Deflate', 'Inflate'],
+ ['deflateRaw', 'inflateRaw', 'DeflateRaw', 'InflateRaw'],
+ // FIXME(bartlomieju):
+ // ['brotliCompress', 'brotliDecompress',
+ // 'BrotliCompress', 'BrotliDecompress'],
+ ]) {
+ zlib[method[0]](expect, opts, common.mustCall((err, result) => {
+ zlib[method[1]](result, opts, common.mustCall((err, result) => {
+ assert.strictEqual(result.toString(), expectStr,
+ `Should get original string after ${method[0]}/` +
+ `${method[1]} ${type} with options.`);
+ }));
+ }));
+
+ zlib[method[0]](expect, common.mustCall((err, result) => {
+ zlib[method[1]](result, common.mustCall((err, result) => {
+ assert.strictEqual(result.toString(), expectStr,
+ `Should get original string after ${method[0]}/` +
+ `${method[1]} ${type} without options.`);
+ }));
+ }));
+
+ // FIXME(bartlomieju):
+ // zlib[method[0]](expect, optsInfo, common.mustCall((err, result) => {
+ // assert.ok(result.engine instanceof zlib[method[2]],
+ // `Should get engine ${method[2]} after ${method[0]} ` +
+ // `${type} with info option.`);
+
+ // const compressed = result.buffer;
+ // zlib[method[1]](compressed, optsInfo, common.mustCall((err, result) => {
+ // assert.strictEqual(result.buffer.toString(), expectStr,
+ // `Should get original string after ${method[0]}/` +
+ // `${method[1]} ${type} with info option.`);
+ // assert.ok(result.engine instanceof zlib[method[3]],
+ // `Should get engine ${method[3]} after ${method[0]} ` +
+ // `${type} with info option.`);
+ // }));
+ // }));
+
+ {
+ const compressed = zlib[`${method[0]}Sync`](expect, opts);
+ const decompressed = zlib[`${method[1]}Sync`](compressed, opts);
+ assert.strictEqual(decompressed.toString(), expectStr,
+ `Should get original string after ${method[0]}Sync/` +
+ `${method[1]}Sync ${type} with options.`);
+ }
+
+
+ {
+ const compressed = zlib[`${method[0]}Sync`](expect);
+ const decompressed = zlib[`${method[1]}Sync`](compressed);
+ assert.strictEqual(decompressed.toString(), expectStr,
+ `Should get original string after ${method[0]}Sync/` +
+ `${method[1]}Sync ${type} without options.`);
+ }
+
+ // FIXME(bartlomieju):
+ // {
+ // const compressed = zlib[`${method[0]}Sync`](expect, optsInfo);
+ // assert.ok(compressed.engine instanceof zlib[method[2]],
+ // `Should get engine ${method[2]} after ${method[0]} ` +
+ // `${type} with info option.`);
+ // const decompressed = zlib[`${method[1]}Sync`](compressed.buffer,
+ // optsInfo);
+ // assert.strictEqual(decompressed.buffer.toString(), expectStr,
+ // `Should get original string after ${method[0]}Sync/` +
+ // `${method[1]}Sync ${type} without options.`);
+ // assert.ok(decompressed.engine instanceof zlib[method[3]],
+ // `Should get engine ${method[3]} after ${method[0]} ` +
+ // `${type} with info option.`);
+ // }
+ }
+}
+
+// FIXME(bartlomieju):
+// assert.throws(
+// () => zlib.gzip('abc'),
+// {
+// code: 'ERR_INVALID_ARG_TYPE',
+// name: 'TypeError',
+// message: 'The "callback" argument must be of type function. ' +
+// 'Received undefined'
+// }
+// );