Home / File/ libsql.test.ts — drizzle-orm Source File

libsql.test.ts — drizzle-orm Source File

Architecture documentation for libsql.test.ts, a typescript file in the drizzle-orm codebase. 14 imports, 0 dependents.

Entity Profile

Dependency Diagram

graph LR
  5d37242e_76a0_a160_94b8_1a6a235a6008["libsql.test.ts"]
  46ce8b0c_dd54_2020_c1e8_2865e4c5e575["sqlite-common.ts"]
  5d37242e_76a0_a160_94b8_1a6a235a6008 --> 46ce8b0c_dd54_2020_c1e8_2865e4c5e575
  3418d3a3_df7d_8999_e21a_2b4339e5aa45["tests"]
  5d37242e_76a0_a160_94b8_1a6a235a6008 --> 3418d3a3_df7d_8999_e21a_2b4339e5aa45
  7f26f618_3381_4763_89e6_6503ea1e3ebd["sqlite-common-cache.ts"]
  5d37242e_76a0_a160_94b8_1a6a235a6008 --> 7f26f618_3381_4763_89e6_6503ea1e3ebd
  a0747176_ae28_8a69_935b_aa8d197ce39a["TestCache"]
  5d37242e_76a0_a160_94b8_1a6a235a6008 --> a0747176_ae28_8a69_935b_aa8d197ce39a
  271b550c_f48f_806e_3db7_b135393b905d["TestGlobalCache"]
  5d37242e_76a0_a160_94b8_1a6a235a6008 --> 271b550c_f48f_806e_3db7_b135393b905d
  1fb7c294_0b28_add4_155b_1659a26ba166["tests"]
  5d37242e_76a0_a160_94b8_1a6a235a6008 --> 1fb7c294_0b28_add4_155b_1659a26ba166
  33707adf_3867_206c_1f47_142479def47f["client"]
  5d37242e_76a0_a160_94b8_1a6a235a6008 --> 33707adf_3867_206c_1f47_142479def47f
  cad5819d_2851_9c06_9778_62eb6e1b2dab["async-retry"]
  5d37242e_76a0_a160_94b8_1a6a235a6008 --> cad5819d_2851_9c06_9778_62eb6e1b2dab
  690f7dfc_0aea_9ee8_d6e7_26bbb3689031["drizzle-orm"]
  5d37242e_76a0_a160_94b8_1a6a235a6008 --> 690f7dfc_0aea_9ee8_d6e7_26bbb3689031
  28ab9394_054d_e176_bc32_0ec8b0808e2a["libsql"]
  5d37242e_76a0_a160_94b8_1a6a235a6008 --> 28ab9394_054d_e176_bc32_0ec8b0808e2a
  7b1d67bb_d699_d5f9_a910_5776c48d8391["migrator"]
  5d37242e_76a0_a160_94b8_1a6a235a6008 --> 7b1d67bb_d699_d5f9_a910_5776c48d8391
  8d35eaf2_a542_cfd4_fa1a_fafca0f02686["vitest"]
  5d37242e_76a0_a160_94b8_1a6a235a6008 --> 8d35eaf2_a542_cfd4_fa1a_fafca0f02686
  5536e6a8_02de_67a7_6eaf_0fd73c9c2d92["common"]
  5d37242e_76a0_a160_94b8_1a6a235a6008 --> 5536e6a8_02de_67a7_6eaf_0fd73c9c2d92
  be4f1824_b255_ba95_9daf_35a679c997bf["utils"]
  5d37242e_76a0_a160_94b8_1a6a235a6008 --> be4f1824_b255_ba95_9daf_35a679c997bf
  style 5d37242e_76a0_a160_94b8_1a6a235a6008 fill:#6366f1,stroke:#818cf8,color:#fff

Relationship Graph

Source Code

import { type Client, createClient } from '@libsql/client';
import retry from 'async-retry';
import { sql } from 'drizzle-orm';
import { drizzle, type LibSQLDatabase } from 'drizzle-orm/libsql';
import { migrate } from 'drizzle-orm/libsql/migrator';
import { afterAll, beforeAll, beforeEach, expect, test } from 'vitest';
import { skipTests } from '~/common';
import { randomString } from '~/utils';
import { anotherUsersMigratorTable, tests, usersMigratorTable } from './sqlite-common';
import { TestCache, TestGlobalCache, tests as cacheTests } from './sqlite-common-cache';

const ENABLE_LOGGING = false;

let db: LibSQLDatabase;
let dbGlobalCached: LibSQLDatabase;
let cachedDb: 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 });
	cachedDb = drizzle(client, { logger: ENABLE_LOGGING, cache: new TestCache() });
	dbGlobalCached = drizzle(client, { logger: ENABLE_LOGGING, cache: new TestGlobalCache() });
});

afterAll(async () => {
	client?.close();
});

beforeEach((ctx) => {
	ctx.sqlite = {
		db,
	};
	ctx.cachedSqlite = {
		db: cachedDb,
		dbGlobalCached,
	};
});

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',
]);

cacheTests();
tests();

Domain

Dependencies

Frequently Asked Questions

What does libsql.test.ts do?
libsql.test.ts is a source file in the drizzle-orm codebase, written in typescript. It belongs to the DrizzleORM domain.
What does libsql.test.ts depend on?
libsql.test.ts imports 14 module(s): TestCache, TestGlobalCache, async-retry, client, common, drizzle-orm, libsql, migrator, and 6 more.
Where is libsql.test.ts in the architecture?
libsql.test.ts is located at integration-tests/tests/sqlite/libsql.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