2023-08-28 21:41:57 +02:00
|
|
|
import { PostgreSqlContainer } from '@testcontainers/postgresql';
|
2023-10-19 00:02:42 +02:00
|
|
|
import { access } from 'fs/promises';
|
2023-10-06 23:32:28 +02:00
|
|
|
import path from 'path';
|
|
|
|
|
2023-07-11 23:54:44 +02:00
|
|
|
export default async () => {
|
2023-10-06 23:32:28 +02:00
|
|
|
const allTests: boolean = process.env.IMMICH_RUN_ALL_TESTS === 'true';
|
|
|
|
|
|
|
|
if (!allTests) {
|
|
|
|
console.warn(
|
|
|
|
`\n\n
|
|
|
|
*** Not running all e2e tests. Run 'make test-e2e' to run all tests inside Docker (recommended)\n
|
|
|
|
*** or set 'IMMICH_RUN_ALL_TESTS=true' to run all tests(requires dependencies to be installed)\n`,
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
let IMMICH_TEST_ASSET_PATH: string = '';
|
2023-07-11 23:54:44 +02:00
|
|
|
|
2023-10-06 23:32:28 +02:00
|
|
|
if (process.env.IMMICH_TEST_ASSET_PATH === undefined) {
|
|
|
|
IMMICH_TEST_ASSET_PATH = path.normalize(`${__dirname}/../assets/`);
|
|
|
|
process.env.IMMICH_TEST_ASSET_PATH = IMMICH_TEST_ASSET_PATH;
|
|
|
|
} else {
|
|
|
|
IMMICH_TEST_ASSET_PATH = process.env.IMMICH_TEST_ASSET_PATH;
|
|
|
|
}
|
2023-07-11 23:54:44 +02:00
|
|
|
|
2023-10-06 23:32:28 +02:00
|
|
|
const directoryExists = async (dirPath: string) =>
|
2023-10-19 00:02:42 +02:00
|
|
|
await access(dirPath)
|
2023-10-06 23:32:28 +02:00
|
|
|
.then(() => true)
|
|
|
|
.catch(() => false);
|
2023-07-11 23:54:44 +02:00
|
|
|
|
2023-10-06 23:32:28 +02:00
|
|
|
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`,
|
|
|
|
);
|
|
|
|
}
|
2023-07-11 23:54:44 +02:00
|
|
|
|
2023-10-06 23:32:28 +02:00
|
|
|
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('postgres')
|
|
|
|
.withExposedPorts(5432)
|
|
|
|
.withDatabase('immich')
|
|
|
|
.withUsername('postgres')
|
|
|
|
.withPassword('postgres')
|
|
|
|
.withReuse()
|
|
|
|
.start();
|
|
|
|
|
|
|
|
process.env.DB_URL = pg.getConnectionUri();
|
|
|
|
}
|
|
|
|
|
|
|
|
process.env.NODE_ENV = 'development';
|
|
|
|
process.env.TYPESENSE_ENABLED = 'false';
|
|
|
|
process.env.IMMICH_MACHINE_LEARNING_ENABLED = 'false';
|
|
|
|
process.env.IMMICH_TEST_ENV = 'true';
|
|
|
|
process.env.TZ = 'Z';
|
2023-07-11 23:54:44 +02:00
|
|
|
};
|