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
|
'use strict';
const common = require('../common');
const fixtures = require('../common/fixtures');
const fs = require('fs');
// This test ensures that appropriate TypeError is thrown by createReadStream
// when an argument with invalid type is passed
const example = fixtures.path('x.txt');
// Should not throw.
fs.createReadStream(example, undefined);
fs.createReadStream(example, null);
fs.createReadStream(example, 'utf8');
fs.createReadStream(example, { encoding: 'utf8' });
const createReadStreamErr = (path, opt, error) => {
common.expectsError(() => {
fs.createReadStream(path, opt);
}, error);
};
const typeError = {
code: 'ERR_INVALID_ARG_TYPE',
type: TypeError
};
const rangeError = {
code: 'ERR_OUT_OF_RANGE',
type: RangeError
};
[123, 0, true, false].forEach((opts) =>
createReadStreamErr(example, opts, typeError)
);
// Case 0: Should not throw if either start or end is undefined
[{}, { start: 0 }, { end: Infinity }].forEach((opts) =>
fs.createReadStream(example, opts)
);
// Case 1: Should throw TypeError if either start or end is not of type 'number'
[
{ start: 'invalid' },
{ end: 'invalid' },
{ start: 'invalid', end: 'invalid' }
].forEach((opts) => createReadStreamErr(example, opts, typeError));
// Case 2: Should throw RangeError if either start or end is NaN
[{ start: NaN }, { end: NaN }, { start: NaN, end: NaN }].forEach((opts) =>
createReadStreamErr(example, opts, rangeError)
);
// Case 3: Should throw RangeError if either start or end is negative
[{ start: -1 }, { end: -1 }, { start: -1, end: -1 }].forEach((opts) =>
createReadStreamErr(example, opts, rangeError)
);
// Case 4: Should throw RangeError if either start or end is fractional
[{ start: 0.1 }, { end: 0.1 }, { start: 0.1, end: 0.1 }].forEach((opts) =>
createReadStreamErr(example, opts, rangeError)
);
// Case 5: Should not throw if both start and end are whole numbers
fs.createReadStream(example, { start: 1, end: 5 });
// Case 6: Should throw RangeError if start is greater than end
createReadStreamErr(example, { start: 5, end: 1 }, rangeError);
// Case 7: Should throw RangeError if start or end is not safe integer
const NOT_SAFE_INTEGER = 2 ** 53;
[
{ start: NOT_SAFE_INTEGER, end: Infinity },
{ start: 0, end: NOT_SAFE_INTEGER }
].forEach((opts) =>
createReadStreamErr(example, opts, rangeError)
);
|