node/test/parallel/test-stream-promises.js
Moshe Atlow 5d8ff32945
test: wrap missing common.mustCall
PR-URL: https://github.com/nodejs/node/pull/45064
Reviewed-By: Matteo Collina <matteo.collina@gmail.com>
Reviewed-By: Robert Nagy <ronagy@icloud.com>
Reviewed-By: Tobias Nießen <tniessen@tnie.de>
Reviewed-By: Yagiz Nizipli <yagiz@nizipli.com>
Reviewed-By: Erick Wendel <erick.workspace@gmail.com>
Reviewed-By: Luigi Pinca <luigipinca@gmail.com>
Reviewed-By: Colin Ihrig <cjihrig@gmail.com>
Reviewed-By: James M Snell <jasnell@gmail.com>
2022-10-20 08:40:29 +00:00

149 lines
3.3 KiB
JavaScript

'use strict';
const common = require('../common');
const stream = require('stream');
const {
Readable, Writable, promises,
} = stream;
const {
finished, pipeline,
} = require('stream/promises');
const fs = require('fs');
const assert = require('assert');
const { promisify } = require('util');
assert.strictEqual(promises.pipeline, pipeline);
assert.strictEqual(promises.finished, finished);
assert.strictEqual(pipeline, promisify(stream.pipeline));
assert.strictEqual(finished, promisify(stream.finished));
// pipeline success
{
let finished = false;
const processed = [];
const expected = [Buffer.from('a'), Buffer.from('b'), Buffer.from('c')];
const read = new Readable({
read() {
}
});
const write = new Writable({
write(data, enc, cb) {
processed.push(data);
cb();
}
});
write.on('finish', () => {
finished = true;
});
for (let i = 0; i < expected.length; i++) {
read.push(expected[i]);
}
read.push(null);
pipeline(read, write).then(common.mustCall((value) => {
assert.ok(finished);
assert.deepStrictEqual(processed, expected);
}));
}
// pipeline error
{
const read = new Readable({
read() {
}
});
const write = new Writable({
write(data, enc, cb) {
cb();
}
});
read.push('data');
setImmediate(() => read.destroy());
pipeline(read, write).catch(common.mustCall((err) => {
assert.ok(err, 'should have an error');
}));
}
// finished success
{
async function run() {
const rs = fs.createReadStream(__filename);
let ended = false;
rs.resume();
rs.on('end', () => {
ended = true;
});
await finished(rs);
assert(ended);
}
run().then(common.mustCall());
}
// finished error
{
const rs = fs.createReadStream('file-does-not-exist');
assert.rejects(finished(rs), {
code: 'ENOENT'
}).then(common.mustCall());
}
{
const streamObj = new Readable();
assert.throws(() => {
// Passing cleanup option not as boolean
// should throw error
finished(streamObj, { cleanup: 2 });
}, { code: 'ERR_INVALID_ARG_TYPE' });
}
// Below code should not throw any errors as the
// streamObj is `Stream` and cleanup is boolean
{
const streamObj = new Readable();
finished(streamObj, { cleanup: true });
}
// Cleanup function should not be called when cleanup is set to false
// listenerCount should be 1 after calling finish
{
const streamObj = new Writable();
assert.strictEqual(streamObj.listenerCount('end'), 0);
finished(streamObj, { cleanup: false }).then(common.mustCall(() => {
assert.strictEqual(streamObj.listenerCount('end'), 1);
}));
streamObj.end();
}
// Cleanup function should be called when cleanup is set to true
// listenerCount should be 0 after calling finish
{
const streamObj = new Writable();
assert.strictEqual(streamObj.listenerCount('end'), 0);
finished(streamObj, { cleanup: true }).then(common.mustCall(() => {
assert.strictEqual(streamObj.listenerCount('end'), 0);
}));
streamObj.end();
}
// Cleanup function should not be called when cleanup has not been set
// listenerCount should be 1 after calling finish
{
const streamObj = new Writable();
assert.strictEqual(streamObj.listenerCount('end'), 0);
finished(streamObj).then(common.mustCall(() => {
assert.strictEqual(streamObj.listenerCount('end'), 1);
}));
streamObj.end();
}