mirror of
https://github.com/oven-sh/bun
synced 2026-02-09 18:38:55 +00:00
* 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>
77 lines
1.7 KiB
JavaScript
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();
|