Home / File/ sqlite-generated.test.ts — drizzle-orm Source File

sqlite-generated.test.ts — drizzle-orm Source File

Architecture documentation for sqlite-generated.test.ts, a typescript file in the drizzle-orm codebase. 5 imports, 0 dependents.

Entity Profile

Dependency Diagram

graph LR
  d4b5faf5_3712_c7cd_ba76_a1977c4075df["sqlite-generated.test.ts"]
  fb6b4a65_030b_ce6b_df0d_2be21adcd2b3["schemaDiffer.ts"]
  d4b5faf5_3712_c7cd_ba76_a1977c4075df --> fb6b4a65_030b_ce6b_df0d_2be21adcd2b3
  843d184b_68ea_28e0_a4e7_11ed8d0a221a["diffTestSchemasSqlite"]
  d4b5faf5_3712_c7cd_ba76_a1977c4075df --> 843d184b_68ea_28e0_a4e7_11ed8d0a221a
  690f7dfc_0aea_9ee8_d6e7_26bbb3689031["drizzle-orm"]
  d4b5faf5_3712_c7cd_ba76_a1977c4075df --> 690f7dfc_0aea_9ee8_d6e7_26bbb3689031
  25248a9d_ba06_2b33_4421_8575da2f9c34["sqlite-core"]
  d4b5faf5_3712_c7cd_ba76_a1977c4075df --> 25248a9d_ba06_2b33_4421_8575da2f9c34
  8d35eaf2_a542_cfd4_fa1a_fafca0f02686["vitest"]
  d4b5faf5_3712_c7cd_ba76_a1977c4075df --> 8d35eaf2_a542_cfd4_fa1a_fafca0f02686
  style d4b5faf5_3712_c7cd_ba76_a1977c4075df fill:#6366f1,stroke:#818cf8,color:#fff

Relationship Graph

Source Code

// 1. add stored column to existing table - not supported +
// 2. add virtual column to existing table - supported +
// 3. create table with stored/virtual columns(pg, mysql, sqlite)
// 4. add stored generated to column -> not supported +
// 5. add virtual generated to column -> supported with drop+add column +
// 6. drop stored/virtual expression -> supported with drop+add column
// 7. alter generated expession -> stored not supported, virtual supported

import { SQL, sql } from 'drizzle-orm';
import { int, sqliteTable, text } from 'drizzle-orm/sqlite-core';
import { expect, test } from 'vitest';
import { diffTestSchemasSqlite } from './schemaDiffer';

// should generate 0 statements + warning/error in console
test('generated as callback: add column with stored generated constraint', async () => {
	const from = {
		users: sqliteTable('users', {
			id: int('id'),
			id2: int('id2'),
			name: text('name'),
		}),
	};
	const to = {
		users: sqliteTable('users', {
			id: int('id'),
			id2: int('id2'),
			name: text('name'),
			generatedName: text('gen_name').generatedAlwaysAs(
				(): SQL => sql`${to.users.name} || 'hello'`,
				{ mode: 'stored' },
			),
		}),
	};

	const { statements, sqlStatements } = await diffTestSchemasSqlite(
		from,
		to,
		[],
	);

	expect(statements).toStrictEqual([]);
	expect(sqlStatements).toStrictEqual([]);
});

test('generated as callback: add column with virtual generated constraint', async () => {
	const from = {
		users: sqliteTable('users', {
			id: int('id'),
			id2: int('id2'),
			name: text('name'),
		}),
	};
	const to = {
		users: sqliteTable('users', {
			id: int('id'),
			id2: int('id2'),
			name: text('name'),
			generatedName: text('gen_name').generatedAlwaysAs(
				(): SQL => sql`${to.users.name} || 'hello'`,
				{ mode: 'virtual' },
// ... (1667 more lines)

Domain

Dependencies

Frequently Asked Questions

What does sqlite-generated.test.ts do?
sqlite-generated.test.ts is a source file in the drizzle-orm codebase, written in typescript. It belongs to the DrizzleORM domain.
What does sqlite-generated.test.ts depend on?
sqlite-generated.test.ts imports 5 module(s): diffTestSchemasSqlite, drizzle-orm, schemaDiffer.ts, sqlite-core, vitest.
Where is sqlite-generated.test.ts in the architecture?
sqlite-generated.test.ts is located at drizzle-kit/tests/sqlite-generated.test.ts (domain: DrizzleORM, directory: drizzle-kit/tests).

Analyze Your Own Codebase

Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.

Try Supermodel Free