mirror of
https://github.com/denoland/deno.git
synced 2024-12-11 10:07:54 -05:00
180 lines
4.4 KiB
JavaScript
180 lines
4.4 KiB
JavaScript
|
// deno-fmt-ignore-file
|
||
|
// deno-lint-ignore-file
|
||
|
|
||
|
// Copyright Joyent and Node contributors. All rights reserved. MIT license.
|
||
|
// Taken from Node 16.13.0
|
||
|
// This file is automatically generated by "node/_tools/setup.ts". Do not modify this file manually
|
||
|
|
||
|
// Flags: --expose-internals
|
||
|
'use strict';
|
||
|
|
||
|
// TODO: enable remaining tests once functionality is implemented.
|
||
|
|
||
|
const common = require('../common');
|
||
|
const assert = require('assert');
|
||
|
// const { internalBinding } = require('internal/test/binding');
|
||
|
// const cares = internalBinding('cares_wrap');
|
||
|
|
||
|
// Stub `getaddrinfo` to *always* error. This has to be done before we load the
|
||
|
// `dns` module to guarantee that the `dns` module uses the stub.
|
||
|
// cares.getaddrinfo = () => internalBinding('uv').UV_ENOMEM;
|
||
|
|
||
|
const dns = require('dns');
|
||
|
const dnsPromises = dns.promises;
|
||
|
|
||
|
{
|
||
|
const err = {
|
||
|
code: "ERR_INVALID_ARG_TYPE",
|
||
|
name: "TypeError",
|
||
|
message:
|
||
|
/^The "hostname" argument must be of type string\. Received type number/,
|
||
|
};
|
||
|
|
||
|
assert.throws(() => dns.lookup(1, {}), err);
|
||
|
assert.throws(() => dnsPromises.lookup(1, {}), err);
|
||
|
}
|
||
|
|
||
|
// This also verifies different expectWarning notations.
|
||
|
// common.expectWarning({
|
||
|
// // For 'internal/test/binding' module.
|
||
|
// 'internal/test/binding': [
|
||
|
// 'These APIs are for internal testing only. Do not use them.',
|
||
|
// ],
|
||
|
// // For calling `dns.lookup` with falsy `hostname`.
|
||
|
// 'DeprecationWarning': {
|
||
|
// DEP0118: 'The provided hostname "false" is not a valid ' +
|
||
|
// 'hostname, and is supported in the dns module solely for compatibility.'
|
||
|
// }
|
||
|
// });
|
||
|
|
||
|
assert.throws(
|
||
|
() => {
|
||
|
dns.lookup(false, "cb");
|
||
|
},
|
||
|
{
|
||
|
code: "ERR_INVALID_ARG_TYPE",
|
||
|
name: "TypeError",
|
||
|
}
|
||
|
);
|
||
|
|
||
|
assert.throws(
|
||
|
() => {
|
||
|
dns.lookup(false, "options", "cb");
|
||
|
},
|
||
|
{
|
||
|
code: "ERR_INVALID_ARG_TYPE",
|
||
|
name: "TypeError",
|
||
|
}
|
||
|
);
|
||
|
|
||
|
{
|
||
|
const err = {
|
||
|
code: 'ERR_INVALID_ARG_VALUE',
|
||
|
name: 'TypeError',
|
||
|
message: "The argument 'hints' is invalid. Received 100"
|
||
|
};
|
||
|
const options = {
|
||
|
hints: 100,
|
||
|
family: 0,
|
||
|
all: false
|
||
|
};
|
||
|
|
||
|
assert.throws(() => { dnsPromises.lookup(false, options); }, err);
|
||
|
assert.throws(() => {
|
||
|
dns.lookup(false, options, common.mustNotCall());
|
||
|
}, err);
|
||
|
}
|
||
|
|
||
|
{
|
||
|
const family = 20;
|
||
|
const err = {
|
||
|
code: "ERR_INVALID_ARG_VALUE",
|
||
|
name: "TypeError",
|
||
|
message: `The property 'options.family' must be one of: 0, 4, 6. Received ${family}`,
|
||
|
};
|
||
|
const options = {
|
||
|
hints: 0,
|
||
|
family,
|
||
|
all: false
|
||
|
};
|
||
|
|
||
|
assert.throws(() => { dnsPromises.lookup(false, options); }, err);
|
||
|
assert.throws(() => {
|
||
|
dns.lookup(false, options, common.mustNotCall());
|
||
|
}, err);
|
||
|
}
|
||
|
|
||
|
(async function() {
|
||
|
let res;
|
||
|
|
||
|
res = await dnsPromises.lookup(false, {
|
||
|
hints: 0,
|
||
|
family: 0,
|
||
|
all: true
|
||
|
});
|
||
|
assert.deepStrictEqual(res, []);
|
||
|
|
||
|
res = await dnsPromises.lookup('127.0.0.1', {
|
||
|
hints: 0,
|
||
|
family: 4,
|
||
|
all: true
|
||
|
});
|
||
|
assert.deepStrictEqual(res, [{ address: '127.0.0.1', family: 4 }]);
|
||
|
|
||
|
res = await dnsPromises.lookup('127.0.0.1', {
|
||
|
hints: 0,
|
||
|
family: 4,
|
||
|
all: false
|
||
|
});
|
||
|
assert.deepStrictEqual(res, { address: '127.0.0.1', family: 4 });
|
||
|
})().then(common.mustCall());
|
||
|
|
||
|
dns.lookup(false, {
|
||
|
hints: 0,
|
||
|
family: 0,
|
||
|
all: true
|
||
|
}, common.mustSucceed((result, addressType) => {
|
||
|
assert.deepStrictEqual(result, []);
|
||
|
assert.strictEqual(addressType, undefined);
|
||
|
}));
|
||
|
|
||
|
dns.lookup('127.0.0.1', {
|
||
|
hints: 0,
|
||
|
family: 4,
|
||
|
all: true
|
||
|
}, common.mustSucceed((result, addressType) => {
|
||
|
assert.deepStrictEqual(result, [{
|
||
|
address: '127.0.0.1',
|
||
|
family: 4
|
||
|
}]);
|
||
|
assert.strictEqual(addressType, undefined);
|
||
|
}));
|
||
|
|
||
|
dns.lookup('127.0.0.1', {
|
||
|
hints: 0,
|
||
|
family: 4,
|
||
|
all: false
|
||
|
}, common.mustSucceed((result, addressType) => {
|
||
|
assert.deepStrictEqual(result, '127.0.0.1');
|
||
|
assert.strictEqual(addressType, 4);
|
||
|
}));
|
||
|
|
||
|
// let tickValue = 0;
|
||
|
|
||
|
// Should fail due to stub.
|
||
|
// dns.lookup('example.com', common.mustCall((error, result, addressType) => {
|
||
|
// assert(error);
|
||
|
// assert.strictEqual(tickValue, 1);
|
||
|
// assert.strictEqual(error.code, 'ENOMEM');
|
||
|
// const descriptor = Object.getOwnPropertyDescriptor(error, 'message');
|
||
|
// // The error message should be non-enumerable.
|
||
|
// assert.strictEqual(descriptor.enumerable, false);
|
||
|
// }));
|
||
|
|
||
|
// Make sure that the error callback is called on next tick.
|
||
|
// tickValue = 1;
|
||
|
|
||
|
// Should fail due to stub.
|
||
|
// assert.rejects(dnsPromises.lookup('example.com'),
|
||
|
// { code: 'ENOMEM', hostname: 'example.com' });
|