35f507242c
- Reverts https://github.com/vercel/next.js/pull/44616 - Regression introduced in https://github.com/vercel/next.js/pull/51651 - Fixes https://github.com/vercel/next.js/issues/55013
108 lines
3.3 KiB
TypeScript
108 lines
3.3 KiB
TypeScript
import { createNextDescribe } from 'e2e-utils'
|
|
import { check } from 'next-test-utils'
|
|
|
|
createNextDescribe(
|
|
'app-dir edge SSR',
|
|
{
|
|
files: __dirname,
|
|
skipDeployment: true,
|
|
},
|
|
({ next }) => {
|
|
it('should handle edge only routes', async () => {
|
|
const appHtml = await next.render('/edge/basic')
|
|
expect(appHtml).toContain('<p>Edge!</p>')
|
|
|
|
const pageHtml = await next.render('/pages-edge')
|
|
expect(pageHtml).toContain('<p>pages-edge-ssr</p>')
|
|
})
|
|
|
|
it('should retrieve cookies in a server component in the edge runtime', async () => {
|
|
const res = await next.fetch('/edge-apis/cookies')
|
|
expect(await res.text()).toInclude('Hello')
|
|
})
|
|
|
|
it('should handle /index routes correctly', async () => {
|
|
const appHtml = await next.render('/index')
|
|
expect(appHtml).toContain('the /index route')
|
|
})
|
|
|
|
if ((globalThis as any).isNextDev) {
|
|
it('should warn about the re-export of a pages runtime/preferredRegion config', async () => {
|
|
const logs = []
|
|
next.on('stderr', (log) => {
|
|
logs.push(log)
|
|
})
|
|
const appHtml = await next.render('/export/inherit')
|
|
expect(appHtml).toContain('<p>Node!</p>')
|
|
expect(
|
|
logs.some((log) =>
|
|
log.includes(
|
|
`Next.js can't recognize the exported \`runtime\` field in`
|
|
)
|
|
)
|
|
).toBe(true)
|
|
expect(
|
|
logs.some((log) =>
|
|
log.includes(
|
|
`Next.js can't recognize the exported \`preferredRegion\` field in`
|
|
)
|
|
)
|
|
).toBe(true)
|
|
})
|
|
|
|
it('should resolve module without error in edge runtime', async () => {
|
|
const logs = []
|
|
next.on('stderr', (log) => {
|
|
logs.push(log)
|
|
})
|
|
await next.render('/app-edge')
|
|
expect(
|
|
logs.some((log) => log.includes(`Attempted import error:`))
|
|
).toBe(false)
|
|
})
|
|
|
|
it('should resolve client component without error', async () => {
|
|
const logs = []
|
|
next.on('stderr', (log) => {
|
|
logs.push(log)
|
|
})
|
|
const html = await next.render('/with-client')
|
|
expect(html).toContain('My Button')
|
|
expect(logs).toEqual([])
|
|
})
|
|
|
|
it('should handle edge rsc hmr', async () => {
|
|
const pageFile = 'app/edge/basic/page.tsx'
|
|
const content = await next.readFile(pageFile)
|
|
|
|
// Update rendered content
|
|
const updatedContent = content.replace('Edge!', 'edge-hmr')
|
|
await next.patchFile(pageFile, updatedContent)
|
|
await check(async () => {
|
|
const html = await next.render('/edge/basic')
|
|
return html
|
|
}, /edge-hmr/)
|
|
|
|
// Revert
|
|
await next.patchFile(pageFile, content)
|
|
await check(async () => {
|
|
const html = await next.render('/edge/basic')
|
|
return html
|
|
}, /Edge!/)
|
|
})
|
|
} else {
|
|
// Production tests
|
|
it('should generate matchers correctly in middleware manifest', async () => {
|
|
const manifest = JSON.parse(
|
|
await next.readFile('.next/server/middleware-manifest.json')
|
|
)
|
|
expect(manifest.functions['/(group)/group/page'].matchers).toEqual([
|
|
{
|
|
regexp: '^/group$',
|
|
originalSource: '/group',
|
|
},
|
|
])
|
|
})
|
|
}
|
|
}
|
|
)
|