summaryrefslogtreecommitdiff
path: root/test/parallel/test-https-host-headers.js
blob: b8dcda320fddc5511b306483d724517ce871a495 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
'use strict';
const common = require('../common');
const fixtures = require('../common/fixtures');

if (!common.hasCrypto)
  common.skip('missing crypto');

const assert = require('assert');
const https = require('https');
const debug = require('util').debuglog('test');

let counter = 0;

const httpsServer = https.createServer({
  key: fixtures.readKey('agent1-key.pem'),
  cert: fixtures.readKey('agent1-cert.pem'),
}, common.mustCall(function(req, res) {
  debug(`Got request: ${req.headers.host} ${req.url}`);
  if (req.url.startsWith('/setHostFalse')) {
    assert.strictEqual(req.headers.host, undefined);
  } else {
    assert.strictEqual(
      req.headers.host, `localhost:${this.address().port}`,
      `Wrong host header for req[${req.url}]: ${req.headers.host}`);
  }
  res.writeHead(200, {});
  res.end('ok');
}, 9)).listen(0, common.mustCall(function(err) {
  debug(`test https server listening on port ${this.address().port}`);
  assert.ifError(err);
  https.get({
    method: 'GET',
    path: `/${counter++}`,
    host: 'localhost',
    port: this.address().port,
    rejectUnauthorized: false,
  }, cb).on('error', common.mustNotCall());

  https.request({
    method: 'GET',
    path: `/${counter++}`,
    host: 'localhost',
    port: this.address().port,
    rejectUnauthorized: false,
  }, cb).on('error', common.mustNotCall()).end();

  https.request({
    method: 'POST',
    path: `/${counter++}`,
    host: 'localhost',
    port: this.address().port,
    rejectUnauthorized: false,
  }, cb).on('error', common.mustNotCall()).end();

  https.request({
    method: 'PUT',
    path: `/${counter++}`,
    host: 'localhost',
    port: this.address().port,
    rejectUnauthorized: false,
  }, cb).on('error', common.mustNotCall()).end();

  https.request({
    method: 'DELETE',
    path: `/${counter++}`,
    host: 'localhost',
    port: this.address().port,
    rejectUnauthorized: false,
  }, cb).on('error', common.mustNotCall()).end();

  https.get({
    method: 'GET',
    path: `/setHostFalse${counter++}`,
    host: 'localhost',
    setHost: false,
    port: this.address().port,
    rejectUnauthorized: false,
  }, cb).on('error', common.mustNotCall());

  https.request({
    method: 'GET',
    path: `/${counter++}`,
    host: 'localhost',
    setHost: true,
    // agent: false,
    port: this.address().port,
    rejectUnauthorized: false,
  }, cb).on('error', common.mustNotCall()).end();

  https.get({
    method: 'GET',
    path: `/setHostFalse${counter++}`,
    host: 'localhost',
    setHost: 0,
    port: this.address().port,
    rejectUnauthorized: false,
  }, cb).on('error', common.mustNotCall());

  https.get({
    method: 'GET',
    path: `/setHostFalse${counter++}`,
    host: 'localhost',
    setHost: null,
    port: this.address().port,
    rejectUnauthorized: false,
  }, cb).on('error', common.mustNotCall());
}));

const cb = common.mustCall(function(res) {
  counter--;
  debug(`back from https request. counter = ${counter}`);
  if (counter === 0) {
    httpsServer.close();
    debug('ok');
  }
  res.resume();
}, 9);