Home / File/ pg.postgresjs.test.ts — drizzle-orm Source File

pg.postgresjs.test.ts — drizzle-orm Source File

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

File typescript DrizzleORM DatabaseDrivers 9 imports 1 functions 1 classes

Entity Profile

Dependency Diagram

graph LR
  54830b32_1825_3642_e698_3ee90c891663["pg.postgresjs.test.ts"]
  f361b5a8_1c83_007c_ced2_e978f9ffcf4d["pg.schema.ts"]
  54830b32_1825_3642_e698_3ee90c891663 --> f361b5a8_1c83_007c_ced2_e978f9ffcf4d
  c440e00a_e318_94ac_100c_9843a182c7a4["config"]
  54830b32_1825_3642_e698_3ee90c891663 --> c440e00a_e318_94ac_100c_9843a182c7a4
  e9c5db23_dc8f_4a33_356a_8f8fbacc4a0e["dockerode"]
  54830b32_1825_3642_e698_3ee90c891663 --> e9c5db23_dc8f_4a33_356a_8f8fbacc4a0e
  690f7dfc_0aea_9ee8_d6e7_26bbb3689031["drizzle-orm"]
  54830b32_1825_3642_e698_3ee90c891663 --> 690f7dfc_0aea_9ee8_d6e7_26bbb3689031
  abdb41ef_bca7_fd22_4985_3715de398926["postgres-js"]
  54830b32_1825_3642_e698_3ee90c891663 --> abdb41ef_bca7_fd22_4985_3715de398926
  249e672a_a0ca_539d_aeb8_1505bb753d14["get-port"]
  54830b32_1825_3642_e698_3ee90c891663 --> 249e672a_a0ca_539d_aeb8_1505bb753d14
  07445d0e_3235_2bb0_78cf_fa72a47ceb7f["postgres"]
  54830b32_1825_3642_e698_3ee90c891663 --> 07445d0e_3235_2bb0_78cf_fa72a47ceb7f
  de47b2dd_7ed5_08f6_5b8a_f44c9896ce49["uuid"]
  54830b32_1825_3642_e698_3ee90c891663 --> de47b2dd_7ed5_08f6_5b8a_f44c9896ce49
  8d35eaf2_a542_cfd4_fa1a_fafca0f02686["vitest"]
  54830b32_1825_3642_e698_3ee90c891663 --> 8d35eaf2_a542_cfd4_fa1a_fafca0f02686
  style 54830b32_1825_3642_e698_3ee90c891663 fill:#6366f1,stroke:#818cf8,color:#fff

Relationship Graph

Source Code

import 'dotenv/config';
import Docker from 'dockerode';
import { desc, DrizzleError, eq, gt, gte, or, placeholder, sql, TransactionRollbackError } from 'drizzle-orm';
import { drizzle, type PostgresJsDatabase } from 'drizzle-orm/postgres-js';
import getPort from 'get-port';
import postgres from 'postgres';
import { v4 as uuid } from 'uuid';
import { afterAll, beforeAll, beforeEach, expect, expectTypeOf, test } from 'vitest';
import * as schema from './pg.schema.ts';

const ENABLE_LOGGING = false;

const { usersTable, postsTable, commentsTable, usersToGroupsTable, groupsTable, usersV1, usersTableV1 } = schema;

/*
	Test cases:
	- querying nested relation without PK with additional fields
*/

declare module 'vitest' {
	export interface TestContext {
		docker: Docker;
		pgContainer: Docker.Container;
		pgjsDb: PostgresJsDatabase<typeof schema>;
		pgjsClient: postgres.Sql<{}>;
	}
}

let globalDocker: Docker;
let pgContainer: Docker.Container;
let db: PostgresJsDatabase<typeof schema>;
let client: postgres.Sql<{}>;

async function createDockerDB(): Promise<string> {
	const docker = (globalDocker = new Docker());
	const port = await getPort({ port: 5432 });
	const image = 'postgres:14';

	const pullStream = await docker.pull(image);
	await new Promise((resolve, reject) =>
		docker.modem.followProgress(pullStream, (err) => err ? reject(err) : resolve(err))
	);

	pgContainer = await docker.createContainer({
		Image: image,
		Env: [
			'POSTGRES_PASSWORD=postgres',
			'POSTGRES_USER=postgres',
			'POSTGRES_DB=postgres',
		],
		name: `drizzle-integration-tests-${uuid()}`,
		HostConfig: {
			AutoRemove: true,
			PortBindings: {
				'5432/tcp': [{ HostPort: `${port}` }],
			},
		},
	});

	await pgContainer.start();
// ... (6338 more lines)

Domain

Subdomains

Functions

Classes

Types

Dependencies

  • config
  • dockerode
  • drizzle-orm
  • get-port
  • pg.schema.ts
  • postgres
  • postgres-js
  • uuid
  • vitest

Frequently Asked Questions

What does pg.postgresjs.test.ts do?
pg.postgresjs.test.ts is a source file in the drizzle-orm codebase, written in typescript. It belongs to the DrizzleORM domain, DatabaseDrivers subdomain.
What functions are defined in pg.postgresjs.test.ts?
pg.postgresjs.test.ts defines 1 function(s): createDockerDB.
What does pg.postgresjs.test.ts depend on?
pg.postgresjs.test.ts imports 9 module(s): config, dockerode, drizzle-orm, get-port, pg.schema.ts, postgres, postgres-js, uuid, and 1 more.
Where is pg.postgresjs.test.ts in the architecture?
pg.postgresjs.test.ts is located at integration-tests/tests/relational/pg.postgresjs.test.ts (domain: DrizzleORM, subdomain: DatabaseDrivers, directory: integration-tests/tests/relational).

Analyze Your Own Codebase

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

Try Supermodel Free