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

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

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

Entity Profile

Dependency Diagram

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

Relationship Graph

Source Code

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

test('create view', async () => {
	const users = sqliteTable('users', { id: int('id').default(1) });
	const view = sqliteView('view').as((qb) => qb.select().from(users));
	const to = {
		users: users,
		testView: view,
	};

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

	expect(statements.length).toBe(2);
	expect(statements[0]).toStrictEqual({
		type: 'sqlite_create_table',
		tableName: 'users',
		columns: [{
			autoincrement: false,
			default: 1,
			name: 'id',
			type: 'integer',
			primaryKey: false,
			notNull: false,
		}],
		compositePKs: [],
		uniqueConstraints: [],
		referenceData: [],
		checkConstraints: [],
	});
	expect(statements[1]).toStrictEqual({
		type: 'sqlite_create_view',
		name: 'view',
		definition: 'select "id" from "users"',
	});

	expect(sqlStatements.length).toBe(2);
	expect(sqlStatements[0]).toBe(`CREATE TABLE \`users\` (
\t\`id\` integer DEFAULT 1
);\n`);
	expect(sqlStatements[1]).toBe(`CREATE VIEW \`view\` AS select "id" from "users";`);
});

test('drop view', async () => {
	const users = sqliteTable('users', {
		id: int('id').primaryKey({ autoIncrement: true }),
	});

	const from = {
		users: users,
		testView: sqliteView('view', { id: int('id') }).as(sql`SELECT * FROM users`),
	};
	const to = {
		users,
	};

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

// ... (159 more lines)

Domain

Dependencies

Frequently Asked Questions

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