import * as pglue from "./mod.ts"; import postgres_js from "https://deno.land/x/postgresjs/mod.js"; import * as deno_postgres from "https://deno.land/x/postgres/mod.ts"; const c_pglue = await pglue.connect(`postgres://test:test@localhost:5432/test`); const c_pgjs = await postgres_js( `postgres://test:test@localhost:5432/test` ).reserve(); const c_denopg = new deno_postgres.Client({ user: "test", database: "test", hostname: "localhost", password: "test", port: 5432, }); await c_denopg.connect(); async function bench_select( b: Deno.BenchContext, n: number, q: () => PromiseLike ) { await q(); b.start(); const tasks = []; for (let i = 0; i < n; i++) tasks.push(q()); await Promise.all(tasks); b.end(); } async function bench_insert( b: Deno.BenchContext, n: number, q: (a: string, b: boolean, c: number) => PromiseLike ) { await q("prepare", false, 0); b.start(); const tasks = []; for (let i = 0; i < n; i++) tasks.push(q(i.toString(16).repeat(5), i % 3 === 0, i)); await Promise.all(tasks); b.end(); } for (const n of [1, 2, 5, 10]) { Deno.bench(`pglue (select, n=${n})`, async (b) => { await bench_select(b, n, () => c_pglue.query`select * from pg_type`); }); Deno.bench(`postgres.js (select, n=${n})`, async (b) => { await bench_select(b, n, () => c_pgjs`select * from pg_type`); }); Deno.bench(`deno-postgres (select, n=${n})`, async (b) => { await bench_select(b, n, () => c_denopg.queryArray`select * from pg_type`); }); } for (const n of [1, 2, 5, 10, 50, 100, 200]) { Deno.bench(`pglue (insert, n=${n})`, async (b) => { await using _tx = await c_pglue.begin(); await c_pglue.query`create table my_table (a text not null, b boolean not null, c integer not null)`; await bench_insert(b, n, (a, b, c) => c_pglue.query`insert into my_table (a, b, c) values (${a}, ${b}, ${c})`.execute() ); }); Deno.bench(`postgres.js (insert, n=${n})`, async (b) => { await c_pgjs`begin`; try { await c_pgjs`create table my_table (a text not null, b boolean not null, c integer not null)`; await bench_insert(b, n, (a, b, c) => c_pgjs`insert into my_table (a, b, c) values (${a}, ${b}, ${c})`.execute() ); } finally { await c_pgjs`rollback`; } }); Deno.bench(`deno-postgres (insert, n=${n})`, async (b) => { const tx = c_denopg.createTransaction(`my_tx`); await tx.begin(); try { await tx.queryArray`create table my_table (a text not null, b boolean not null, c integer not null)`; await bench_insert( b, n, (a, b, c) => tx.queryArray`insert into my_table (a, b, c) values (${a}, ${b}, ${c})` ); } finally { await tx.rollback(); } }); }