immich/e2e/src/web/specs/auth.e2e-spec.ts
Jason Rasmussen af0de1a768
chore: linting ()
* chore: linting

* fix: broken tests

* fix: formatting
2024-02-29 11:26:55 -05:00

86 lines
3.1 KiB
TypeScript

import { expect, test } from '@playwright/test';
import { apiUtils, dbUtils, webUtils } from 'src/utils';
test.describe('Registration', () => {
test.beforeAll(() => {
apiUtils.setup();
});
test.beforeEach(async () => {
await dbUtils.reset();
});
test.afterAll(async () => {
await dbUtils.teardown();
});
test('admin registration', async ({ page }) => {
// welcome
await page.goto('/');
await page.getByRole('button', { name: 'Getting Started' }).click();
// register
await expect(page).toHaveTitle(/Admin Registration/);
await page.getByLabel('Admin Email').fill('admin@immich.app');
await page.getByLabel('Admin Password', { exact: true }).fill('password');
await page.getByLabel('Confirm Admin Password').fill('password');
await page.getByLabel('Name').fill('Immich Admin');
await page.getByRole('button', { name: 'Sign up' }).click();
// login
await expect(page).toHaveTitle(/Login/);
await page.goto('/auth/login');
await page.getByLabel('Email').fill('admin@immich.app');
await page.getByLabel('Password').fill('password');
await page.getByRole('button', { name: 'Login' }).click();
// onboarding
await expect(page).toHaveURL('/auth/onboarding');
await page.getByRole('button', { name: 'Theme' }).click();
await page.getByRole('button', { name: 'Storage Template' }).click();
await page.getByRole('button', { name: 'Done' }).click();
// success
await expect(page).toHaveURL('/photos');
});
test('user registration', async ({ context, page }) => {
const admin = await apiUtils.adminSetup();
await webUtils.setAuthCookies(context, admin.accessToken);
// create user
await page.goto('/admin/user-management');
await expect(page).toHaveTitle(/User Management/);
await page.getByRole('button', { name: 'Create user' }).click();
await page.getByLabel('Email').fill('user@immich.cloud');
await page.getByLabel('Password', { exact: true }).fill('password');
await page.getByLabel('Confirm Password').fill('password');
await page.getByLabel('Name').fill('Immich User');
await page.getByRole('button', { name: 'Create', exact: true }).click();
// logout
await context.clearCookies();
// login
await page.goto('/auth/login');
await page.getByLabel('Email').fill('user@immich.cloud');
await page.getByLabel('Password').fill('password');
await page.getByRole('button', { name: 'Login' }).click();
// change password
await expect(page.getByRole('heading')).toHaveText('Change Password');
await expect(page).toHaveURL('/auth/change-password');
await page.getByLabel('New Password').fill('new-password');
await page.getByLabel('Confirm Password').fill('new-password');
await page.getByRole('button', { name: 'Change password' }).click();
// login with new password
await expect(page).toHaveURL('/auth/login');
await page.getByLabel('Email').fill('user@immich.cloud');
await page.getByLabel('Password').fill('new-password');
await page.getByRole('button', { name: 'Login' }).click();
// success
await expect(page).toHaveURL(/\/photos/);
});
});