mirror of
https://github.com/go-gitea/gitea.git
synced 2024-12-05 00:44:12 +08:00
3ccda41a53
Fixes: https://github.com/go-gitea/gitea/issues/29981. Introduce `.secondary-nav` as a universal way for styling and margin adjustments inside `.page-content`. If the first child of `.page-content` is `.secondary-nav`, we add margin below it, otherwise we add padding to the first child. Notable changes: - `--color-header-wrapper` is replaced with `--color-secondary-nav-bg`. - `navbar` class is removed. --------- Co-authored-by: Giteabot <teabot@gitea.io> Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>
58 lines
2.2 KiB
JavaScript
58 lines
2.2 KiB
JavaScript
// @ts-check
|
|
import {test, expect} from '@playwright/test';
|
|
import {login_user, save_visual, load_logged_in_context} from './utils_e2e.js';
|
|
|
|
test.beforeAll(async ({browser}, workerInfo) => {
|
|
await login_user(browser, workerInfo, 'user2');
|
|
});
|
|
|
|
test('Load Homepage', async ({page}) => {
|
|
const response = await page.goto('/');
|
|
await expect(response?.status()).toBe(200); // Status OK
|
|
await expect(page).toHaveTitle(/^Gitea: Git with a cup of tea\s*$/);
|
|
await expect(page.locator('.logo')).toHaveAttribute('src', '/assets/img/logo.svg');
|
|
});
|
|
|
|
test('Test Register Form', async ({page}, workerInfo) => {
|
|
const response = await page.goto('/user/sign_up');
|
|
await expect(response?.status()).toBe(200); // Status OK
|
|
await page.type('input[name=user_name]', `e2e-test-${workerInfo.workerIndex}`);
|
|
await page.type('input[name=email]', `e2e-test-${workerInfo.workerIndex}@test.com`);
|
|
await page.type('input[name=password]', 'test123test123');
|
|
await page.type('input[name=retype]', 'test123test123');
|
|
await page.click('form button.ui.primary.button:visible');
|
|
// Make sure we routed to the home page. Else login failed.
|
|
await expect(page.url()).toBe(`${workerInfo.project.use.baseURL}/`);
|
|
await expect(page.locator('.secondary-nav span>img.ui.avatar')).toBeVisible();
|
|
await expect(page.locator('.ui.positive.message.flash-success')).toHaveText('Account was successfully created. Welcome!');
|
|
|
|
save_visual(page);
|
|
});
|
|
|
|
test('Test Login Form', async ({page}, workerInfo) => {
|
|
const response = await page.goto('/user/login');
|
|
await expect(response?.status()).toBe(200); // Status OK
|
|
|
|
await page.type('input[name=user_name]', `user2`);
|
|
await page.type('input[name=password]', `password`);
|
|
await page.click('form button.ui.primary.button:visible');
|
|
|
|
await page.waitForLoadState('networkidle');
|
|
|
|
await expect(page.url()).toBe(`${workerInfo.project.use.baseURL}/`);
|
|
|
|
save_visual(page);
|
|
});
|
|
|
|
test('Test Logged In User', async ({browser}, workerInfo) => {
|
|
const context = await load_logged_in_context(browser, workerInfo, 'user2');
|
|
const page = await context.newPage();
|
|
|
|
await page.goto('/');
|
|
|
|
// Make sure we routed to the home page. Else login failed.
|
|
await expect(page.url()).toBe(`${workerInfo.project.use.baseURL}/`);
|
|
|
|
save_visual(page);
|
|
});
|