c0368e1b09
This addresses some errors for `/_next/data` requests where encoded `/` values in dynamic route param would cause invalid behavior, a headers already sent error would be shown when sending the fallback page in development, and when rendering the `_error` page for a data request the error response would still be treated as a data request. This also adds test cases for these errors to prevent regression
43 lines
907 B
JavaScript
43 lines
907 B
JavaScript
import React from 'react'
|
|
import Link from 'next/link'
|
|
import { useRouter } from 'next/router'
|
|
|
|
export async function getStaticPaths() {
|
|
return {
|
|
paths: [],
|
|
fallback: true,
|
|
}
|
|
}
|
|
|
|
export async function getStaticProps({ params }) {
|
|
await new Promise((resolve) => setTimeout(resolve, 1000))
|
|
|
|
return {
|
|
props: {
|
|
params,
|
|
hello: 'world',
|
|
post: params.slug,
|
|
random: Math.random(),
|
|
time: (await import('perf_hooks')).performance.now(),
|
|
},
|
|
unstable_revalidate: 1,
|
|
}
|
|
}
|
|
|
|
export default ({ post, time, params }) => {
|
|
if (useRouter().isFallback) {
|
|
return <p>hi fallback</p>
|
|
}
|
|
|
|
return (
|
|
<>
|
|
<p>Post: {post}</p>
|
|
<span>time: {time}</span>
|
|
<div id="params">{JSON.stringify(params)}</div>
|
|
<div id="query">{JSON.stringify(useRouter().query)}</div>
|
|
<Link href="/">
|
|
<a id="home">to home</a>
|
|
</Link>
|
|
</>
|
|
)
|
|
}
|