|
|
|
'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$/
|
|
|
|
);
|