mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2025-04-25 00:56:17 +00:00
chore: improve repo migrate e2e test (#7378)
- Generate a repository name for each run, such that retries will use a new repository and not have any leftover. - Make the test actually pass by ensuring the unauthenticated page didn't reuse storage state that contained authenticated cookies. Reviewed-on: https://codeberg.org/forgejo/forgejo/pulls/7378 Reviewed-by: 0ko <0ko@noreply.codeberg.org> Co-authored-by: Gusted <postmaster@gusted.xyz> Co-committed-by: Gusted <postmaster@gusted.xyz>
This commit is contained in:
parent
facc2bb28e
commit
7baf9994bd
1 changed files with 8 additions and 7 deletions
|
@ -38,21 +38,22 @@ test('Migration Repo Name detection', async ({page}, workerInfo) => {
|
||||||
test('Migration Progress Page', async ({page, browser}, workerInfo) => {
|
test('Migration Progress Page', async ({page, browser}, workerInfo) => {
|
||||||
test.skip(workerInfo.project.name === 'Mobile Safari', 'Flaky actionability checks on Mobile Safari');
|
test.skip(workerInfo.project.name === 'Mobile Safari', 'Flaky actionability checks on Mobile Safari');
|
||||||
|
|
||||||
expect((await page.goto('/user2/invalidrepo'))?.status(), 'repo should not exist yet').toBe(404);
|
const repoName = `invalidrepo-${globalThis.crypto.randomUUID()}`;
|
||||||
|
expect((await page.goto(`/user2/${repoName}`))?.status(), 'repo should not exist yet').toBe(404);
|
||||||
|
|
||||||
await page.goto('/repo/migrate?service_type=1');
|
await page.goto('/repo/migrate?service_type=1');
|
||||||
|
|
||||||
const form = page.locator('form');
|
const form = page.locator('form');
|
||||||
await form.getByRole('textbox', {name: 'Repository Name'}).fill('invalidrepo');
|
await form.getByRole('textbox', {name: 'Repository Name'}).fill(repoName);
|
||||||
await form.getByRole('textbox', {name: 'Migrate / Clone from URL'}).fill('https://codeberg.org/forgejo/invalidrepo');
|
await form.getByRole('textbox', {name: 'Migrate / Clone from URL'}).fill(`https://codeberg.org/forgejo/${repoName}`);
|
||||||
await save_visual(page);
|
await save_visual(page);
|
||||||
await form.locator('button.primary').click({timeout: 5000});
|
await form.locator('button.primary').click({timeout: 5000});
|
||||||
await expect(page).toHaveURL('user2/invalidrepo');
|
await expect(page).toHaveURL(`user2/${repoName}`);
|
||||||
await save_visual(page);
|
await save_visual(page);
|
||||||
|
|
||||||
const ctx = await test_context(browser);
|
const ctx = await test_context(browser, {storageState: {cookies: [], origins: []}});
|
||||||
const unauthenticatedPage = await ctx.newPage();
|
const unauthenticatedPage = await ctx.newPage();
|
||||||
expect((await unauthenticatedPage.goto('/user2/invalidrepo'))?.status(), 'public migration page should be accessible').toBe(200);
|
expect((await unauthenticatedPage.goto(`/user2/${repoName}`))?.status(), 'public migration page should be accessible').toBe(200);
|
||||||
await expect(unauthenticatedPage.locator('#repo_migrating_progress')).toBeVisible();
|
await expect(unauthenticatedPage.locator('#repo_migrating_progress')).toBeVisible();
|
||||||
|
|
||||||
await page.reload();
|
await page.reload();
|
||||||
|
@ -60,7 +61,7 @@ test('Migration Progress Page', async ({page, browser}, workerInfo) => {
|
||||||
await save_visual(page);
|
await save_visual(page);
|
||||||
await page.getByRole('button', {name: 'Delete this repository'}).click();
|
await page.getByRole('button', {name: 'Delete this repository'}).click();
|
||||||
const deleteModal = page.locator('#delete-repo-modal');
|
const deleteModal = page.locator('#delete-repo-modal');
|
||||||
await deleteModal.getByRole('textbox', {name: 'Confirmation string'}).fill('user2/invalidrepo');
|
await deleteModal.getByRole('textbox', {name: 'Confirmation string'}).fill(`user2/${repoName}`);
|
||||||
await save_visual(page);
|
await save_visual(page);
|
||||||
await deleteModal.getByRole('button', {name: 'Delete repository'}).click();
|
await deleteModal.getByRole('button', {name: 'Delete repository'}).click();
|
||||||
await expect(page).toHaveURL('/');
|
await expect(page).toHaveURL('/');
|
||||||
|
|
Loading…
Add table
Reference in a new issue