This commit is contained in:
@@ -0,0 +1,36 @@
|
||||
import { expect, test } from '@playwright/test';
|
||||
|
||||
const username = process.env.E2E_ADMIN_USERNAME ?? 'admin';
|
||||
const password = process.env.E2E_ADMIN_PASSWORD;
|
||||
const baseUrl = (process.env.E2E_BASE_URL ?? 'http://178.104.200.7/taxbaik').replace(/\/$/, '');
|
||||
|
||||
test.describe('admin authentication', () => {
|
||||
test('logs in through the real browser UI and reaches dashboard', async ({ page }) => {
|
||||
test.skip(!password, 'E2E_ADMIN_PASSWORD is required.');
|
||||
|
||||
const consoleErrors: string[] = [];
|
||||
page.on('console', message => {
|
||||
if (message.type() === 'error') {
|
||||
consoleErrors.push(message.text());
|
||||
}
|
||||
});
|
||||
page.on('pageerror', error => {
|
||||
consoleErrors.push(error.message);
|
||||
});
|
||||
|
||||
await page.goto(`${baseUrl}/admin/login`);
|
||||
|
||||
await expect(page.getByRole('heading', { name: '관리자 로그인' })).toBeVisible();
|
||||
await page.getByRole('textbox', { name: '사용자명' }).fill(username);
|
||||
await page.getByRole('textbox', { name: '비밀번호' }).fill(password);
|
||||
await page.getByRole('button', { name: '로그인' }).click();
|
||||
|
||||
await expect(page).toHaveURL(/\/taxbaik\/admin\/dashboard$/);
|
||||
await expect(page.getByRole('heading', { name: /대시보드/ })).toBeVisible();
|
||||
await expect(page.getByRole('link', { name: /로그아웃/ })).toBeVisible();
|
||||
|
||||
const token = await page.evaluate(() => localStorage.getItem('auth_token'));
|
||||
expect(token, 'auth_token should be stored after login').toBeTruthy();
|
||||
expect(consoleErrors, 'browser console/page errors').toEqual([]);
|
||||
});
|
||||
});
|
||||
Reference in New Issue
Block a user