Home / File/ mysql-checks.test.ts — drizzle-orm Source File

mysql-checks.test.ts — drizzle-orm Source File

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

Entity Profile

Dependency Diagram

graph LR
  9e50190f_a157_a62d_6e60_d9e969538e3c["mysql-checks.test.ts"]
  fb6b4a65_030b_ce6b_df0d_2be21adcd2b3["schemaDiffer.ts"]
  9e50190f_a157_a62d_6e60_d9e969538e3c --> fb6b4a65_030b_ce6b_df0d_2be21adcd2b3
  c773074f_07b6_08cd_c3ec_75126530b1c5["diffTestSchemasMysql"]
  9e50190f_a157_a62d_6e60_d9e969538e3c --> c773074f_07b6_08cd_c3ec_75126530b1c5
  690f7dfc_0aea_9ee8_d6e7_26bbb3689031["drizzle-orm"]
  9e50190f_a157_a62d_6e60_d9e969538e3c --> 690f7dfc_0aea_9ee8_d6e7_26bbb3689031
  93ed9350_daa0_6c21_81a6_ed6b2a48bbdf["mysql-core"]
  9e50190f_a157_a62d_6e60_d9e969538e3c --> 93ed9350_daa0_6c21_81a6_ed6b2a48bbdf
  8d35eaf2_a542_cfd4_fa1a_fafca0f02686["vitest"]
  9e50190f_a157_a62d_6e60_d9e969538e3c --> 8d35eaf2_a542_cfd4_fa1a_fafca0f02686
  style 9e50190f_a157_a62d_6e60_d9e969538e3c fill:#6366f1,stroke:#818cf8,color:#fff

Relationship Graph

Source Code

import { sql } from 'drizzle-orm';
import { check, int, mysqlTable, serial, varchar } from 'drizzle-orm/mysql-core';
import { expect, test } from 'vitest';
import { diffTestSchemasMysql } from './schemaDiffer';

test('create table with check', async (t) => {
	const to = {
		users: mysqlTable('users', {
			id: serial('id').primaryKey(),
			age: int('age'),
		}, (table) => ({
			checkConstraint: check('some_check_name', sql`${table.age} > 21`),
		})),
	};

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

	expect(statements.length).toBe(1);
	expect(statements[0]).toStrictEqual({
		type: 'create_table',
		tableName: 'users',
		columns: [
			{
				name: 'id',
				type: 'serial',
				notNull: true,
				primaryKey: false,
				autoincrement: true,
			},
			{
				name: 'age',
				type: 'int',
				notNull: false,
				primaryKey: false,
				autoincrement: false,
			},
		],
		compositePKs: [
			'users_id;id',
		],
		checkConstraints: ['some_check_name;\`users\`.\`age\` > 21'],
		compositePkName: 'users_id',
		uniqueConstraints: [],
		schema: undefined,
		internals: {
			tables: {},
			indexes: {},
		},
	});

	expect(sqlStatements.length).toBe(1);
	expect(sqlStatements[0]).toBe(`CREATE TABLE \`users\` (
\t\`id\` serial AUTO_INCREMENT NOT NULL,
\t\`age\` int,
\tCONSTRAINT \`users_id\` PRIMARY KEY(\`id\`),
\tCONSTRAINT \`some_check_name\` CHECK(\`users\`.\`age\` > 21)
);\n`);
});

test('add check contraint to existing table', async (t) => {
// ... (232 more lines)

Domain

Dependencies

Frequently Asked Questions

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