import { PostgreSqlContainer } from '@testcontainers/postgresql'; import { access } from 'fs/promises'; import path from 'path'; export default async () => { let IMMICH_TEST_ASSET_PATH: string = ''; if (process.env.IMMICH_TEST_ASSET_PATH === undefined) { IMMICH_TEST_ASSET_PATH = path.normalize(`${__dirname}/../../test/assets/`); process.env.IMMICH_TEST_ASSET_PATH = IMMICH_TEST_ASSET_PATH; } else { IMMICH_TEST_ASSET_PATH = process.env.IMMICH_TEST_ASSET_PATH; } const directoryExists = async (dirPath: string) => await access(dirPath) .then(() => true) .catch(() => false); if (!(await directoryExists(`${IMMICH_TEST_ASSET_PATH}/albums`))) { throw new Error( `Test assets not found. Please checkout https://github.com/immich-app/test-assets into ${IMMICH_TEST_ASSET_PATH} before testing`, ); } if (process.env.DB_HOSTNAME === undefined) { // DB hostname not set which likely means we're not running e2e through docker compose. Start a local postgres container. const pg = await new PostgreSqlContainer('tensorchord/pgvecto-rs:pg14-v0.1.11') .withExposedPorts(5432) .withDatabase('immich') .withUsername('postgres') .withPassword('postgres') .withReuse() .start(); process.env.DB_URL = pg.getConnectionUri(); } process.env.NODE_ENV = 'development'; process.env.IMMICH_CONFIG_FILE = path.normalize(`${__dirname}/immich-e2e-config.json`); process.env.TZ = 'Z'; };