227 lines
8.2 KiB
TypeScript
227 lines
8.2 KiB
TypeScript
import type { Page } from '@playwright/test';
|
|
import { expect, test } from '@playwright/test';
|
|
import { AdminUrlUtil } from '../helpers/adminUrlUtil';
|
|
import { initPayloadE2E } from '../helpers/configHelpers';
|
|
import { login, saveDocAndAssert } from '../helpers';
|
|
import { textDoc } from './collections/Text';
|
|
import { arrayFieldsSlug } from './collections/Array';
|
|
import { pointFieldsSlug } from './collections/Point';
|
|
import { tabsSlug } from './collections/Tabs';
|
|
import wait from '../../src/utilities/wait';
|
|
|
|
const { beforeAll, describe } = test;
|
|
|
|
let page: Page;
|
|
let serverURL;
|
|
|
|
describe('fields', () => {
|
|
beforeAll(async ({ browser }) => {
|
|
const config = await initPayloadE2E(__dirname);
|
|
serverURL = config.serverURL;
|
|
|
|
const context = await browser.newContext();
|
|
page = await context.newPage();
|
|
|
|
await login({ page, serverURL });
|
|
});
|
|
|
|
describe('text', () => {
|
|
test('should display field in list view', async () => {
|
|
const url: AdminUrlUtil = new AdminUrlUtil(serverURL, 'text-fields');
|
|
await page.goto(url.list);
|
|
const textCell = page.locator('.row-1 .cell-text');
|
|
await expect(textCell)
|
|
.toHaveText(textDoc.text);
|
|
});
|
|
});
|
|
|
|
describe('point', () => {
|
|
let url: AdminUrlUtil;
|
|
beforeAll(() => {
|
|
url = new AdminUrlUtil(serverURL, pointFieldsSlug);
|
|
});
|
|
|
|
test('should save point', async () => {
|
|
await page.goto(url.create);
|
|
const longField = page.locator('#field-longitude-point');
|
|
await longField.fill('9');
|
|
|
|
const latField = page.locator('#field-latitude-point');
|
|
await latField.fill('-2');
|
|
|
|
const localizedLongField = page.locator('#field-longitude-localized');
|
|
await localizedLongField.fill('1');
|
|
|
|
const localizedLatField = page.locator('#field-latitude-localized');
|
|
await localizedLatField.fill('-1');
|
|
|
|
const groupLongitude = page.locator('#field-longitude-group__point');
|
|
await groupLongitude.fill('3');
|
|
|
|
const groupLatField = page.locator('#field-latitude-group__point');
|
|
await groupLatField.fill('-8');
|
|
|
|
await saveDocAndAssert(page);
|
|
});
|
|
});
|
|
|
|
describe('fields - array', () => {
|
|
let url: AdminUrlUtil;
|
|
beforeAll(() => {
|
|
url = new AdminUrlUtil(serverURL, arrayFieldsSlug);
|
|
});
|
|
|
|
test('should be readOnly', async () => {
|
|
await page.goto(url.create);
|
|
const field = page.locator('#field-readOnly__0__text');
|
|
await expect(field)
|
|
.toBeDisabled();
|
|
});
|
|
|
|
test('should have defaultValue', async () => {
|
|
await page.goto(url.create);
|
|
const field = page.locator('#field-readOnly__0__text');
|
|
await expect(field)
|
|
.toHaveValue('defaultValue');
|
|
});
|
|
});
|
|
|
|
describe('fields - tabs', () => {
|
|
let url: AdminUrlUtil;
|
|
beforeAll(() => {
|
|
url = new AdminUrlUtil(serverURL, tabsSlug);
|
|
});
|
|
|
|
test('should fill and retain a new value within a tab while switching tabs', async () => {
|
|
const textInRowValue = 'hello';
|
|
const numberInRowValue = '23';
|
|
|
|
await page.goto(url.create);
|
|
|
|
await page.locator('.tabs-field__tab-button:has-text("Tab with Row")').click();
|
|
await page.locator('#field-textInRow').fill(textInRowValue);
|
|
await page.locator('#field-numberInRow').fill(numberInRowValue);
|
|
|
|
await wait(300);
|
|
|
|
await page.locator('.tabs-field__tab-button:has-text("Tab with Array")').click();
|
|
await page.locator('.tabs-field__tab-button:has-text("Tab with Row")').click();
|
|
|
|
await wait(100);
|
|
|
|
await expect(page.locator('#field-textInRow')).toHaveValue(textInRowValue);
|
|
await expect(page.locator('#field-numberInRow')).toHaveValue(numberInRowValue);
|
|
});
|
|
|
|
test('should retain updated values within tabs while switching between tabs', async () => {
|
|
const textInRowValue = 'new value';
|
|
await page.goto(url.list);
|
|
await page.locator('.cell-id a').click();
|
|
|
|
// Go to Row tab, update the value
|
|
await page.locator('.tabs-field__tab-button:has-text("Tab with Row")').click();
|
|
await page.locator('#field-textInRow').fill(textInRowValue);
|
|
|
|
await wait(100);
|
|
|
|
// Go to Array tab, then back to Row. Make sure new value is still there
|
|
await page.locator('.tabs-field__tab-button:has-text("Tab with Array")').click();
|
|
await page.locator('.tabs-field__tab-button:has-text("Tab with Row")').click();
|
|
|
|
await expect(page.locator('#field-textInRow')).toHaveValue(textInRowValue);
|
|
|
|
// Go to array tab, save the doc
|
|
await page.locator('.tabs-field__tab-button:has-text("Tab with Array")').click();
|
|
await page.click('#action-save', { delay: 100 });
|
|
|
|
await wait(250);
|
|
|
|
// Go back to row tab, make sure the new value is still present
|
|
await page.locator('.tabs-field__tab-button:has-text("Tab with Row")').click();
|
|
await expect(page.locator('#field-textInRow')).toHaveValue(textInRowValue);
|
|
});
|
|
});
|
|
|
|
describe('fields - richText', () => {
|
|
async function navigateToRichTextFields() {
|
|
const url: AdminUrlUtil = new AdminUrlUtil(serverURL, 'rich-text-fields');
|
|
await page.goto(url.list);
|
|
await page.locator('.row-1 .cell-id').click();
|
|
}
|
|
|
|
describe('toolbar', () => {
|
|
test('should create new url link', async () => {
|
|
await navigateToRichTextFields();
|
|
|
|
// Open link popup
|
|
await page.locator('.rich-text__toolbar button:not([disabled]) .link').click();
|
|
|
|
const editLinkModal = page.locator('.rich-text-link-edit-modal__template');
|
|
await expect(editLinkModal).toBeVisible();
|
|
|
|
// Fill values and click Confirm
|
|
await editLinkModal.locator('#field-text').fill('link text');
|
|
await editLinkModal.locator('label[for="field-linkType-custom"]').click();
|
|
await editLinkModal.locator('#field-url').fill('https://payloadcms.com');
|
|
await wait(200);
|
|
await editLinkModal.locator('button[type="submit"]').click();
|
|
|
|
// Remove link from editor body
|
|
await page.locator('span >> text="link text"').click();
|
|
const popup = page.locator('.popup--active .rich-text-link__popup');
|
|
await expect(popup.locator('.rich-text-link__link-label')).toBeVisible();
|
|
await popup.locator('.rich-text-link__link-close').click();
|
|
await expect(page.locator('span >> text="link text"')).toHaveCount(0);
|
|
});
|
|
|
|
test('should not create new url link when read only', async () => {
|
|
await navigateToRichTextFields();
|
|
|
|
// Attempt to open link popup
|
|
const modalTrigger = page.locator('.rich-text--read-only .rich-text__toolbar button .link');
|
|
await expect(modalTrigger).toBeDisabled();
|
|
});
|
|
});
|
|
|
|
describe('editor', () => {
|
|
test('should populate url link', async () => {
|
|
navigateToRichTextFields();
|
|
|
|
// Open link popup
|
|
await page.locator('#field-richText span >> text="render links"').click();
|
|
const popup = page.locator('.popup--active .rich-text-link__popup');
|
|
await expect(popup).toBeVisible();
|
|
await expect(popup.locator('a')).toHaveAttribute('href', 'https://payloadcms.com');
|
|
|
|
// Open link edit modal
|
|
await popup.locator('.rich-text-link__link-edit').click();
|
|
const editLinkModal = page.locator('.rich-text-link-edit-modal__template');
|
|
await expect(editLinkModal).toBeVisible();
|
|
|
|
// Close link edit modal
|
|
await editLinkModal.locator('button[type="submit"]').click();
|
|
await expect(editLinkModal).not.toBeVisible();
|
|
});
|
|
|
|
test('should populate relationship link', async () => {
|
|
navigateToRichTextFields();
|
|
|
|
// Open link popup
|
|
await page.locator('#field-richText span >> text="link to relationships"').click();
|
|
const popup = page.locator('.popup--active .rich-text-link__popup');
|
|
await expect(popup).toBeVisible();
|
|
await expect(popup.locator('a')).toHaveAttribute('href', /\/admin\/collections\/array-fields\/.*/);
|
|
|
|
// Open link edit modal
|
|
await popup.locator('.rich-text-link__link-edit').click();
|
|
const editLinkModal = page.locator('.rich-text-link-edit-modal__template');
|
|
await expect(editLinkModal).toBeVisible();
|
|
|
|
// Close link edit modal
|
|
await editLinkModal.locator('button[type="submit"]').click();
|
|
await expect(editLinkModal).not.toBeVisible();
|
|
});
|
|
});
|
|
});
|
|
});
|