Template
1
0
Fork 0
mirror of https://codeberg.org/forgejo/forgejo synced 2024-11-21 17:34:24 +01:00

e2e: Use the existing logged_in context for page

This commit is contained in:
Nirmal Kumar R 2024-11-19 17:52:58 +05:30
parent 4b7354a1af
commit 01402068e7

View file

@ -5,29 +5,37 @@
// @watch end
import {expect} from '@playwright/test';
import {test, load_logged_in_context, login, login_user} from './utils_e2e.ts';
import {test, load_logged_in_context, login_user} from './utils_e2e.ts';
test.beforeAll(async ({browser}, workerInfo) => {
await login_user(browser, workerInfo, 'user2');
});
test('Markdown image preview behaviour', async ({browser}, workerInfo) => {
const page = await login({browser}, workerInfo);
const context = await load_logged_in_context(browser, workerInfo, 'user2');
// editing the root README.md file for image preview
const editPath = '/user2/repo1/src/branch/master/README.md';
const page = await context.newPage();
const response = await page.goto(editPath, {waitUntil: 'domcontentloaded'});
expect(response?.status()).toBe(200);
// click 'Edit file' tab
await page.locator('[data-tooltip-content="Edit file"]').click();
// this yields the monaco editor
const editor = page.getByRole('presentation').nth(0);
await editor.click();
// clear all the content
await page.keyboard.press('ControlOrMeta+KeyA');
// add the image
await page.keyboard.type('![Logo of Forgejo](./assets/logo.svg "Logo of Forgejo")');
// click 'Preview' tab
await page.locator('a[data-tab="preview"]').click();
// check for the image preview via the expected attribute
const preview = page.locator('div[data-tab="preview"] p[dir="auto"] a');
await expect(preview).toHaveAttribute('href', 'http://localhost:3003/user2/repo1/media/branch/master/assets/logo.svg');
});