Files
Final_PGA/backend/tests/sql-guard.test.ts
2026-03-19 18:00:46 +07:00

28 lines
630 B
TypeScript

import test from "node:test";
import assert from "node:assert/strict";
import { guardSql } from "../src/lib/sql-guard.js";
test("guardSql blocks DROP DATABASE", () => {
assert.throws(
() =>
guardSql("DROP DATABASE appdb", {
allowMultiStatement: false,
readOnly: false,
allowSchemaChanges: true
}),
/blocked/i
);
});
test("guardSql blocks writes for read-only users", () => {
assert.throws(
() =>
guardSql("update users set name = 'x'", {
allowMultiStatement: false,
readOnly: true,
allowSchemaChanges: false
}),
/Read-only/i
);
});