2022-09-02 21:18:23 +02:00
|
|
|
// @ts-check
|
2024-09-11 22:34:33 +02:00
|
|
|
|
|
|
|
// @watch start
|
|
|
|
// templates/user/auth/**
|
|
|
|
// web_src/js/features/user-**
|
|
|
|
// modules/{user,auth}/**
|
|
|
|
// @watch end
|
|
|
|
|
2024-08-14 23:34:36 +02:00
|
|
|
import {expect} from '@playwright/test';
|
2024-09-14 12:04:43 +02:00
|
|
|
import {test, login_user, save_visual} from './utils_e2e.js';
|
2022-09-02 21:18:23 +02:00
|
|
|
|
|
|
|
test.beforeAll(async ({browser}, workerInfo) => {
|
|
|
|
await login_user(browser, workerInfo, 'user2');
|
|
|
|
});
|
|
|
|
|
|
|
|
test('Load Homepage', async ({page}) => {
|
|
|
|
const response = await page.goto('/');
|
2024-10-23 16:22:25 +02:00
|
|
|
expect(response?.status()).toBe(200); // Status OK
|
2024-06-08 20:33:55 +02:00
|
|
|
await expect(page).toHaveTitle(/^Forgejo: Beyond coding. We Forge.\s*$/);
|
2022-09-02 21:18:23 +02:00
|
|
|
await expect(page.locator('.logo')).toHaveAttribute('src', '/assets/img/logo.svg');
|
|
|
|
});
|
|
|
|
|
2024-07-22 20:03:32 +02:00
|
|
|
test('Register Form', async ({page}, workerInfo) => {
|
2022-09-02 21:18:23 +02:00
|
|
|
const response = await page.goto('/user/sign_up');
|
2024-10-23 16:22:25 +02:00
|
|
|
expect(response?.status()).toBe(200); // Status OK
|
2022-09-02 21:18:23 +02:00
|
|
|
await page.type('input[name=user_name]', `e2e-test-${workerInfo.workerIndex}`);
|
|
|
|
await page.type('input[name=email]', `e2e-test-${workerInfo.workerIndex}@test.com`);
|
2023-08-21 21:27:50 +02:00
|
|
|
await page.type('input[name=password]', 'test123test123');
|
|
|
|
await page.type('input[name=retype]', 'test123test123');
|
2023-09-19 00:05:31 +02:00
|
|
|
await page.click('form button.ui.primary.button:visible');
|
2022-09-02 21:18:23 +02:00
|
|
|
// Make sure we routed to the home page. Else login failed.
|
2024-10-23 16:22:25 +02:00
|
|
|
expect(page.url()).toBe(`${workerInfo.project.use.baseURL}/`);
|
2024-03-23 00:54:09 +01:00
|
|
|
await expect(page.locator('.secondary-nav span>img.ui.avatar')).toBeVisible();
|
2023-08-08 17:25:05 +02:00
|
|
|
await expect(page.locator('.ui.positive.message.flash-success')).toHaveText('Account was successfully created. Welcome!');
|
2022-09-02 21:18:23 +02:00
|
|
|
|
|
|
|
save_visual(page);
|
|
|
|
});
|
|
|
|
|
2024-09-14 12:04:43 +02:00
|
|
|
// eslint-disable-next-line playwright/no-skipped-test
|
|
|
|
test.describe.skip('example with different viewports (not actually run)', () => {
|
|
|
|
// only necessary when the default web / mobile devices are not enough.
|
|
|
|
// If you need to use a single fixed viewport, you can also use:
|
|
|
|
// test.use({viewport: {width: 400, height: 800}});
|
|
|
|
// also see https://playwright.dev/docs/test-parameterize
|
|
|
|
for (const width of [400, 1000]) {
|
|
|
|
// do not actually run (skip) this test
|
|
|
|
test(`Do x on width: ${width}px`, async ({page}) => {
|
|
|
|
await page.setViewportSize({
|
|
|
|
width,
|
|
|
|
height: 800,
|
|
|
|
});
|
|
|
|
// do something, then check that an element is fully in viewport
|
|
|
|
// (i.e. not overflowing)
|
|
|
|
await expect(page.locator('#my-element')).toBeInViewport({ratio: 1});
|
|
|
|
});
|
|
|
|
}
|
2022-09-02 21:18:23 +02:00
|
|
|
});
|