import test from "ava"; import Database from "better-sqlite3"; test("Open in-memory database", async (t) => { const [db] = await connect(":memory:"); t.is(db.memory, true); }); test("Property .name of in-memory database", async (t) => { let name = ":memory:"; const db = new Database(name); t.is(db.name,name); }); test("Property .name of database", async (t) => { let name = "foobar.db"; const db = new Database(name); t.is(db.name,name); }); test("Statement.get() returns data", async (t) => { const [db] = await connect(":memory:"); const stmt = db.prepare("SELECT 1"); const result = stmt.get(); t.is(result["1"], 1); const result2 = stmt.get(); t.is(result2["1"], 1); }); test("Statement.get() returns undefined when no data", async (t) => { const [db] = await connect(":memory:"); const stmt = db.prepare("SELECT 1 WHERE 1 = 2"); const result = stmt.get(); t.is(result, undefined); }); test("Statement.run() returns correct result object", async (t) => { const [db] = await connect(":memory:"); db.prepare("CREATE TABLE users (name TEXT)").run(); const rows = db.prepare("INSERT INTO users (name) VALUES (?)").run("Alice"); t.deepEqual(rows, { changes: 1, lastInsertRowid: 1 }); }); test("Statment.iterate() should correctly return an iterable object", async (t) => { const [db] = await connect(":memory:"); db.prepare("CREATE TABLE users (name TEXT, age INTEGER)").run(); db.prepare("INSERT INTO users (name, age) VALUES (?, ?)").run("Alice", 42); db.prepare("INSERT INTO users (name, age) VALUES (?, ?)").run("Bob", 24); let rows = db.prepare("SELECT * FROM users").iterate(); for (const row of rows) { t.truthy(row.name); t.true(typeof row.age === "number"); } }); test("Empty prepared statement should throw", async (t) => { const [db] = await connect(":memory:"); t.throws( () => { db.prepare(""); }, { instanceOf: Error }, ); }); test("Test pragma", async (t) => { const [db] = await connect(":memory:"); t.deepEqual(typeof db.pragma("cache_size")[0].cache_size, "number"); t.deepEqual(typeof db.pragma("cache_size", { simple: true }), "number"); }); test("Test bind()", async (t) => { const [db] = await connect(":memory:"); db.prepare("CREATE TABLE users (name TEXT, age INTEGER)").run(); db.prepare("INSERT INTO users (name, age) VALUES (?, ?)").run("Alice", 42); let stmt = db.prepare("SELECT * FROM users WHERE name = ?").bind("Alice"); for (const row of stmt.iterate()) { t.truthy(row.name); t.true(typeof row.age === "number"); } t.throws( () => { db.bind("Bob"); }, { instanceOf: Error }, ); }); const connect = async (path) => { const db = new Database(path); return [db]; };