mirror of
https://github.com/nodejs/node.git
synced 2025-04-28 21:46:48 +00:00

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>
48 lines
1.1 KiB
JavaScript
48 lines
1.1 KiB
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 fixtures = require('../common/fixtures');
|
|
|
|
if (!common.hasCrypto)
|
|
common.skip('missing crypto');
|
|
|
|
const assert = require('assert');
|
|
const http = require('http');
|
|
const https = require('https');
|
|
|
|
class MyServerResponse extends http.ServerResponse {
|
|
status(code) {
|
|
return this.writeHead(code, { 'Content-Type': 'text/plain' });
|
|
}
|
|
}
|
|
|
|
const server = https.createServer({
|
|
key: fixtures.readKey('agent1-key.pem'),
|
|
cert: fixtures.readKey('agent1-cert.pem'),
|
|
ca: fixtures.readKey('ca1-cert.pem'),
|
|
ServerResponse: MyServerResponse
|
|
}, common.mustCall(function(req, res) {
|
|
res.status(200);
|
|
res.end();
|
|
}));
|
|
server.listen();
|
|
|
|
server.on('listening', function makeRequest() {
|
|
https.get({
|
|
port: this.address().port,
|
|
rejectUnauthorized: false
|
|
}, (res) => {
|
|
assert.strictEqual(res.statusCode, 200);
|
|
res.on('end', () => {
|
|
server.close();
|
|
});
|
|
res.resume();
|
|
});
|
|
});
|