Files
bun.sh/bench/snippets/dns.node.mjs
Jarred Sumner 87983464d8 Implement DNS module (#1691)
* Boilerplate for DNS stuff

* Add c-ares

* lookup

* make

* Implement dns.lookup

* Create c-ares

* wip

* normalize

* repro

* Revert "repro"

This reverts commit 8b93e0c295b335b8882a9601da47720348549beb.

* Implement macOS `getaddrinfo_async_start`

* embiggen

* Update string_immutable.zig

* Update Makefile

* alright

* Update .gitignore

* Add types

* more ccache

* Update Dockerfile

* Update Dockerfile

* Update Dockerfile

* Update bun.d.ts

Co-authored-by: Jarred Sumner <709451+Jarred-Sumner@users.noreply.github.com>
2023-01-07 07:09:48 -08:00

77 lines
1.7 KiB
JavaScript

import { lookup, resolve } from "node:dns/promises";
import { bench, run } from "mitata";
bench("(cached) dns.lookup remote x 50", async () => {
var tld = "example.com";
const run = () => lookup(tld).catch(() => {});
const total = 50;
var remain = total;
var done;
await new Promise((resolve) => {
for (var i = 0; i < total; i++)
run().finally(() => {
remain--;
if (remain === 0) {
done();
}
});
done = resolve;
});
});
bench("(cached in batch) dns.lookup remote x 50", async () => {
var tld = Math.random().toString(16) + ".example.com";
const run = () => lookup(tld).catch(() => {});
const total = 50;
var remain = total;
var done;
await new Promise((resolve) => {
for (var i = 0; i < total; i++)
run().finally(() => {
remain--;
if (remain === 0) {
done();
}
});
done = resolve;
});
});
bench("dns.lookup remote x 50", async () => {
var remain = 50;
var done;
const run = () =>
lookup(Math.random().toString() + ".example.com").catch(() => {});
await new Promise((resolve) => {
for (var i = 0; i < 50; i++)
run().finally(() => {
remain--;
if (remain === 0) {
done();
}
});
done = resolve;
});
});
bench("dns.resolve remote x 50", async () => {
var remain = 50;
var done;
const run = () =>
resolve(Math.random().toString() + ".example.com").catch(() => {});
await new Promise((resolve) => {
for (var i = 0; i < 50; i++)
run().finally(() => {
remain--;
if (remain === 0) {
done();
}
});
done = resolve;
});
});
await run();