mirror of
https://github.com/seerr-team/seerr.git
synced 2026-04-18 06:18:17 -04:00
97 lines
2.8 KiB
TypeScript
97 lines
2.8 KiB
TypeScript
import { UserType } from '@server/constants/user';
|
|
import dataSource, { getRepository } from '@server/datasource';
|
|
import { User } from '@server/entity/User';
|
|
import gravatarUrl from 'gravatar-url';
|
|
|
|
export interface SeedDbOptions {
|
|
/** If true, preserves existing data instead of dropping the database */
|
|
preserveDb?: boolean;
|
|
/** If true, runs migrations instead of synchronizing schema */
|
|
withMigrations?: boolean;
|
|
}
|
|
|
|
// Precomputed bcrypt hash of 'test1234'. We precompute this to avoid
|
|
// having to hash the password every time we seed the database.
|
|
const TEST_USER_PASSWORD_HASH =
|
|
'$2b$12$Z5V2P5HZgmx4/AnWFMZN1.aD5AM1NucNi.mhNTSQ9oVtmdzu7Le/a';
|
|
|
|
/**
|
|
* Seeds test users into the database.
|
|
* Assumes the database schema is already set up.
|
|
*/
|
|
async function seedTestUsers(): Promise<void> {
|
|
const userRepository = getRepository(User);
|
|
|
|
const admin = await userRepository.findOne({
|
|
select: { id: true, plexId: true },
|
|
where: { id: 1 },
|
|
});
|
|
|
|
// Create the admin user
|
|
const user =
|
|
(await userRepository.findOne({
|
|
where: { email: 'admin@seerr.dev' },
|
|
})) ?? new User();
|
|
user.plexId = admin?.plexId ?? 1;
|
|
user.plexToken = '1234';
|
|
user.plexUsername = 'admin';
|
|
user.username = 'admin';
|
|
user.email = 'admin@seerr.dev';
|
|
user.userType = UserType.PLEX;
|
|
user.password = TEST_USER_PASSWORD_HASH;
|
|
user.permissions = 2;
|
|
user.avatar = gravatarUrl('admin@seerr.dev', { default: 'mm', size: 200 });
|
|
await userRepository.save(user);
|
|
|
|
// Create the other user
|
|
const otherUser =
|
|
(await userRepository.findOne({
|
|
where: { email: 'friend@seerr.dev' },
|
|
})) ?? new User();
|
|
otherUser.plexId = admin?.plexId ?? 1;
|
|
otherUser.plexToken = '1234';
|
|
otherUser.plexUsername = 'friend';
|
|
otherUser.username = 'friend';
|
|
otherUser.email = 'friend@seerr.dev';
|
|
otherUser.userType = UserType.PLEX;
|
|
otherUser.password = TEST_USER_PASSWORD_HASH;
|
|
otherUser.permissions = 32;
|
|
otherUser.avatar = gravatarUrl('friend@seerr.dev', {
|
|
default: 'mm',
|
|
size: 200,
|
|
});
|
|
await userRepository.save(otherUser);
|
|
}
|
|
|
|
/**
|
|
* Initializes the database connection and seeds test users.
|
|
* Used by both Cypress tests and Vitest unit tests.
|
|
*/
|
|
export async function seedTestDb(options: SeedDbOptions = {}): Promise<void> {
|
|
const dbConnection = dataSource.isInitialized
|
|
? dataSource
|
|
: await dataSource.initialize();
|
|
|
|
if (!options.preserveDb) {
|
|
await dbConnection.dropDatabase();
|
|
}
|
|
|
|
if (options.withMigrations) {
|
|
await dbConnection.runMigrations();
|
|
} else {
|
|
await dbConnection.synchronize();
|
|
}
|
|
|
|
await seedTestUsers();
|
|
}
|
|
|
|
/**
|
|
* Resets the database to a clean state with seeded test users.
|
|
* Used between tests to ensure isolation.
|
|
* Assumes DB has been initialized.
|
|
*/
|
|
export async function resetTestDb(): Promise<void> {
|
|
await dataSource.synchronize(true);
|
|
await seedTestUsers();
|
|
}
|