summaryrefslogtreecommitdiff
path: root/test/parallel
diff options
context:
space:
mode:
Diffstat (limited to 'test/parallel')
-rw-r--r--test/parallel/test-stream-writable-write-writev-finish.js156
-rw-r--r--test/parallel/test-stream-writable-writev-finish.js53
2 files changed, 156 insertions, 53 deletions
diff --git a/test/parallel/test-stream-writable-write-writev-finish.js b/test/parallel/test-stream-writable-write-writev-finish.js
new file mode 100644
index 0000000000..c4aaa36606
--- /dev/null
+++ b/test/parallel/test-stream-writable-write-writev-finish.js
@@ -0,0 +1,156 @@
+'use strict';
+
+const common = require('../common');
+const assert = require('assert');
+const stream = require('stream');
+
+// ensure consistency between the finish event when using cork()
+// and writev and when not using them
+
+{
+ const writable = new stream.Writable();
+
+ writable._write = (chunks, encoding, cb) => {
+ cb(new Error('write test error'));
+ };
+
+ let firstError = false;
+ writable.on('finish', common.mustCall(function() {
+ assert.strictEqual(firstError, true);
+ }));
+
+ writable.on('prefinish', common.mustCall());
+
+ writable.on('error', common.mustCall((er) => {
+ assert.strictEqual(er.message, 'write test error');
+ firstError = true;
+ }));
+
+ writable.end('test');
+}
+
+{
+ const writable = new stream.Writable();
+
+ writable._write = (chunks, encoding, cb) => {
+ setImmediate(cb, new Error('write test error'));
+ };
+
+ let firstError = false;
+ writable.on('finish', common.mustCall(function() {
+ assert.strictEqual(firstError, true);
+ }));
+
+ writable.on('prefinish', common.mustCall());
+
+ writable.on('error', common.mustCall((er) => {
+ assert.strictEqual(er.message, 'write test error');
+ firstError = true;
+ }));
+
+ writable.end('test');
+}
+
+{
+ const writable = new stream.Writable();
+
+ writable._write = (chunks, encoding, cb) => {
+ cb(new Error('write test error'));
+ };
+
+ writable._writev = (chunks, cb) => {
+ cb(new Error('writev test error'));
+ };
+
+ let firstError = false;
+ writable.on('finish', common.mustCall(function() {
+ assert.strictEqual(firstError, true);
+ }));
+
+ writable.on('prefinish', common.mustCall());
+
+ writable.on('error', common.mustCall((er) => {
+ assert.strictEqual(er.message, 'writev test error');
+ firstError = true;
+ }));
+
+ writable.cork();
+ writable.write('test');
+
+ setImmediate(function() {
+ writable.end('test');
+ });
+}
+
+{
+ const writable = new stream.Writable();
+
+ writable._write = (chunks, encoding, cb) => {
+ setImmediate(cb, new Error('write test error'));
+ };
+
+ writable._writev = (chunks, cb) => {
+ setImmediate(cb, new Error('writev test error'));
+ };
+
+ let firstError = false;
+ writable.on('finish', common.mustCall(function() {
+ assert.strictEqual(firstError, true);
+ }));
+
+ writable.on('prefinish', common.mustCall());
+
+ writable.on('error', common.mustCall((er) => {
+ assert.strictEqual(er.message, 'writev test error');
+ firstError = true;
+ }));
+
+ writable.cork();
+ writable.write('test');
+
+ setImmediate(function() {
+ writable.end('test');
+ });
+}
+
+// Regression test for
+// https://github.com/nodejs/node/issues/13812
+
+{
+ const rs = new stream.Readable();
+ rs.push('ok');
+ rs.push(null);
+ rs._read = () => {};
+
+ const ws = new stream.Writable();
+ let firstError = false;
+
+ ws.on('finish', common.mustCall(function() {
+ assert.strictEqual(firstError, true);
+ }));
+ ws.on('error', common.mustCall(function() {
+ firstError = true;
+ }));
+
+ ws._write = (chunk, encoding, done) => {
+ setImmediate(done, new Error());
+ };
+ rs.pipe(ws);
+}
+
+{
+ const rs = new stream.Readable();
+ rs.push('ok');
+ rs.push(null);
+ rs._read = () => {};
+
+ const ws = new stream.Writable();
+
+ ws.on('finish', common.mustNotCall());
+ ws.on('error', common.mustCall());
+
+ ws._write = (chunk, encoding, done) => {
+ done(new Error());
+ };
+ rs.pipe(ws);
+}
diff --git a/test/parallel/test-stream-writable-writev-finish.js b/test/parallel/test-stream-writable-writev-finish.js
deleted file mode 100644
index 6f74ca08d2..0000000000
--- a/test/parallel/test-stream-writable-writev-finish.js
+++ /dev/null
@@ -1,53 +0,0 @@
-'use strict';
-
-const common = require('../common');
-const assert = require('assert');
-const stream = require('stream');
-
-// ensure consistency between the finish event when using cork()
-// and writev and when not using them
-
-{
- const writable = new stream.Writable();
-
- writable._write = (chunks, encoding, cb) => {
- cb(new Error('write test error'));
- };
-
- writable.on('finish', common.mustCall());
-
- writable.on('prefinish', common.mustCall());
-
- writable.on('error', common.mustCall((er) => {
- assert.strictEqual(er.message, 'write test error');
- }));
-
- writable.end('test');
-}
-
-{
- const writable = new stream.Writable();
-
- writable._write = (chunks, encoding, cb) => {
- cb(new Error('write test error'));
- };
-
- writable._writev = (chunks, cb) => {
- cb(new Error('writev test error'));
- };
-
- writable.on('finish', common.mustCall());
-
- writable.on('prefinish', common.mustCall());
-
- writable.on('error', common.mustCall((er) => {
- assert.strictEqual(er.message, 'writev test error');
- }));
-
- writable.cork();
- writable.write('test');
-
- setImmediate(function() {
- writable.end('test');
- });
-}