mirror of
https://github.com/nodejs/node.git
synced 2024-11-29 23:16:30 +01:00
a899576c97
This adds the optional options argument to `http.createServer()`. It contains two options: the `IncomingMessage` and `ServerReponse` option. PR-URL: https://github.com/nodejs/node/pull/15752 Reviewed-By: Matteo Collina <matteo.collina@gmail.com> Reviewed-By: Anatoli Papirovski <apapirovski@mac.com> Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Evan Lucas <evanlucas@me.com>
36 lines
858 B
JavaScript
36 lines
858 B
JavaScript
'use strict';
|
|
|
|
/**
|
|
* This test covers http.Server({ ServerResponse }) option:
|
|
* With ServerResponse option the server should use
|
|
* the new class for creating res Object instead of the default
|
|
* http.ServerResponse.
|
|
*/
|
|
const common = require('../common');
|
|
const assert = require('assert');
|
|
const http = require('http');
|
|
|
|
class MyServerResponse extends http.ServerResponse {
|
|
status(code) {
|
|
return this.writeHead(code, { 'Content-Type': 'text/plain' });
|
|
}
|
|
}
|
|
|
|
const server = http.Server({
|
|
ServerResponse: MyServerResponse
|
|
}, common.mustCall(function(req, res) {
|
|
res.status(200);
|
|
res.end();
|
|
}));
|
|
server.listen();
|
|
|
|
server.on('listening', function makeRequest() {
|
|
http.get({ port: this.address().port }, (res) => {
|
|
assert.strictEqual(res.statusCode, 200);
|
|
res.on('end', () => {
|
|
server.close();
|
|
});
|
|
res.resume();
|
|
});
|
|
});
|