59 lines
2.1 KiB
TypeScript
59 lines
2.1 KiB
TypeScript
import type { Page } from '@playwright/test'
|
|
|
|
import { expect, test } from '@playwright/test'
|
|
|
|
import { initPageConsoleErrorCatch } from '../helpers.js'
|
|
import { initPayloadE2E } from '../helpers/configHelpers.js'
|
|
import config from './config.js'
|
|
|
|
const { beforeAll, describe } = test
|
|
|
|
import path from 'path'
|
|
import { fileURLToPath } from 'url'
|
|
const filename = fileURLToPath(import.meta.url)
|
|
const dirname = path.dirname(filename)
|
|
|
|
describe('field error states', () => {
|
|
let serverURL: string
|
|
let page: Page
|
|
|
|
beforeAll(async ({ browser }) => {
|
|
;({ serverURL } = await initPayloadE2E({ config, dirname }))
|
|
const context = await browser.newContext()
|
|
page = await context.newPage()
|
|
initPageConsoleErrorCatch(page)
|
|
})
|
|
|
|
test('Remove row should remove error states from parent fields', async () => {
|
|
await page.goto(`${serverURL}/admin/collections/error-fields/create`)
|
|
|
|
// add parent array
|
|
await page.locator('#field-parentArray > .array-field__add-row').click()
|
|
|
|
// add first child array
|
|
await page.locator('#parentArray-row-0 .collapsible__content .array-field__add-row').click()
|
|
await page.locator('#field-parentArray__0__childArray__0__childArrayText').focus()
|
|
await page.keyboard.type('T1')
|
|
|
|
// add second child array
|
|
await page.locator('#parentArray-row-0 .collapsible__content .array-field__add-row').click()
|
|
await page.locator('#field-parentArray__0__childArray__1__childArrayText').focus()
|
|
await page.keyboard.type('T2')
|
|
|
|
// add third child array
|
|
await page.locator('#parentArray-row-0 .collapsible__content .array-field__add-row').click()
|
|
await page.locator('#parentArray-0-childArray-row-2 .array-actions__button').click()
|
|
await page
|
|
.locator('#parentArray-0-childArray-row-2 .array-actions__action.array-actions__remove')
|
|
.click()
|
|
|
|
await page.locator('#action-save').click()
|
|
|
|
const errorPill = await page.waitForSelector(
|
|
'#parentArray-row-0 > .collapsible > .collapsible__toggle-wrap .array-field__row-error-pill',
|
|
{ state: 'hidden', timeout: 500 },
|
|
)
|
|
expect(errorPill).toBeNull()
|
|
})
|
|
})
|