Skip to content

Commit

Permalink
test: make e2e stable
Browse files Browse the repository at this point in the history
  • Loading branch information
eoaksnes committed Nov 1, 2023
1 parent e9aa2ec commit da7eacb
Show file tree
Hide file tree
Showing 6 changed files with 42 additions and 13 deletions.
2 changes: 1 addition & 1 deletion e2e/playwright.config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ export default defineConfig({
/* Retries will always fail due to missing call to ./reset-all.sh */
retries: 0,
/* Opt out of parallel tests on CI. */
workers: process.env.CI ? 1 : undefined,
workers: process.env.CI ? 6 : undefined,
/* Reporter to use. See https://playwright.dev/docs/test-reporters */
reporter: 'html',
/* Shared settings for all the projects below. See https://playwright.dev/docs/api/class-testoptions. */
Expand Down
10 changes: 10 additions & 0 deletions e2e/tests/plugin-list-task_list.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,8 @@ async function reloadPage(page: Page) {
}

test('Add a new task', async ({ page }) => {
const lastTabPanel = page.getByRole('tabpanel').last()
await expect(lastTabPanel).toBeVisible()
await page.getByRole('button', { name: 'Add item' }).click()
await expect(page.getByText('1 - 4 of 4')).toBeVisible()
await page.getByRole('button', { name: 'Save' }).click()
Expand All @@ -43,6 +45,7 @@ test('Add a new task', async ({ page }) => {
await expect(page.getByRole('alert')).toHaveText(['Document updated'])
await page.getByRole('button', { name: 'close', exact: true }).click()
await reloadPage(page) //TODO: Remove when #153 is solved.
await expect(lastTabPanel).toBeVisible()
await expect(page.getByText('Tax return', { exact: true })).toBeVisible()
await page
.getByRole('button', { name: 'Open item', exact: true })
Expand All @@ -62,10 +65,13 @@ test('Add a new task', async ({ page }) => {
})

test('Mark task as complete', async ({ page }) => {
const lastTabPanel = page.getByRole('tabpanel').last()
await expect(lastTabPanel).toBeVisible()
await page
.getByRole('button', { name: 'Open item', exact: true })
.first()
.click()
await expect(page.getByRole('button', { name: 'Submit' })).toBeVisible()
await expect(page.getByLabel('Task title:')).toHaveValue('Wash the car')
await page.getByText('Mark task as complete').click()
await page.getByRole('button', { name: 'Submit' }).click()
Expand All @@ -76,6 +82,7 @@ test('Mark task as complete', async ({ page }) => {
.getByRole('button', { name: 'Open item', exact: true })
.first()
.click()
await expect(page.getByTestId('form-checkbox')).toBeVisible()
await expect(page.getByTestId('form-checkbox')).toBeChecked()
await page
.getByRole('button', { name: 'Close item', exact: true })
Expand All @@ -84,6 +91,8 @@ test('Mark task as complete', async ({ page }) => {
})

test('Delete a task', async ({ page }) => {
const lastTabPanel = page.getByRole('tabpanel').last()
await expect(lastTabPanel).toBeVisible()
await expect(
page.getByRole('paragraph').getByText('Tax return')
).toBeVisible()
Expand All @@ -96,6 +105,7 @@ test('Delete a task', async ({ page }) => {
await page.getByRole('button', { name: 'Save' }).click()
await expect(page.getByRole('button', { name: 'Save' })).toBeDisabled()
await reloadPage(page) //TODO: Remove when #153 is solved.
await expect(lastTabPanel).toBeVisible()
await expect(
page.getByRole('paragraph').getByText('Wash the car')
).toBeVisible()
Expand Down
2 changes: 2 additions & 0 deletions e2e/tests/plugin-table-car_list.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,8 @@ test('Table car list example', async ({ page }) => {
await page.getByRole('button', { name: 'table' }).click()
await page.getByRole('button', { name: 'car_list' }).click()
await page.getByRole('button', { name: 'CarList' }).click()
const lastTabPanel = page.getByRole('tabpanel').last()
await expect(lastTabPanel).toBeVisible()
}

await page.goto('http://localhost:3000/')
Expand Down
34 changes: 26 additions & 8 deletions packages/dm-core-plugins/src/view_selector/Content.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,15 +4,36 @@ import {
ViewCreator,
} from '@development-framework/dm-core'
import * as React from 'react'
import styled from 'styled-components'
import { TItemData } from './types'
import { PropsWithChildren, useRef } from 'react'
import styled from 'styled-components'

type LazyProps = {
visible: boolean
}

const HidableWrapper = styled.div<any>`
const HideContentWrapper = styled.div<any>`
display: ${(props: { hidden: boolean }) => (props.hidden && 'none') || 'flex'}
align-self: normal;
width: 100%;
`

const Lazy = ({ visible, children }: PropsWithChildren<LazyProps>) => {
const rendered = useRef(visible)

if (visible && !rendered.current) {
rendered.current = true
}

if (!rendered.current) return null

return (
<HideContentWrapper hidden={!visible} role="tabpanel">
{children}
</HideContentWrapper>
)
}

export const Content = (props: {
type: string
selectedViewId: string
Expand All @@ -24,14 +45,11 @@ export const Content = (props: {
}): React.ReactElement => {
const { selectedViewId, viewSelectorItems, setFormData, formData, onOpen } =
props

return (
<div style={props.style}>
{viewSelectorItems.map((config: TItemData) => (
<HidableWrapper
key={config.viewId}
hidden={config.viewId !== selectedViewId}
role="tabpanel"
>
<Lazy key={config.viewId} visible={selectedViewId == config.viewId}>
<ViewCreator
idReference={config.rootEntityId}
viewConfig={config.viewConfig}
Expand All @@ -43,7 +61,7 @@ export const Content = (props: {
})
}}
/>
</HidableWrapper>
</Lazy>
))}
</div>
)
Expand Down
6 changes: 3 additions & 3 deletions packages/dm-core-plugins/src/view_selector/TabsPlugin.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { IUIPlugin, Loading } from '@development-framework/dm-core'
import { IUIPlugin } from '@development-framework/dm-core'
import { TViewSelectorConfig } from './types'
import * as React from 'react'
import { Tabs } from './Tabs'
Expand All @@ -7,7 +7,7 @@ import { useViewSelector } from './useViewSelector'

export const TabsPlugin = (
props: IUIPlugin & { config?: TViewSelectorConfig }
): React.ReactElement => {
): React.ReactElement | null => {
const { idReference, config, type } = props

const {
Expand All @@ -26,7 +26,7 @@ export const TabsPlugin = (
throw new Error(JSON.stringify(error, null, 2))
}
if (isLoading || !viewSelectorItems.length || !selectedViewId) {
return <Loading />
return null
}

return (
Expand Down
1 change: 0 additions & 1 deletion packages/dm-core/src/hooks/useList.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -69,7 +69,6 @@ export function useList<T extends object>(
.catch((error: AxiosError<ErrorResponse>) => {
setError(error.response?.data || { message: error.name, data: error })
})
.finally(() => setLoading(false))
}, [dmssAPI, idReference])

useEffect(() => {
Expand Down

0 comments on commit da7eacb

Please sign in to comment.