summaryrefslogtreecommitdiff
path: root/test/parallel/test-stream-writable-finished.js
diff options
context:
space:
mode:
authorzero1five <zerodengyin@gmail.com>2019-06-02 03:04:56 +0800
committerRich Trott <rtrott@gmail.com>2019-06-25 14:46:10 -0700
commit33aef82b42ca689411673784e203e59d3f4eb142 (patch)
tree2d329d20782e537d53507f5fbe98897803149273 /test/parallel/test-stream-writable-finished.js
parent2bb93e11085ea582aea1636f544d900520d479ed (diff)
downloadandroid-node-v8-33aef82b42ca689411673784e203e59d3f4eb142.tar.gz
android-node-v8-33aef82b42ca689411673784e203e59d3f4eb142.tar.bz2
android-node-v8-33aef82b42ca689411673784e203e59d3f4eb142.zip
stream: add writableFinished
add a new getter to duplex stream to replace the property `this .writableState.finished` of the object that inherited duplex. Refs: https://github.com/nodejs/node/issues/445 PR-URL: https://github.com/nodejs/node/pull/28007 Reviewed-By: Luigi Pinca <luigipinca@gmail.com> Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Anna Henningsen <anna@addaleax.net> Reviewed-By: Rich Trott <rtrott@gmail.com>
Diffstat (limited to 'test/parallel/test-stream-writable-finished.js')
-rw-r--r--test/parallel/test-stream-writable-finished.js30
1 files changed, 30 insertions, 0 deletions
diff --git a/test/parallel/test-stream-writable-finished.js b/test/parallel/test-stream-writable-finished.js
new file mode 100644
index 0000000000..a5dfc06025
--- /dev/null
+++ b/test/parallel/test-stream-writable-finished.js
@@ -0,0 +1,30 @@
+'use strict';
+
+const common = require('../common');
+const { Writable } = require('stream');
+const assert = require('assert');
+
+// basic
+{
+ // Find it on Writable.prototype
+ assert(Writable.prototype.hasOwnProperty('writableFinished'));
+}
+
+// event
+{
+ const writable = new Writable();
+
+ writable._write = (chunk, encoding, cb) => {
+ // The state finished should start in false.
+ assert.strictEqual(writable.writableFinished, false);
+ cb();
+ };
+
+ writable.on('finish', common.mustCall(() => {
+ assert.strictEqual(writable.writableFinished, true);
+ }));
+
+ writable.end('testing finished state', common.mustCall(() => {
+ assert.strictEqual(writable.writableFinished, true);
+ }));
+}