'use strict'; const common = require('../common'); const http = require('http'); const PORT = common.PORT; const SSLPORT = common.PORT + 1; const assert = require('assert'); const hostExpect = 'localhost'; const fs = require('fs'); const path = require('path'); const fixtures = path.resolve(__dirname, '../fixtures/keys'); const options = { key: fs.readFileSync(fixtures + '/agent1-key.pem'), cert: fs.readFileSync(fixtures + '/agent1-cert.pem') }; let gotHttpsResp = false; let gotHttpResp = false; if (common.hasCrypto) { var https = require('https'); } else { console.log('1..0 # Skipped: missing crypto'); } process.on('exit', function() { if (common.hasCrypto) { assert(gotHttpsResp); } assert(gotHttpResp); console.log('ok'); }); http.globalAgent.defaultPort = PORT; http.createServer(function(req, res) { assert.equal(req.headers.host, hostExpect); assert.equal(req.headers['x-port'], PORT); res.writeHead(200); res.end('ok'); this.close(); }).listen(PORT, function() { http.get({ host: 'localhost', headers: { 'x-port': PORT } }, function(res) { gotHttpResp = true; res.resume(); }); }); if (common.hasCrypto) { https.globalAgent.defaultPort = SSLPORT; https.createServer(options, function(req, res) { assert.equal(req.headers.host, hostExpect); assert.equal(req.headers['x-port'], SSLPORT); res.writeHead(200); res.end('ok'); this.close(); }).listen(SSLPORT, function() { https.get({ host: 'localhost', rejectUnauthorized: false, headers: { 'x-port': SSLPORT } }, function(res) { gotHttpsResp = true; res.resume(); }); }); }