mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2025-04-24 20:47:30 +00:00

Ref https://codeberg.org/forgejo/design/issues/9. Changes: * Updated SVGs which had inconsistent paddings making them look off * Better usability on mobile * Better space efficiency on desktop, up to 4 columns * Nice responsive design * Less bland look on desktop. The borders were already here but invisible in Forgejo dark theme Preview: * https://codeberg.org/attachments/3c9e10ae-3315-46e5-b8bb-8021f6fd8936 * https://codeberg.org/attachments/8196ad89-5ab6-443a-98ce-a70dcc75bca9 * https://codeberg.org/attachments/24f52a14-2ac4-4949-8108-55c34bd3c650 Reviewed-on: https://codeberg.org/forgejo/forgejo/pulls/6795 Reviewed-by: Beowulf <beowulf@beocode.eu> Reviewed-by: Otto <otto@codeberg.org>
88 lines
4.1 KiB
TypeScript
88 lines
4.1 KiB
TypeScript
// @watch start
|
|
// web_src/js/features/repo-migrate.js
|
|
// @watch end
|
|
|
|
import {expect} from '@playwright/test';
|
|
import {test, save_visual, test_context, dynamic_id} from './utils_e2e.ts';
|
|
|
|
test.use({user: 'user2'});
|
|
|
|
test('Migration type seleciton screen', async ({page}) => {
|
|
await page.goto('/repo/migrate');
|
|
|
|
// For branding purposes, it is desired that `gitea-` prefixes in SVGs are
|
|
// replaced with something like `productlogo-`.
|
|
await expect(page.locator('svg.gitea-git')).toBeVisible();
|
|
await expect(page.locator('svg.octicon-mark-github')).toBeVisible();
|
|
await expect(page.locator('svg.gitea-gitlab')).toBeVisible();
|
|
await expect(page.locator('svg.gitea-forgejo')).toBeVisible();
|
|
await expect(page.locator('svg.gitea-gitea')).toBeVisible();
|
|
await expect(page.locator('svg.gitea-gogs')).toBeVisible();
|
|
await expect(page.locator('svg.gitea-onedev')).toBeVisible();
|
|
await expect(page.locator('svg.gitea-gitbucket')).toBeVisible();
|
|
await expect(page.locator('svg.gitea-codebase')).toBeVisible();
|
|
|
|
await save_visual(page);
|
|
});
|
|
|
|
test('Migration Repo Name detection', async ({page}, workerInfo) => {
|
|
test.skip(workerInfo.project.name === 'Mobile Safari', 'Flaky actionability checks on Mobile Safari');
|
|
|
|
await page.goto('/repo/migrate?service_type=2');
|
|
|
|
const form = page.locator('form');
|
|
|
|
// Test trailing slashes are stripped
|
|
await form.getByRole('textbox', {name: 'Migrate / Clone from URL'}).fill('https://github.com/example/test/');
|
|
await form.getByRole('textbox', {name: 'Migrate / Clone from URL'}).blur();
|
|
await expect(form.getByRole('textbox', {name: 'Repository Name'})).toHaveValue('test');
|
|
|
|
// Test trailing .git is stripped
|
|
await page.reload();
|
|
await form.getByRole('textbox', {name: 'Migrate / Clone from URL'}).fill('https://github.com/example/test.git');
|
|
await form.getByRole('textbox', {name: 'Migrate / Clone from URL'}).blur();
|
|
await expect(form.getByRole('textbox', {name: 'Repository Name'})).toHaveValue('test');
|
|
|
|
// Test trailing .git and trailing / together is stripped
|
|
await page.reload();
|
|
await form.getByRole('textbox', {name: 'Migrate / Clone from URL'}).fill('https://github.com/example/test.git/');
|
|
await form.getByRole('textbox', {name: 'Migrate / Clone from URL'}).blur();
|
|
await expect(form.getByRole('textbox', {name: 'Repository Name'})).toHaveValue('test');
|
|
|
|
// Save screenshot only once
|
|
await save_visual(page);
|
|
});
|
|
|
|
test('Migration Progress Page', async ({page, browser}, workerInfo) => {
|
|
test.skip(workerInfo.project.name === 'Mobile Safari', 'Flaky actionability checks on Mobile Safari');
|
|
|
|
const repoName = dynamic_id();
|
|
expect((await page.goto(`/user2/${repoName}`))?.status(), 'repo should not exist yet').toBe(404);
|
|
|
|
await page.goto('/repo/migrate?service_type=1');
|
|
|
|
const form = page.locator('form');
|
|
await form.getByRole('textbox', {name: 'Repository Name'}).fill(repoName);
|
|
await form.getByRole('textbox', {name: 'Migrate / Clone from URL'}).fill(`https://codeberg.org/forgejo/${repoName}`);
|
|
await save_visual(page);
|
|
await form.locator('button.primary').click({timeout: 5000});
|
|
await expect(page).toHaveURL(`user2/${repoName}`);
|
|
await save_visual(page);
|
|
|
|
const ctx = await test_context(browser, {storageState: {cookies: [], origins: []}});
|
|
const unauthenticatedPage = await ctx.newPage();
|
|
expect((await unauthenticatedPage.goto(`/user2/${repoName}`))?.status(), 'public migration page should be accessible').toBe(200);
|
|
await expect(unauthenticatedPage.locator('#repo_migrating_progress')).toBeVisible();
|
|
|
|
await page.reload();
|
|
await expect(page.locator('#repo_migrating_failed')).toBeVisible();
|
|
await save_visual(page);
|
|
await page.getByRole('button', {name: 'Delete this repository'}).click();
|
|
const deleteModal = page.locator('#delete-repo-modal');
|
|
await deleteModal.getByRole('textbox', {name: 'Confirmation string'}).fill(`user2/${repoName}`);
|
|
await save_visual(page);
|
|
await deleteModal.getByRole('button', {name: 'Delete repository'}).click();
|
|
await expect(page).toHaveURL('/');
|
|
// checked last to preserve the order of screenshots from first run
|
|
await save_visual(unauthenticatedPage);
|
|
});
|