2024-09-11 16:34:33 -04:00
|
|
|
// @watch start
|
|
|
|
// templates/user/auth/**
|
|
|
|
// web_src/js/features/user-**
|
|
|
|
// modules/{user,auth}/**
|
|
|
|
// @watch end
|
|
|
|
|
2024-08-14 17:34:36 -04:00
|
|
|
import {expect} from '@playwright/test';
|
2024-12-07 12:38:06 -05:00
|
|
|
import {test} from './utils_e2e.ts';
|
2022-09-02 15:18:23 -04:00
|
|
|
|
|
|
|
test('Load Homepage', async ({page}) => {
|
|
|
|
const response = await page.goto('/');
|
2024-10-23 10:22:25 -04:00
|
|
|
expect(response?.status()).toBe(200); // Status OK
|
2024-06-08 14:33:55 -04:00
|
|
|
await expect(page).toHaveTitle(/^Forgejo: Beyond coding. We Forge.\s*$/);
|
2022-09-02 15:18:23 -04:00
|
|
|
await expect(page.locator('.logo')).toHaveAttribute('src', '/assets/img/logo.svg');
|
|
|
|
});
|
|
|
|
|
2024-07-22 14:03:32 -04:00
|
|
|
test('Register Form', async ({page}, workerInfo) => {
|
2022-09-02 15:18:23 -04:00
|
|
|
const response = await page.goto('/user/sign_up');
|
2024-10-23 10:22:25 -04:00
|
|
|
expect(response?.status()).toBe(200); // Status OK
|
2024-11-14 19:41:55 -05:00
|
|
|
await page.fill('input[name=user_name]', `e2e-test-${workerInfo.workerIndex}`);
|
|
|
|
await page.fill('input[name=email]', `e2e-test-${workerInfo.workerIndex}@test.com`);
|
|
|
|
await page.fill('input[name=password]', 'test123test123');
|
|
|
|
await page.fill('input[name=retype]', 'test123test123');
|
2023-09-18 18:05:31 -04:00
|
|
|
await page.click('form button.ui.primary.button:visible');
|
2022-09-02 15:18:23 -04:00
|
|
|
// Make sure we routed to the home page. Else login failed.
|
2024-10-23 10:22:25 -04:00
|
|
|
expect(page.url()).toBe(`${workerInfo.project.use.baseURL}/`);
|
2024-03-22 19:54:09 -04:00
|
|
|
await expect(page.locator('.secondary-nav span>img.ui.avatar')).toBeVisible();
|
2023-08-08 11:25:05 -04:00
|
|
|
await expect(page.locator('.ui.positive.message.flash-success')).toHaveText('Account was successfully created. Welcome!');
|
2022-09-02 15:18:23 -04:00
|
|
|
});
|
|
|
|
|
2024-09-14 06:04:43 -04: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 15:18:23 -04:00
|
|
|
});
|