0
Fork 0
mirror of https://github.com/withastro/astro.git synced 2025-01-13 22:11:20 -05:00

wip: test foreign keys pragma

This commit is contained in:
bholmesdev 2024-01-30 15:59:07 -05:00
parent 9e3ff8b462
commit 1efc1d4584

View file

@ -1,5 +1,7 @@
import type { AstroConfig } from 'astro';
import type { Arguments } from 'yargs-parser';
import { createClient, type InStatement } from '@libsql/client';
import { getAstroStudioEnv, getRemoteDatabaseUrl } from '../utils.js';
export async function cli({ flags, config }: { flags: Arguments; config: AstroConfig }) {
const command = flags._[3] as string;
@ -21,6 +23,59 @@ export async function cli({ flags, config }: { flags: Arguments; config: AstroCo
const { cmd: verifyCommand } = await import('./commands/verify/index.js');
return await verifyCommand({ config, flags });
}
case 'batch-test': {
const queries: InStatement[] = [
{
sql: 'PRAGMA foreign_keys=OFF;',
args: [],
},
// {
// sql: 'DROP TABLE IF EXISTS user;',
// args: [],
// },
// {
// sql: 'DROP TABLE IF EXISTS account;',
// args: [],
// },
// {
// sql: `CREATE TABLE user (
// id INTEGER PRIMARY KEY,
// name TEXT NOT NULL
// );`,
// args: [],
// },
// {
// sql: `CREATE TABLE account (
// id INTEGER PRIMARY KEY,
// user_id INTEGER NOT NULL,
// FOREIGN KEY (user_id) REFERENCES user (id)
// );`,
// args: [],
// },
// {
// sql: `INSERT INTO user (id, name) VALUES (?, ?);`,
// args: [1, 'Alice'],
// },
{
sql: `INSERT INTO account (id, user_id) VALUES (?, ?);`,
args: [2, 5],
},
];
const url = new URL('/db/query', getRemoteDatabaseUrl());
const appToken = getAstroStudioEnv().ASTRO_STUDIO_APP_TOKEN;
const res = await fetch(url, {
method: 'POST',
headers: new Headers({
Authorization: `Bearer ${appToken}`,
}),
body: JSON.stringify(queries),
});
console.log(res, res.status === 200 ? await res.json() : await res.text());
return;
}
default: {
if (command == null) {
// eslint-disable-next-line no-console