summaryrefslogtreecommitdiff
path: root/test/parallel/test-zlib-deflate-constructors.js
blob: 49695fbaa55585dd4f65ba7362e77d82a3afa965 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
'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: '' + 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'}); },
  new RegExp('^TypeError: Invalid dictionary: it should be a Buffer, ' +
             'TypedArray, or DataView$')
);