mirror of
https://github.com/oven-sh/bun
synced 2026-02-10 10:58:56 +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
TypeScript
77 lines
1.7 KiB
TypeScript
import { dns } from "bun";
|
|
import { bench, run, group } from "mitata";
|
|
|
|
async function forEachBackend(name, fn) {
|
|
group(name, () => {
|
|
for (let backend of [
|
|
"libc",
|
|
"c-ares",
|
|
process.platform === "darwin" ? "system" : "",
|
|
].filter(Boolean))
|
|
bench(backend, fn(backend));
|
|
});
|
|
}
|
|
|
|
forEachBackend("dns.lookup remote x 50", (backend) => async () => {
|
|
const run = () =>
|
|
dns
|
|
.lookup(Math.random().toString(16) + ".example.com", { backend })
|
|
.catch(() => {});
|
|
var remain = 16;
|
|
var done;
|
|
await new Promise((resolve) => {
|
|
for (var i = 0; i < 16; i++)
|
|
run().finally(() => {
|
|
remain--;
|
|
if (remain === 0) {
|
|
done();
|
|
}
|
|
});
|
|
done = resolve;
|
|
});
|
|
});
|
|
|
|
forEachBackend("(cached) dns.lookup remote x 50", (backend) => {
|
|
var tld = "example.com";
|
|
const run = () => dns.lookup(tld, { backend }).catch(() => {});
|
|
|
|
return async () => {
|
|
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;
|
|
});
|
|
};
|
|
});
|
|
|
|
forEachBackend(
|
|
"(cached in batch) dns.lookup remote x 50",
|
|
(backend) => async () => {
|
|
var tld = Math.random().toString(16) + ".example.com";
|
|
const run = () => dns.lookup(tld, { backend }).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;
|
|
});
|
|
},
|
|
);
|
|
|
|
await run();
|