Add a new e2e test for toggling issue reactions via the reaction picker dropdown. Add `aria-label` attributes to improve reaction accessibility: - Add `aria-label="Reaction"` to the reaction picker dropdown - Add `role="group"` with `aria-label="Reactions"` to the reactions container, giving it a semantic identity for screen readers - Include the reaction key in each reaction button's `aria-label` (e.g. `+1: user1, user2`) so screen readers announce which reaction a button represents E2e test improvements: - Simplify `randomString` to use `Math.random` instead of `node:crypto` - Replace `generatePassword` with a static password, remove unused `clickDropdownItem` - Enable `fullyParallel: true` and `workers: '50%'` in Playwright config - Run both chromium and firefox in all environments (not just CI) - Parallelize `login` and `apiCreateRepo` setup where possible - Use dedicated test user in `user-settings` test for concurrency safety Co-authored-by: Claude (Opus 4.6) <noreply@anthropic.com>
14 lines
583 B
TypeScript
14 lines
583 B
TypeScript
import {env} from 'node:process';
|
|
import {test} from '@playwright/test';
|
|
import {login, apiDeleteRepo, randomString} from './utils.ts';
|
|
|
|
test('create a repository', async ({page}) => {
|
|
const repoName = `e2e-repo-${randomString(8)}`;
|
|
await login(page);
|
|
await page.goto('/repo/create');
|
|
await page.locator('input[name="repo_name"]').fill(repoName);
|
|
await page.getByRole('button', {name: 'Create Repository'}).click();
|
|
await page.waitForURL(new RegExp(`/${env.GITEA_TEST_E2E_USER}/${repoName}$`));
|
|
await apiDeleteRepo(page.request, env.GITEA_TEST_E2E_USER, repoName);
|
|
});
|