mirror of
https://github.com/nodejs/node.git
synced 2025-05-09 13:05:07 +00:00

When an OutgoingMessage is closed (for example, using the `end` method), its 'writable' property should be changed to false - since it is not writable anymore. The 'writable' property should have the opposite value of the 'finished' property. PR-URL: https://github.com/nodejs/node/pull/14024 Fixes: https://github.com/nodejs/node/issues/14023 Reviewed-By: Matteo Collina <matteo.collina@gmail.com> Reviewed-By: Gireesh Punathil <gpunathi@in.ibm.com>
32 lines
864 B
JavaScript
32 lines
864 B
JavaScript
'use strict';
|
|
const common = require('../common');
|
|
const assert = require('assert');
|
|
const http = require('http');
|
|
|
|
// Verify that after calling end() on an `OutgoingMessage` (or a type that
|
|
// inherits from `OutgoingMessage`), its `writable` property is set to false.
|
|
|
|
const server = http.createServer(common.mustCall(function(req, res) {
|
|
assert.strictEqual(res.writable, true);
|
|
assert.strictEqual(res.finished, false);
|
|
res.end();
|
|
assert.strictEqual(res.writable, false);
|
|
assert.strictEqual(res.finished, true);
|
|
|
|
server.close();
|
|
}));
|
|
|
|
server.listen(0);
|
|
|
|
server.on('listening', common.mustCall(function() {
|
|
const clientRequest = http.request({
|
|
port: server.address().port,
|
|
method: 'GET',
|
|
path: '/'
|
|
});
|
|
|
|
assert.strictEqual(clientRequest.writable, true);
|
|
clientRequest.end();
|
|
assert.strictEqual(clientRequest.writable, false);
|
|
}));
|