Some checks failed
Test examples / Test Examples (20) (push) Has been cancelled
Test examples / Test Examples (22) (push) Has been cancelled
Lock Threads / action (push) Has been cancelled
Trigger Release / start (push) Has been cancelled
Stale issue handler / stale (push) Has been cancelled
Update Font Data / create-pull-request (push) Has been cancelled
build-and-deploy / deploy-target (push) Has been cancelled
build-and-deploy / build (push) Has been cancelled
build-and-deploy / stable - aarch64-unknown-linux-musl - node@16 (push) Has been cancelled
build-and-deploy / stable - x86_64-unknown-linux-musl - node@16 (push) Has been cancelled
build-and-deploy / stable - aarch64-unknown-linux-gnu - node@16 (push) Has been cancelled
build-and-deploy / stable - x86_64-unknown-linux-gnu - node@16 (push) Has been cancelled
build-and-deploy / stable - aarch64-pc-windows-msvc - node@16 (push) Has been cancelled
build-and-deploy / stable - x86_64-pc-windows-msvc - node@16 (push) Has been cancelled
build-and-deploy / stable - aarch64-apple-darwin - node@16 (push) Has been cancelled
build-and-deploy / stable - x86_64-apple-darwin - node@16 (push) Has been cancelled
build-and-deploy / build-wasm (nodejs) (push) Has been cancelled
build-and-deploy / build-wasm (web) (push) Has been cancelled
build-and-deploy / Deploy preview tarball (push) Has been cancelled
build-and-deploy / Potentially publish release (push) Has been cancelled
build-and-deploy / publish-turbopack-npm-packages (push) Has been cancelled
build-and-deploy / Deploy examples (push) Has been cancelled
build-and-deploy / thank you, build (push) Has been cancelled
build-and-deploy / Upload Turbopack Bytesize metrics to Datadog (push) Has been cancelled
Rspack Next.js development integration tests / Rspack integration tests (push) Has been cancelled
Rspack Next.js production integration tests / Rspack integration tests (push) Has been cancelled
Turbopack Next.js development integration tests / Next.js integration tests (push) Has been cancelled
Turbopack Next.js production integration tests / Next.js integration tests (push) Has been cancelled
Update Rspack test manifest / Update and upload Rspack development test manifest (push) Has been cancelled
Update Rspack test manifest / Update and upload Rspack production test manifest (push) Has been cancelled
Upload bundler test manifests to areweturboyet.com / Upload test results (push) Has been cancelled
Update React / create-pull-request (push) Has been cancelled
test-e2e-project-reset-cron / reset-test-project (push) Has been cancelled
Notify about the top 15 issues/PRs/feature requests (most reacted) in the last 90 days / run (push) Has been cancelled
165 lines
5.8 KiB
TypeScript
165 lines
5.8 KiB
TypeScript
import { nextTestSetup } from 'e2e-utils'
|
||
import { waitForRedbox } from 'next-test-utils'
|
||
import stripAnsi from 'strip-ansi'
|
||
|
||
describe('use-cache-segment-configs', () => {
|
||
const { next, skipped, isNextDev, isTurbopack, isRspack } = nextTestSetup({
|
||
files: __dirname,
|
||
skipStart: process.env.NEXT_TEST_MODE !== 'dev',
|
||
skipDeployment: true,
|
||
})
|
||
|
||
if (skipped) {
|
||
return
|
||
}
|
||
|
||
it("it should error when using segment configs that aren't supported by useCache", async () => {
|
||
if (isNextDev) {
|
||
const browser = await next.browser('/runtime')
|
||
|
||
await waitForRedbox(browser)
|
||
|
||
if (isTurbopack) {
|
||
await expect(browser).toDisplayRedbox(`
|
||
{
|
||
"description": "Route segment config "runtime" is not compatible with \`nextConfig.experimental.useCache\`. Please remove it.",
|
||
"environmentLabel": null,
|
||
"label": "Build Error",
|
||
"source": "./app/runtime/page.tsx (1:14)
|
||
Route segment config "runtime" is not compatible with \`nextConfig.experimental.useCache\`. Please remove it.
|
||
> 1 | export const runtime = 'edge'
|
||
| ^^^^^^^",
|
||
"stack": [],
|
||
}
|
||
`)
|
||
} else if (isRspack) {
|
||
await expect(browser).toDisplayRedbox(`
|
||
{
|
||
"description": " ╰─▶ × Error: x Route segment config "runtime" is not compatible with \`nextConfig.experimental.useCache\`. Please remove it.",
|
||
"environmentLabel": null,
|
||
"label": "Build Error",
|
||
"source": "<FIXME-nextjs-internal-source>
|
||
╰─▶ × Error: x Route segment config "runtime" is not compatible with \`nextConfig.experimental.useCache\`. Please remove it.
|
||
│ ,-[1:1]
|
||
│ 1 | export const runtime = 'edge'
|
||
│ : ^^^^^^^
|
||
│ 2 |
|
||
│ 3 | export default function Page() {
|
||
│ 4 | return <div>This page uses \`export const runtime\`.</div>
|
||
│ \`----
|
||
│",
|
||
"stack": [],
|
||
}
|
||
`)
|
||
} else {
|
||
// FIXME: Fix broken import trace for Webpack loader resource.
|
||
await expect(browser).toDisplayRedbox(`
|
||
{
|
||
"description": " x Route segment config "runtime" is not compatible with \`nextConfig.experimental.useCache\`. Please remove it.",
|
||
"environmentLabel": null,
|
||
"label": "Build Error",
|
||
"source": "<FIXME-nextjs-internal-source>
|
||
Error: x Route segment config "runtime" is not compatible with \`nextConfig.experimental.useCache\`. Please remove it.
|
||
,-[1:1]
|
||
1 | export const runtime = 'edge'
|
||
: ^^^^^^^
|
||
2 |
|
||
3 | export default function Page() {
|
||
4 | return <div>This page uses \`export const runtime\`.</div>
|
||
\`----",
|
||
"stack": [],
|
||
}
|
||
`)
|
||
}
|
||
} else {
|
||
const { cliOutput } = await next.build()
|
||
|
||
const buildOutput = getBuildOutput(cliOutput)
|
||
|
||
if (isTurbopack) {
|
||
expect(buildOutput).toMatchInlineSnapshot(`
|
||
"Error: Turbopack build failed with 1 errors:
|
||
./app/runtime/page.tsx:1:14
|
||
Route segment config "runtime" is not compatible with \`nextConfig.experimental.useCache\`. Please remove it.
|
||
> 1 | export const runtime = 'edge'
|
||
| ^^^^^^^
|
||
2 |
|
||
3 | export default function Page() {
|
||
4 | return <div>This page uses \`export const runtime\`.</div>
|
||
|
||
Ecmascript file had an error
|
||
|
||
|
||
at <unknown> (./app/runtime/page.tsx:1:14)
|
||
"
|
||
`)
|
||
} else if (isRspack) {
|
||
expect(buildOutput).toMatchInlineSnapshot(`
|
||
"
|
||
// TODO(veil): Fix broken import trace for Webpack loader resource.
|
||
╰─▶ × Error: x Route segment config "runtime" is not compatible with \`nextConfig.experimental.useCache\`. Please remove it.
|
||
│ ,-[1:1]
|
||
│ 1 | export const runtime = 'edge'
|
||
│ : ^^^^^^^
|
||
│ 2 |
|
||
│ 3 | export default function Page() {
|
||
│ 4 | return <div>This page uses \`export const runtime\`.</div>
|
||
│ \`----
|
||
│
|
||
|
||
Import trace for requested module:
|
||
// TODO(veil): Fix broken import trace for Webpack loader resource.
|
||
|
||
|
||
> Build failed because of Rspack errors
|
||
"
|
||
`)
|
||
} else {
|
||
expect(buildOutput).toMatchInlineSnapshot(`
|
||
"
|
||
// TODO(veil): Fix broken import trace for Webpack loader resource.
|
||
Error: x Route segment config "runtime" is not compatible with \`nextConfig.experimental.useCache\`. Please remove it.
|
||
,-[1:1]
|
||
1 | export const runtime = 'edge'
|
||
: ^^^^^^^
|
||
2 |
|
||
3 | export default function Page() {
|
||
4 | return <div>This page uses \`export const runtime\`.</div>
|
||
\`----
|
||
|
||
Import trace for requested module:
|
||
// TODO(veil): Fix broken import trace for Webpack loader resource.
|
||
|
||
|
||
> Build failed because of webpack errors
|
||
"
|
||
`)
|
||
}
|
||
}
|
||
})
|
||
})
|
||
|
||
function getBuildOutput(cliOutput: string): string {
|
||
const lines: string[] = []
|
||
let skipLines = true
|
||
|
||
for (const line of cliOutput.split('\n')) {
|
||
if (!skipLines) {
|
||
if (line.includes('__next_edge_ssr_entry__')) {
|
||
lines.push(
|
||
'// TODO(veil): Fix broken import trace for Webpack loader resource.'
|
||
)
|
||
} else {
|
||
lines.push(stripAnsi(line))
|
||
}
|
||
} else if (
|
||
line.includes('Build error occurred') ||
|
||
line.includes('Failed to compile')
|
||
) {
|
||
skipLines = false
|
||
}
|
||
}
|
||
|
||
return lines.join('\n')
|
||
}
|