()
| 365 | let pgContainer: Docker.Container; |
| 366 | |
| 367 | export async function createDockerDB(): Promise<{ connectionString: string; container: Docker.Container }> { |
| 368 | const docker = new Docker(); |
| 369 | const port = await getPort({ port: 5432 }); |
| 370 | const image = 'postgres:14'; |
| 371 | |
| 372 | const pullStream = await docker.pull(image); |
| 373 | await new Promise((resolve, reject) => |
| 374 | docker.modem.followProgress(pullStream, (err) => (err ? reject(err) : resolve(err))) |
| 375 | ); |
| 376 | |
| 377 | pgContainer = await docker.createContainer({ |
| 378 | Image: image, |
| 379 | Env: ['POSTGRES_PASSWORD=postgres', 'POSTGRES_USER=postgres', 'POSTGRES_DB=postgres'], |
| 380 | name: `drizzle-integration-tests-${uuidV4()}`, |
| 381 | HostConfig: { |
| 382 | AutoRemove: true, |
| 383 | PortBindings: { |
| 384 | '5432/tcp': [{ HostPort: `${port}` }], |
| 385 | }, |
| 386 | }, |
| 387 | }); |
| 388 | |
| 389 | await pgContainer.start(); |
| 390 | |
| 391 | return { connectionString: `postgres://postgres:postgres@localhost:${port}/postgres`, container: pgContainer }; |
| 392 | } |
| 393 | |
| 394 | afterAll(async () => { |
| 395 | await pgContainer?.stop().catch(console.error); |
no test coverage detected