aboutsummaryrefslogtreecommitdiff
path: root/bench/snippets/dns.ts
diff options
context:
space:
mode:
Diffstat (limited to 'bench/snippets/dns.ts')
-rw-r--r--bench/snippets/dns.ts76
1 files changed, 76 insertions, 0 deletions
diff --git a/bench/snippets/dns.ts b/bench/snippets/dns.ts
new file mode 100644
index 000000000..308d54b6a
--- /dev/null
+++ b/bench/snippets/dns.ts
@@ -0,0 +1,76 @@
+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();