summaryrefslogtreecommitdiff
path: root/test/parallel/test-net-better-error-messages-port-hostname.js
blob: 3cc9e589873927beb70dc932fbe64f0d70465612 (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
'use strict';

// This tests that the error thrown from net.createConnection
// comes with host and port properties.
// See https://github.com/nodejs/node-v0.x-archive/issues/7005

const common = require('../common');
const assert = require('assert');
const net = require('net');

const { addresses } = require('../common/internet');
const {
  errorLookupMock,
  mockedErrorCode
} = require('../common/dns');

// Using port 0 as hostname used is already invalid.
const c = net.createConnection({
  port: 0,
  host: addresses.INVALID_HOST,
  lookup: common.mustCall(errorLookupMock())
});

c.on('connect', common.mustNotCall());

c.on('error', common.mustCall((error) => {
  assert.ok(!('port' in error));
  assert.ok(!('host' in error));
  assert.throws(() => { throw error; }, {
    errno: mockedErrorCode,
    code: mockedErrorCode,
    name: 'Error',
    message: 'getaddrinfo ENOTFOUND something.invalid',
    hostname: addresses.INVALID_HOST,
    syscall: 'getaddrinfo'
  });
}));