test: stabilize task and role editor flows

This commit is contained in:
zhi
2026-03-16 13:22:24 +00:00
parent 53c974eb25
commit 67aa98da4f
2 changed files with 49 additions and 15 deletions

View File

@@ -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');
}