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

mysql.test.ts — drizzle-orm Source File

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

File typescript DrizzleORM SQLDialects 9 imports 4 functions

Entity Profile

Dependency Diagram

graph LR
  23393d08_86bb_d392_da82_d43eb3156269["mysql.test.ts"]
  344e7e95_8861_e873_85de_b45a690e1dc7["mysqlSchema.ts"]
  23393d08_86bb_d392_da82_d43eb3156269 --> 344e7e95_8861_e873_85de_b45a690e1dc7
  e9c5db23_dc8f_4a33_356a_8f8fbacc4a0e["dockerode"]
  23393d08_86bb_d392_da82_d43eb3156269 --> e9c5db23_dc8f_4a33_356a_8f8fbacc4a0e
  690f7dfc_0aea_9ee8_d6e7_26bbb3689031["drizzle-orm"]
  23393d08_86bb_d392_da82_d43eb3156269 --> 690f7dfc_0aea_9ee8_d6e7_26bbb3689031
  da5f49c7_67eb_d6c6_2fa2_c3592f35dc62["mysql2"]
  23393d08_86bb_d392_da82_d43eb3156269 --> da5f49c7_67eb_d6c6_2fa2_c3592f35dc62
  1b99b4c2_9e7b_c1fa_0dd2_deadc369be98["drizzle-seed"]
  23393d08_86bb_d392_da82_d43eb3156269 --> 1b99b4c2_9e7b_c1fa_0dd2_deadc369be98
  249e672a_a0ca_539d_aeb8_1505bb753d14["get-port"]
  23393d08_86bb_d392_da82_d43eb3156269 --> 249e672a_a0ca_539d_aeb8_1505bb753d14
  a340f455_7575_91f4_791a_10cd9b9dba1a["promise"]
  23393d08_86bb_d392_da82_d43eb3156269 --> a340f455_7575_91f4_791a_10cd9b9dba1a
  de47b2dd_7ed5_08f6_5b8a_f44c9896ce49["uuid"]
  23393d08_86bb_d392_da82_d43eb3156269 --> de47b2dd_7ed5_08f6_5b8a_f44c9896ce49
  8d35eaf2_a542_cfd4_fa1a_fafca0f02686["vitest"]
  23393d08_86bb_d392_da82_d43eb3156269 --> 8d35eaf2_a542_cfd4_fa1a_fafca0f02686
  style 23393d08_86bb_d392_da82_d43eb3156269 fill:#6366f1,stroke:#818cf8,color:#fff

Relationship Graph

Source Code

import Docker from 'dockerode';
import { sql } from 'drizzle-orm';
import type { MySql2Database } from 'drizzle-orm/mysql2';
import { drizzle } from 'drizzle-orm/mysql2';
import { reset, seed } from 'drizzle-seed';
import getPort from 'get-port';
import type { Connection } from 'mysql2/promise';
import { createConnection } from 'mysql2/promise';
import { v4 as uuid } from 'uuid';
import { afterAll, afterEach, beforeAll, expect, test } from 'vitest';
import * as schema from './mysqlSchema.ts';

let mysqlContainer: Docker.Container;
let client: Connection;
let db: MySql2Database;

async function createDockerDB(): Promise<string> {
	const docker = new Docker();
	const port = await getPort({ port: 3306 });
	const image = 'mysql:8';

	const pullStream = await docker.pull(image);
	await new Promise((resolve, reject) =>
		// eslint-disable-next-line @typescript-eslint/no-unsafe-argument
		docker.modem.followProgress(pullStream, (err) => err ? reject(err) : resolve(err))
	);

	mysqlContainer = await docker.createContainer({
		Image: image,
		Env: ['MYSQL_ROOT_PASSWORD=mysql', 'MYSQL_DATABASE=drizzle'],
		name: `drizzle-integration-tests-${uuid()}`,
		HostConfig: {
			AutoRemove: true,
			PortBindings: {
				'3306/tcp': [{ HostPort: `${port}` }],
			},
		},
	});

	await mysqlContainer.start();

	return `mysql://root:mysql@127.0.0.1:${port}/drizzle`;
}

const createNorthwindTables = async () => {
	await db.execute(
		sql`
			    CREATE TABLE \`customer\` (
				\`id\` varchar(256) NOT NULL,
				\`company_name\` text NOT NULL,
				\`contact_name\` text NOT NULL,
				\`contact_title\` text NOT NULL,
				\`address\` text NOT NULL,
				\`city\` text NOT NULL,
				\`postal_code\` text,
				\`region\` text,
				\`country\` text NOT NULL,
				\`phone\` text NOT NULL,
				\`fax\` text,
				CONSTRAINT \`customer_id\` PRIMARY KEY(\`id\`)
// ... (431 more lines)

Domain

Subdomains

Dependencies

  • dockerode
  • drizzle-orm
  • drizzle-seed
  • get-port
  • mysql2
  • mysqlSchema.ts
  • promise
  • uuid
  • vitest

Frequently Asked Questions

What does mysql.test.ts do?
mysql.test.ts is a source file in the drizzle-orm codebase, written in typescript. It belongs to the DrizzleORM domain, SQLDialects subdomain.
What functions are defined in mysql.test.ts?
mysql.test.ts defines 4 function(s): createAllDataTypesTable, createAllGeneratorsTables, createDockerDB, createNorthwindTables.
What does mysql.test.ts depend on?
mysql.test.ts imports 9 module(s): dockerode, drizzle-orm, drizzle-seed, get-port, mysql2, mysqlSchema.ts, promise, uuid, and 1 more.
Where is mysql.test.ts in the architecture?
mysql.test.ts is located at integration-tests/tests/seeder/mysql.test.ts (domain: DrizzleORM, subdomain: SQLDialects, directory: integration-tests/tests/seeder).

Analyze Your Own Codebase

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

Try Supermodel Free