|
23 | 23 | const common = require('../common'); |
24 | 24 | const assert = require('assert'); |
25 | 25 | const Duplex = require('stream').Duplex; |
| 26 | +const { Readable, Writable } = require('stream'); |
26 | 27 | const { ReadableStream, WritableStream } = require('stream/web'); |
27 | 28 |
|
28 | 29 | const stream = new Duplex({ objectMode: true }); |
@@ -131,3 +132,47 @@ process.on('exit', () => { |
131 | 132 | assert.deepStrictEqual(Buffer.from(result.value), dataToRead); |
132 | 133 | })); |
133 | 134 | } |
| 135 | + |
| 136 | +const assertMessages = { |
| 137 | + isDuplex: 'Expected a Duplex stream', |
| 138 | + duplexUnchanged: 'Expected the Duplex stream to be returned unchanged', |
| 139 | + notDuplex: 'Expected a non-Duplex stream', |
| 140 | + isReadable: 'Expected a Readable stream' |
| 141 | +}; |
| 142 | + |
| 143 | +// readable.compose - Duplex stream unchanged |
| 144 | +{ |
| 145 | + const readable = new Readable({ |
| 146 | + read() {} |
| 147 | + }); |
| 148 | + |
| 149 | + const duplex = new Duplex({ |
| 150 | + read() {}, |
| 151 | + write(chunk, encoding, callback) { |
| 152 | + callback(); |
| 153 | + } |
| 154 | + }); |
| 155 | + |
| 156 | + const composedStream = readable.compose(duplex); |
| 157 | + |
| 158 | + assert(composedStream instanceof Duplex, assertMessages.isDuplex); |
| 159 | + assert.strictEqual(composedStream, duplex, assertMessages.duplexUnchanged); |
| 160 | +} |
| 161 | + |
| 162 | +// readable.compose - wraps non-Duplex streams |
| 163 | +{ |
| 164 | + const readable = new Readable({ |
| 165 | + read() {} |
| 166 | + }); |
| 167 | + |
| 168 | + const writable = new Writable({ |
| 169 | + write(chunk, encoding, callback) { |
| 170 | + callback(); |
| 171 | + } |
| 172 | + }); |
| 173 | + |
| 174 | + const composedStream = readable.compose(writable); |
| 175 | + |
| 176 | + assert(!(composedStream instanceof Duplex), assertMessages.notDuplex); |
| 177 | + assert(composedStream instanceof Readable, assertMessages.isReadable); |
| 178 | +} |
0 commit comments