develop #2

Merged
jenkins merged 49 commits from develop into main 2026-04-08 19:55:46 +08:00
4 changed files with 46 additions and 34 deletions
Showing only changes of commit b34c09bdaf - Show all commits
+16
View File
@@ -0,0 +1,16 @@
import { test as setup } from '@playwright/test';
const authFile = 'playwright/.auth/user.json';
setup('authenticate', async ({ page }) => {
await page.goto('/login');
await page.waitForLoadState('networkidle');
await page.locator('input[placeholder*="用户名"]').fill('admin');
await page.locator('input[placeholder*="密码"]').fill('admin123');
await page.locator('button:has-text("登录")').click();
await page.waitForURL('**/dashboard', { timeout: 30000 });
await page.context().storageState({ path: authFile });
});
+23
View File
@@ -0,0 +1,23 @@
import { Page } from '@playwright/test';
export async function loginAsAdmin(page: Page) {
await page.goto('/login');
await page.waitForLoadState('networkidle');
await page.locator('input[placeholder*="用户名"]').fill('admin');
await page.locator('input[placeholder*="密码"]').fill('admin123');
await page.locator('button:has-text("登录")').click();
await page.waitForURL('**/dashboard', { timeout: 30000 });
const token = await page.evaluate(() => {
return localStorage.getItem('token') || '';
});
return token;
}
export async function saveAuthState(page: Page) {
const storage = await page.context().storageState();
return storage;
}
@@ -8,43 +8,10 @@ test.describe('管理员完整工作流', () => {
const roleKey = `test_role_${timestamp}`;
const username = `testuser_${timestamp}`;
test('管理员登录', async ({ page }) => {
await test.step('访问登录页面', async () => {
await page.goto('/login');
await expect(page).toHaveTitle(/登录/);
});
await test.step('等待页面加载完成', async () => {
await page.waitForLoadState('networkidle');
await expect(page.locator('input[placeholder*="用户名"]')).toBeVisible({ timeout: 10000 });
});
await test.step('输入管理员凭证', async () => {
const usernameInput = page.locator('input[placeholder*="用户名"]');
const passwordInput = page.locator('input[placeholder*="密码"]');
await usernameInput.waitFor({ state: 'visible' });
await usernameInput.fill('admin');
await passwordInput.waitFor({ state: 'visible' });
await passwordInput.fill('admin123');
});
await test.step('点击登录按钮', async () => {
const loginButton = page.locator('button:has-text("登录")');
await loginButton.waitFor({ state: 'visible' });
await loginButton.click();
});
await test.step('验证登录成功', async () => {
await page.waitForURL('**/dashboard', { timeout: 30000 });
await expect(page).toHaveURL(/.*dashboard/);
});
});
test('创建角色并分配权限', async ({ page }) => {
await test.step('导航到角色管理', async () => {
await page.goto('/dashboard');
await page.waitForLoadState('networkidle');
await page.locator('text=系统管理').click();
await page.locator('text=角色管理').click();
await expect(page).toHaveURL(/.*roles/);
+6
View File
@@ -53,12 +53,18 @@ export default defineConfig({
},
projects: [
{
name: 'setup',
testMatch: /.*\.setup\.ts/,
},
{
name: 'journeys',
testDir: './e2e/journeys',
testMatch: /.*\.spec\.ts/,
dependencies: ['setup'],
use: {
...devices['Desktop Chrome'],
storageState: 'playwright/.auth/user.json',
launchOptions: {
args: [
'--disable-blink-features=AutomationControlled',