libsql-node.test.ts — drizzle-orm Source File
Architecture documentation for libsql-node.test.ts, a typescript file in the drizzle-orm codebase. 11 imports, 0 dependents.
Entity Profile
Dependency Diagram
graph LR 22d4991a_f1b3_edc2_3450_997c8f9c57ef["libsql-node.test.ts"] 46ce8b0c_dd54_2020_c1e8_2865e4c5e575["sqlite-common.ts"] 22d4991a_f1b3_edc2_3450_997c8f9c57ef --> 46ce8b0c_dd54_2020_c1e8_2865e4c5e575 3418d3a3_df7d_8999_e21a_2b4339e5aa45["tests"] 22d4991a_f1b3_edc2_3450_997c8f9c57ef --> 3418d3a3_df7d_8999_e21a_2b4339e5aa45 6f32af20_ab5b_cbce_a419_7668b18f337c["node"] 22d4991a_f1b3_edc2_3450_997c8f9c57ef --> 6f32af20_ab5b_cbce_a419_7668b18f337c cad5819d_2851_9c06_9778_62eb6e1b2dab["async-retry"] 22d4991a_f1b3_edc2_3450_997c8f9c57ef --> cad5819d_2851_9c06_9778_62eb6e1b2dab 690f7dfc_0aea_9ee8_d6e7_26bbb3689031["drizzle-orm"] 22d4991a_f1b3_edc2_3450_997c8f9c57ef --> 690f7dfc_0aea_9ee8_d6e7_26bbb3689031 28ab9394_054d_e176_bc32_0ec8b0808e2a["libsql"] 22d4991a_f1b3_edc2_3450_997c8f9c57ef --> 28ab9394_054d_e176_bc32_0ec8b0808e2a 7b1d67bb_d699_d5f9_a910_5776c48d8391["migrator"] 22d4991a_f1b3_edc2_3450_997c8f9c57ef --> 7b1d67bb_d699_d5f9_a910_5776c48d8391 d6ca6647_cf2a_68be_5858_e36f9fa8820d["node"] 22d4991a_f1b3_edc2_3450_997c8f9c57ef --> d6ca6647_cf2a_68be_5858_e36f9fa8820d 8d35eaf2_a542_cfd4_fa1a_fafca0f02686["vitest"] 22d4991a_f1b3_edc2_3450_997c8f9c57ef --> 8d35eaf2_a542_cfd4_fa1a_fafca0f02686 5536e6a8_02de_67a7_6eaf_0fd73c9c2d92["common"] 22d4991a_f1b3_edc2_3450_997c8f9c57ef --> 5536e6a8_02de_67a7_6eaf_0fd73c9c2d92 be4f1824_b255_ba95_9daf_35a679c997bf["utils"] 22d4991a_f1b3_edc2_3450_997c8f9c57ef --> be4f1824_b255_ba95_9daf_35a679c997bf style 22d4991a_f1b3_edc2_3450_997c8f9c57ef fill:#6366f1,stroke:#818cf8,color:#fff
Relationship Graph
Source Code
import { type Client, createClient } from '@libsql/client/node';
import retry from 'async-retry';
import { sql } from 'drizzle-orm';
import type { LibSQLDatabase } from 'drizzle-orm/libsql';
import { migrate } from 'drizzle-orm/libsql/migrator';
import { drizzle } from 'drizzle-orm/libsql/node';
import { afterAll, beforeAll, beforeEach, expect, test } from 'vitest';
import { skipTests } from '~/common';
import { randomString } from '~/utils';
import { anotherUsersMigratorTable, tests, usersMigratorTable } from './sqlite-common';
const ENABLE_LOGGING = false;
let db: LibSQLDatabase;
let client: Client;
beforeAll(async () => {
const url = process.env['LIBSQL_URL'];
const authToken = process.env['LIBSQL_AUTH_TOKEN'];
if (!url) {
throw new Error('LIBSQL_URL is not set');
}
client = await retry(async () => {
client = createClient({ url, authToken });
return client;
}, {
retries: 20,
factor: 1,
minTimeout: 250,
maxTimeout: 250,
randomize: false,
onRetry() {
client?.close();
},
});
db = drizzle(client, { logger: ENABLE_LOGGING });
});
afterAll(async () => {
client?.close();
});
beforeEach((ctx) => {
ctx.sqlite = {
db,
};
});
test('migrator', async () => {
await db.run(sql`drop table if exists another_users`);
await db.run(sql`drop table if exists users12`);
await db.run(sql`drop table if exists __drizzle_migrations`);
await migrate(db, { migrationsFolder: './drizzle2/sqlite' });
await db.insert(usersMigratorTable).values({ name: 'John', email: 'email' }).run();
const result = await db.select().from(usersMigratorTable).all();
await db.insert(anotherUsersMigratorTable).values({ name: 'John', email: 'email' }).run();
const result2 = await db.select().from(anotherUsersMigratorTable).all();
expect(result).toEqual([{ id: 1, name: 'John', email: 'email' }]);
expect(result2).toEqual([{ id: 1, name: 'John', email: 'email' }]);
await db.run(sql`drop table another_users`);
await db.run(sql`drop table users12`);
await db.run(sql`drop table __drizzle_migrations`);
});
test('migrator : migrate with custom table', async () => {
const customTable = randomString();
await db.run(sql`drop table if exists another_users`);
await db.run(sql`drop table if exists users12`);
await db.run(sql`drop table if exists ${sql.identifier(customTable)}`);
await migrate(db, { migrationsFolder: './drizzle2/sqlite', migrationsTable: customTable });
// test if the custom migrations table was created
const res = await db.all(sql`select * from ${sql.identifier(customTable)};`);
expect(res.length > 0).toBeTruthy();
// test if the migrated table are working as expected
await db.insert(usersMigratorTable).values({ name: 'John', email: 'email' });
const result = await db.select().from(usersMigratorTable);
expect(result).toEqual([{ id: 1, name: 'John', email: 'email' }]);
await db.run(sql`drop table another_users`);
await db.run(sql`drop table users12`);
await db.run(sql`drop table ${sql.identifier(customTable)}`);
});
skipTests([
'delete with limit and order by',
'update with limit and order by',
]);
tests();
Domain
Dependencies
- async-retry
- common
- drizzle-orm
- libsql
- migrator
- node
- node
- sqlite-common.ts
- tests
- utils
- vitest
Source
Frequently Asked Questions
What does libsql-node.test.ts do?
libsql-node.test.ts is a source file in the drizzle-orm codebase, written in typescript. It belongs to the DrizzleORM domain.
What does libsql-node.test.ts depend on?
libsql-node.test.ts imports 11 module(s): async-retry, common, drizzle-orm, libsql, migrator, node, node, sqlite-common.ts, and 3 more.
Where is libsql-node.test.ts in the architecture?
libsql-node.test.ts is located at integration-tests/tests/sqlite/libsql-node.test.ts (domain: DrizzleORM, directory: integration-tests/tests/sqlite).
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free