'use strict'; require('../common'); const zlib = require('zlib'); const assert = require('assert'); // Work with and without `new` keyword assert.ok(zlib.Deflate() instanceof zlib.Deflate); assert.ok(new zlib.Deflate() instanceof zlib.Deflate); assert.ok(zlib.DeflateRaw() instanceof zlib.DeflateRaw); assert.ok(new zlib.DeflateRaw() instanceof zlib.DeflateRaw); // Throws if `opts.chunkSize` is invalid assert.throws( () => { new zlib.Deflate({chunkSize: -Infinity}); }, /^RangeError: Invalid chunk size: -Infinity$/ ); // Confirm that maximum chunk size cannot be exceeded because it is `Infinity`. assert.strictEqual(zlib.constants.Z_MAX_CHUNK, Infinity); // Throws if `opts.windowBits` is invalid assert.throws( () => { new zlib.Deflate({windowBits: -Infinity}); }, /^RangeError: Invalid windowBits: -Infinity$/ ); assert.throws( () => { new zlib.Deflate({windowBits: Infinity}); }, /^RangeError: Invalid windowBits: Infinity$/ ); // Throws if `opts.level` is invalid assert.throws( () => { new zlib.Deflate({level: -Infinity}); }, /^RangeError: Invalid compression level: -Infinity$/ ); assert.throws( () => { new zlib.Deflate({level: Infinity}); }, /^RangeError: Invalid compression level: Infinity$/ ); // Throws a RangeError if `level` invalid in `Deflate.prototype.params()` assert.throws( () => { new zlib.Deflate().params(-Infinity); }, /^RangeError: Invalid compression level: -Infinity$/ ); assert.throws( () => { new zlib.Deflate().params(Infinity); }, /^RangeError: Invalid compression level: Infinity$/ ); // Throws if `opts.memLevel` is invalid assert.throws( () => { new zlib.Deflate({memLevel: -Infinity}); }, /^RangeError: Invalid memLevel: -Infinity$/ ); assert.throws( () => { new zlib.Deflate({memLevel: Infinity}); }, /^RangeError: Invalid memLevel: Infinity$/ ); // Does not throw if opts.strategy is valid assert.doesNotThrow( () => { new zlib.Deflate({strategy: zlib.constants.Z_FILTERED}); } ); assert.doesNotThrow( () => { new zlib.Deflate({strategy: zlib.constants.Z_HUFFMAN_ONLY}); } ); assert.doesNotThrow( () => { new zlib.Deflate({strategy: zlib.constants.Z_RLE}); } ); assert.doesNotThrow( () => { new zlib.Deflate({strategy: zlib.constants.Z_FIXED}); } ); assert.doesNotThrow( () => { new zlib.Deflate({ strategy: zlib.constants.Z_DEFAULT_STRATEGY}); } ); // Throws if opt.strategy is the wrong type. assert.throws( () => { new zlib.Deflate({ strategy: String(zlib.constants.Z_RLE) }); }, /^TypeError: Invalid strategy: 3$/ ); // Throws if opts.strategy is invalid assert.throws( () => { new zlib.Deflate({strategy: 'this is a bogus strategy'}); }, /^TypeError: Invalid strategy: this is a bogus strategy$/ ); // Throws TypeError if `strategy` is invalid in `Deflate.prototype.params()` assert.throws( () => { new zlib.Deflate().params(0, 'I am an invalid strategy'); }, /^TypeError: Invalid strategy: I am an invalid strategy$/ ); // Throws if opts.dictionary is not a Buffer assert.throws( () => { new zlib.Deflate({dictionary: 'not a buffer'}); }, /^TypeError: Invalid dictionary: it should be a Buffer, TypedArray, or DataView$/ );