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

postgres.test.ts — drizzle-orm Source File

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

File typescript DrizzleORM RelationalQuery 8 imports 1 functions

Entity Profile

Dependency Diagram

graph LR
  42b70c38_4ce5_3d2a_ecd3_fb7503f20e2d["postgres.test.ts"]
  e9c5db23_dc8f_4a33_356a_8f8fbacc4a0e["dockerode"]
  42b70c38_4ce5_3d2a_ecd3_fb7503f20e2d --> e9c5db23_dc8f_4a33_356a_8f8fbacc4a0e
  690f7dfc_0aea_9ee8_d6e7_26bbb3689031["drizzle-orm"]
  42b70c38_4ce5_3d2a_ecd3_fb7503f20e2d --> 690f7dfc_0aea_9ee8_d6e7_26bbb3689031
  53497908_16e7_977d_e97d_7414884a88a6["pg-core"]
  42b70c38_4ce5_3d2a_ecd3_fb7503f20e2d --> 53497908_16e7_977d_e97d_7414884a88a6
  abdb41ef_bca7_fd22_4985_3715de398926["postgres-js"]
  42b70c38_4ce5_3d2a_ecd3_fb7503f20e2d --> abdb41ef_bca7_fd22_4985_3715de398926
  249e672a_a0ca_539d_aeb8_1505bb753d14["get-port"]
  42b70c38_4ce5_3d2a_ecd3_fb7503f20e2d --> 249e672a_a0ca_539d_aeb8_1505bb753d14
  07445d0e_3235_2bb0_78cf_fa72a47ceb7f["postgres"]
  42b70c38_4ce5_3d2a_ecd3_fb7503f20e2d --> 07445d0e_3235_2bb0_78cf_fa72a47ceb7f
  de47b2dd_7ed5_08f6_5b8a_f44c9896ce49["uuid"]
  42b70c38_4ce5_3d2a_ecd3_fb7503f20e2d --> de47b2dd_7ed5_08f6_5b8a_f44c9896ce49
  8d35eaf2_a542_cfd4_fa1a_fafca0f02686["vitest"]
  42b70c38_4ce5_3d2a_ecd3_fb7503f20e2d --> 8d35eaf2_a542_cfd4_fa1a_fafca0f02686
  style 42b70c38_4ce5_3d2a_ecd3_fb7503f20e2d fill:#6366f1,stroke:#818cf8,color:#fff

Relationship Graph

Source Code

import Docker from 'dockerode';
import { sql } from 'drizzle-orm';
import { bigserial, geometry, line, pgTable, point } from 'drizzle-orm/pg-core';
import { drizzle, type PostgresJsDatabase } from 'drizzle-orm/postgres-js';
import getPort from 'get-port';
import postgres, { type Sql } from 'postgres';
import { v4 as uuid } from 'uuid';
import { afterAll, beforeAll, beforeEach, expect, test } from 'vitest';

const ENABLE_LOGGING = false;

let pgContainer: Docker.Container;
let docker: Docker;
let client: Sql;
let db: PostgresJsDatabase;

async function createDockerDB(): Promise<string> {
	const inDocker = (docker = new Docker());
	const port = await getPort({ port: 5432 });
	const image = 'postgis/postgis:16-3.4';

	const pullStream = await docker.pull(image);
	await new Promise((resolve, reject) =>
		inDocker.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();

	return `postgres://postgres:postgres@localhost:${port}/postgres`;
}

beforeAll(async () => {
	const connectionString = process.env['PG_POSTGIS_CONNECTION_STRING'] ?? (await createDockerDB());

	const sleep = 1000;
	let timeLeft = 20000;
	let connected = false;
	let lastError: unknown | undefined;
	do {
		try {
			client = postgres(connectionString, {
				max: 1,
				onnotice: () => {
					// disable notices
				},
			});
			await client`select 1`;
			connected = true;
// ... (86 more lines)

Domain

Subdomains

Functions

Dependencies

  • dockerode
  • drizzle-orm
  • get-port
  • pg-core
  • postgres
  • postgres-js
  • uuid
  • vitest

Frequently Asked Questions

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

Analyze Your Own Codebase

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

Try Supermodel Free