1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2024-12-30 02:59:11 -05:00
denoland-deno/tests/node_compat/test/parallel/test-dns-lookup.js
Matt Mastracci f5e46c9bf2
chore: move cli/tests/ -> tests/ (#22369)
This looks like a massive PR, but it's only a move from cli/tests ->
tests, and updates of relative paths for files.

This is the first step towards aggregate all of the integration test
files under tests/, which will lead to a set of integration tests that
can run without the CLI binary being built.

While we could leave these tests under `cli`, it would require us to
keep a more complex directory structure for the various test runners. In
addition, we have a lot of complexity to ignore various test files in
the `cli` project itself (cargo publish exclusion rules, autotests =
false, etc).

And finally, the `tests/` folder will eventually house the `test_ffi`,
`test_napi` and other testing code, reducing the size of the root repo
directory.

For easier review, the extremely large and noisy "move" is in the first
commit (with no changes -- just a move), while the remainder of the
changes to actual files is in the second commit.
2024-02-10 20:22:13 +00:00

179 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' });