rsnext/test/development/acceptance/component-stack.test.ts
Hannes Bornö d59aa9655e
Port error overlay hydration error to pages directory (#46677)
Co-authored-by: JJ Kasper <jj@jjsweb.site>
2023-03-06 19:40:25 -08:00

62 lines
1.2 KiB
TypeScript

/* eslint-env jest */
import { sandbox } from './helpers'
import { createNextDescribe } from 'e2e-utils'
createNextDescribe(
'Component Stack in error overlay',
{
files: {},
dependencies: {
react: 'latest',
'react-dom': 'latest',
},
skipStart: true,
},
({ next }) => {
it('should show a component stack on hydration error', async () => {
const { cleanup, session } = await sandbox(
next,
new Map([
[
'component.js',
`
const isClient = typeof window !== 'undefined'
export default function Component() {
return (
<div>
<p>{isClient ? "client" : "server"}</p>
</div>
);
}
`,
],
[
'index.js',
`
import Component from './component'
export default function Mismatch() {
return (
<main>
<Component />
</main>
);
}
`,
],
])
)
expect(await session.hasRedbox(true)).toBe(true)
expect(await session.getRedboxComponentStack()).toMatchInlineSnapshot(`
"p
div
Component
main
Mismatch"
`)
await cleanup()
})
}
)