test: stabilize task and role editor flows
This commit is contained in:
@@ -78,16 +78,30 @@ test.describe('Role Editor', () => {
|
||||
console.log('➕ Creating temp-tester role...');
|
||||
await page.click('button:has-text("+ Create New Role")');
|
||||
await page.waitForSelector('input[placeholder="e.g., developer, manager"]', { timeout: 5000 });
|
||||
|
||||
|
||||
await page.fill('input[placeholder="e.g., developer, manager"]', 'temp-tester');
|
||||
await page.fill('input[placeholder="Role description"]', 'Temporary tester role');
|
||||
|
||||
const createRoleResponsePromise = page.waitForResponse((response) => {
|
||||
return response.request().method() === 'POST' && /\/roles$/.test(response.url());
|
||||
});
|
||||
|
||||
await page.click('button:has-text("Create")');
|
||||
|
||||
await page.waitForTimeout(1000);
|
||||
|
||||
// Verify role was created
|
||||
const newRolesCount = await page.locator('.role-editor-page >> text=temp-tester').count();
|
||||
expect(newRolesCount).toBeGreaterThan(0);
|
||||
const createRoleResponse = await createRoleResponsePromise;
|
||||
const createRoleBody = await createRoleResponse.text();
|
||||
console.log('Create role response:', createRoleResponse.status(), createRoleBody);
|
||||
expect([200, 201, 400]).toContain(createRoleResponse.status());
|
||||
if (createRoleResponse.status() === 400) {
|
||||
expect(createRoleBody).toContain('Role already exists');
|
||||
}
|
||||
|
||||
await page.goto(`${BASE_URL}/roles`);
|
||||
await page.waitForLoadState('networkidle');
|
||||
await page.waitForSelector('.role-editor-page', { timeout: 10000 });
|
||||
|
||||
await expect.poll(async () => {
|
||||
return await page.locator('.role-editor-page >> text=temp-tester').count();
|
||||
}, { timeout: 10000 }).toBeGreaterThan(0);
|
||||
console.log('✅ temp-tester role created');
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user