Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Upgrade React from 2d16326d-20240930 to 1460d67c-20241003 #70800

Open
wants to merge 5 commits into
base: canary
Choose a base branch
from

Conversation

vercel-release-bot
Copy link
Collaborator

breaking change for canary users: Bumps peer dependency of React from 19.0.0-rc-2d16326d-20240930 to 19.0.0-rc-1460d67c-20241003

diff facebook/react@2d16326d...1460d67c

React upstream changes

@ijjk ijjk added CI approved Approve running CI for fork create-next-app Related to our CLI tool for quickly starting a new Next.js application. examples Issue/PR related to examples tests type: next labels Oct 4, 2024
@ijjk
Copy link
Member

ijjk commented Oct 4, 2024

Failing test suites

Commit: 8677690

pnpm test test/integration/app-dir-export/test/dev-custom-dist-dir.test.ts

  • app dir - with output export and custom distDir (next dev) > should render properly
Expand output

● app dir - with output export and custom distDir (next dev) › should render properly

expect(received).toBe(expected) // Object.is equality

Expected: 200
Received: 500

  31 |   it('should render properly', async () => {
  32 |     const res = await fetchViaHTTP(appPort, '/')
> 33 |     expect(res.status).toBe(200)
     |                        ^
  34 |     expect(await res.text()).toContain('Home')
  35 |   })
  36 | })

  at Object.toBe (integration/app-dir-export/test/dev-custom-dist-dir.test.ts:33:24)

Read more about building and testing Next.js in contributing.md.

TURBOPACK=1 pnpm test-dev test/development/app-dir/experimental-lightningcss/experimental-lightningcss.test.ts (turbopack)

  • experimental-lightningcss > should support css modules
Expand output

● experimental-lightningcss › should support css modules

expect(received).toBe(expected) // Object.is equality

Expected: "hello world"
Received: ""

  10 |     // Recommended for tests that check HTML. Cheerio is a HTML parser that has a jQuery like API.
  11 |     const $ = await next.render$('/')
> 12 |     expect($('p').text()).toBe('hello world')
     |                           ^
  13 |     // swc_css does not include `-module` in the class name, while lightningcss does.
  14 |     expect($('p').attr('class')).toBe(
  15 |       'search-keyword style-module__hlQ3RG__blue'

  at Object.toBe (development/app-dir/experimental-lightningcss/experimental-lightningcss.test.ts:12:27)

Read more about building and testing Next.js in contributing.md.

TURBOPACK=1 pnpm test-dev test/development/app-dir/dev-fetch-hmr/dev-fetch-hmr.test.ts (turbopack)

  • dev-fetch-hmr > should retain module level fetch patching
Expand output

● dev-fetch-hmr › should retain module level fetch patching

expect(received).toBe(expected) // Object.is equality

Expected: "touch to trigger HMR"
Received: ""

  21 |     expect(magicNumber2).toBe(magicNumber)
  22 |     const update = cheerio.load(html2)('#update').text()
> 23 |     expect(update).toBe('touch to trigger HMR')
     |                    ^
  24 |
  25 |     // trigger HMR
  26 |     await next.patchFile('app/page.tsx', (content) =>

  at Object.toBe (development/app-dir/dev-fetch-hmr/dev-fetch-hmr.test.ts:23:20)

Read more about building and testing Next.js in contributing.md.

pnpm test test/integration/babel-next-image/babel-next-image.test.js

  • babel-next-image > should work with babel and next/image
Expand output

● babel-next-image › should work with babel and next/image

expect(received).toBe(expected) // Object.is equality

Expected: 200
Received: 500

  15 |   it('should work with babel and next/image', async () => {
  16 |     const res = await fetchViaHTTP(appPort, '/')
> 17 |     expect(res.status).toBe(200)
     |                        ^
  18 |   })
  19 | })
  20 |

  at Object.toBe (integration/babel-next-image/babel-next-image.test.js:17:24)

Read more about building and testing Next.js in contributing.md.

TURBOPACK=1 pnpm test test/integration/amp-export-validation/test/index.test.js (turbopack)

  • AMP Validation on Export > production mode > should have shown errors during build
Expand output

● AMP Validation on Export › production mode › should have shown errors during build

expect(received).toMatch(expected)

Expected pattern: /error.*The mandatory attribute 'height' is missing in tag 'amp-video'\./
Received string:  "  ▲ Next.js 15.0.0-canary.178 (turbo)·
   Checking validity of types ...
   Creating an optimized production build ...
   Building (0/7) ...
   Building (1/7)··
   Building (3/7)··
   Building (5/7)··
 ✓ Building (7/7)
 ✓ Compiled successfully
   Collecting page data ...
   Generating static pages (0/8) ...
   Generating static pages (2/8)··
Failed to build /first after 1 attempts.
 ⚠ Linting is disabled.·
Error occurred prerendering page \"/first\". Read more: https://nextjs.org/docs/messages/prerender-error·
AssertionError: Assertion failed: WebAssembly is uninitialized

  at new module$contents$goog$asserts_AssertionError (../evalmachine.<anonymous>:102:1441)
  at module$contents$goog$asserts_doAssertFailure (../evalmachine.<anonymous>:103:354)
  at goog.asserts.assertExists (../evalmachine.<anonymous>:104:374)
  at Object.module$contents$amp$validator_validateString [as validateString] (../evalmachine.<anonymous>:2238:108)
  at Validator.validateString (../packages/next/dist/compiled/amphtml-validator/index.js:17:2057)
  at validateAmp (../packages/next/dist/export/routes/pages.js:92:34)
  at async exportPagesPage (../packages/next/dist/export/routes/pages.js:109:13)
  at async exportPageImpl (../packages/next/dist/export/worker.js:203:16)
  at async Span.traceAsyncFn (../packages/next/dist/trace/trace.js:157:20)·
  > Build error occurred
  Error: Export encountered an error on /first, exiting the build.
  at exportPageWithRetry (../packages/next/dist/export/worker.js:293:31)
      at async Promise.all (index 5)
  at ../async /root/actions-runner/_work/next.js/next.js/packages/next/dist/export/worker.js:323:35
  at async Object.exportPages (../packages/next/dist/export/worker.js:318:5) {
    type: 'ExportPageError',
    code: 'NEXT_EXPORT_PAGE_ERROR'
  }
  "
  at Object.toMatch (integration/amp-export-validation/test/index.test.js:28:29)

Read more about building and testing Next.js in contributing.md.

__NEXT_EXPERIMENTAL_PPR=true pnpm test-dev test/development/app-dir/dynamic-error-trace/index.test.ts (PPR)

  • app dir - dynamic error trace > should show the error trace
Expand output

● app dir - dynamic error trace › should show the error trace

expect(received).toEqual(expected) // deep equality

- Expected  - 0
+ Received  + 2

  Array [
    "",
    "",
+   "",
+   "",
  ]

  46 |       stackFrameElements.map((f) => f.innerText())
  47 |     )
> 48 |     expect(stackFrames).toEqual(isReactExperimental ? ['', ''] : [])
     |                         ^
  49 |
  50 |     const codeframe = await getRedboxSource(browser)
  51 |     // TODO(NDX-115): column for "^"" marker is inconsistent between native, Webpack, and Turbopack

  at Object.toEqual (development/app-dir/dynamic-error-trace/index.test.ts:48:25)

Read more about building and testing Next.js in contributing.md.

__NEXT_EXPERIMENTAL_PPR=true pnpm test-dev test/development/app-dir/dynamic-io-warnings/dynamic-io.warnings.test.ts (PPR)

  • dynamic-requests warnings > warnings on sync cookie access
  • dynamic-requests warnings > warnings on sync draftMode access
  • dynamic-requests warnings > warnings on sync headers access
  • dynamic-requests warnings > warnings on sync params access
  • dynamic-requests warnings > warnings on sync searchParams access
Expand output

● dynamic-requests warnings › warnings on sync cookie access

expect(received).toEqual(expected) // deep equality

- Expected  -  8
+ Received  + 16

  Object {
    "browserConsoleErrors": Array [
-     StringContaining "In route /pages/cookies a cookie property was accessed directly with `cookies().get('page')`.",
-     StringContaining "In route /pages/cookies a cookie property was accessed directly with `cookies().get('component')`.",
-     StringContaining "In route /pages/cookies a cookie property was accessed directly with `cookies().has('component')`.",
-     StringContaining "In route /pages/cookies cookies were iterated over",
+     "%c%s%c  In route /pages/cookies a searchParam property was accessed directly with `searchParams.toJSON`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/cookies a searchParam property was accessed directly with `searchParams.$$typeof`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/cookies a searchParam property was accessed directly with `searchParams.$$typeof`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/cookies a searchParam property was accessed directly with `searchParams.status`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/cookies a cookie property was accessed directly with `cookies().get('page')`. `cookies()` should be awaited before using its value. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/cookies a cookie property was accessed directly with `cookies().get('component')`. `cookies()` should be awaited before using its value. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/cookies a cookie property was accessed directly with `cookies().has('component')`. `cookies()` should be awaited before using its value. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/cookies cookies were iterated over. `cookies()` should be awaited before using its value. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
    ],
    "terminalCookieErrors": Array [
-     StringContaining "In route /pages/cookies a cookie property was accessed directly with `cookies().get('page')`.",
-     StringContaining "In route /pages/cookies a cookie property was accessed directly with `cookies().get('component')`.",
-     StringContaining "In route /pages/cookies a cookie property was accessed directly with `cookies().has('component')`.",
-     StringContaining "In route /pages/cookies cookies were iterated over",
+     " In route /pages/cookies a searchParam property was accessed directly with `searchParams.toJSON`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
+     " In route /pages/cookies a searchParam property was accessed directly with `searchParams.$$typeof`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
+     " In route /pages/cookies a searchParam property was accessed directly with `searchParams.$$typeof`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
+     " In route /pages/cookies a searchParam property was accessed directly with `searchParams.status`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
+     " In route /pages/cookies a cookie property was accessed directly with `cookies().get('page')`. `cookies()` should be awaited before using its value. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
+     " In route /pages/cookies a cookie property was accessed directly with `cookies().get('component')`. `cookies()` should be awaited before using its value. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
+     " In route /pages/cookies a cookie property was accessed directly with `cookies().has('component')`. `cookies()` should be awaited before using its value. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
+     " In route /pages/cookies cookies were iterated over. `cookies()` should be awaited before using its value. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
    ],
  }

  19 |       return line.includes('In route /pages/cookies')
  20 |     })
> 21 |     expect({ browserConsoleErrors, terminalCookieErrors }).toEqual({
     |                                                            ^
  22 |       browserConsoleErrors: [
  23 |         expect.stringContaining(
  24 |           "In route /pages/cookies a cookie property was accessed directly with `cookies().get('page')`."

  at Object.toEqual (development/app-dir/dynamic-io-warnings/dynamic-io.warnings.test.ts:21:60)

● dynamic-requests warnings › warnings on sync draftMode access

expect(received).toEqual(expected) // deep equality

- Expected  -  8
+ Received  + 16

  Object {
    "browserConsoleErrors": Array [
-     StringContaining "In route /pages/draftMode a `draftMode()` property was accessed directly with `draftMode().isEnabled`.",
-     StringContaining "In route /pages/draftMode a `draftMode()` property was accessed directly with `draftMode().isEnabled`.",
-     StringContaining "In route /pages/draftMode a `draftMode()` property was accessed directly with `draftMode().enable()`.",
-     StringContaining "In route /pages/draftMode a `draftMode()` property was accessed directly with `draftMode().isEnabled`.",
+     "%c%s%c  In route /pages/draftMode a searchParam property was accessed directly with `searchParams.toJSON`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/draftMode a searchParam property was accessed directly with `searchParams.$$typeof`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/draftMode a searchParam property was accessed directly with `searchParams.$$typeof`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/draftMode a searchParam property was accessed directly with `searchParams.status`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/draftMode a `draftMode()` property was accessed directly with `draftMode().isEnabled`. `draftMode()` should be awaited before using its value. Learn more: https://nextjs.org/docs/messages/draft-mode-sync-access background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/draftMode a `draftMode()` property was accessed directly with `draftMode().isEnabled`. `draftMode()` should be awaited before using its value. Learn more: https://nextjs.org/docs/messages/draft-mode-sync-access background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/draftMode a `draftMode()` property was accessed directly with `draftMode().enable()`. `draftMode()` should be awaited before using its value. Learn more: https://nextjs.org/docs/messages/draft-mode-sync-access background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/draftMode a `draftMode()` property was accessed directly with `draftMode().isEnabled`. `draftMode()` should be awaited before using its value. Learn more: https://nextjs.org/docs/messages/draft-mode-sync-access background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
    ],
    "terminalCookieErrors": Array [
-     StringContaining "In route /pages/draftMode a `draftMode()` property was accessed directly with `draftMode().isEnabled`.",
-     StringContaining "In route /pages/draftMode a `draftMode()` property was accessed directly with `draftMode().isEnabled`.",
-     StringContaining "In route /pages/draftMode a `draftMode()` property was accessed directly with `draftMode().enable()`.",
-     StringContaining "In route /pages/draftMode a `draftMode()` property was accessed directly with `draftMode().isEnabled`.",
+     " In route /pages/draftMode a searchParam property was accessed directly with `searchParams.toJSON`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
+     " In route /pages/draftMode a searchParam property was accessed directly with `searchParams.$$typeof`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
+     " In route /pages/draftMode a searchParam property was accessed directly with `searchParams.$$typeof`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
+     " In route /pages/draftMode a searchParam property was accessed directly with `searchParams.status`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
+     " In route /pages/draftMode a `draftMode()` property was accessed directly with `draftMode().isEnabled`. `draftMode()` should be awaited before using its value. Learn more: https://nextjs.org/docs/messages/draft-mode-sync-access",
+     " In route /pages/draftMode a `draftMode()` property was accessed directly with `draftMode().isEnabled`. `draftMode()` should be awaited before using its value. Learn more: https://nextjs.org/docs/messages/draft-mode-sync-access",
+     " In route /pages/draftMode a `draftMode()` property was accessed directly with `draftMode().enable()`. `draftMode()` should be awaited before using its value. Learn more: https://nextjs.org/docs/messages/draft-mode-sync-access",
+     " In route /pages/draftMode a `draftMode()` property was accessed directly with `draftMode().isEnabled`. `draftMode()` should be awaited before using its value. Learn more: https://nextjs.org/docs/messages/draft-mode-sync-access",
    ],
  }

  64 |       return line.includes('In route /pages/draftMode')
  65 |     })
> 66 |     expect({ browserConsoleErrors, terminalCookieErrors }).toEqual({
     |                                                            ^
  67 |       browserConsoleErrors: [
  68 |         expect.stringContaining(
  69 |           'In route /pages/draftMode a `draftMode()` property was accessed directly with `draftMode().isEnabled`.'

  at Object.toEqual (development/app-dir/dynamic-io-warnings/dynamic-io.warnings.test.ts:66:60)

● dynamic-requests warnings › warnings on sync headers access

expect(received).toEqual(expected) // deep equality

- Expected  -  8
+ Received  + 16

  Object {
    "browserConsoleErrors": Array [
-     StringContaining "In route /pages/headers a header property was accessed directly with `headers().get('page')`.",
-     StringContaining "In route /pages/headers a header property was accessed directly with `headers().get('component')`.",
-     StringContaining "In route /pages/headers a header property was accessed directly with `headers().has('component')`.",
-     StringContaining "In route /pages/headers headers were iterated over",
+     "%c%s%c  In route /pages/headers a searchParam property was accessed directly with `searchParams.toJSON`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/headers a searchParam property was accessed directly with `searchParams.$$typeof`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/headers a searchParam property was accessed directly with `searchParams.$$typeof`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/headers a searchParam property was accessed directly with `searchParams.status`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/headers a header property was accessed directly with `headers().get('page')`. `headers()` should be awaited before using its value. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/headers a header property was accessed directly with `headers().get('component')`. `headers()` should be awaited before using its value. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/headers a header property was accessed directly with `headers().has('component')`. `headers()` should be awaited before using its value. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/headers headers were iterated over. `headers()` should be awaited before using its value. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
    ],
    "terminalCookieErrors": Array [
-     StringContaining "In route /pages/headers a header property was accessed directly with `headers().get('page')`.",
-     StringContaining "In route /pages/headers a header property was accessed directly with `headers().get('component')`.",
-     StringContaining "In route /pages/headers a header property was accessed directly with `headers().has('component')`.",
-     StringContaining "In route /pages/headers headers were iterated over",
+     " In route /pages/headers a searchParam property was accessed directly with `searchParams.toJSON`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
+     " In route /pages/headers a searchParam property was accessed directly with `searchParams.$$typeof`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
+     " In route /pages/headers a searchParam property was accessed directly with `searchParams.$$typeof`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
+     " In route /pages/headers a searchParam property was accessed directly with `searchParams.status`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
+     " In route /pages/headers a header property was accessed directly with `headers().get('page')`. `headers()` should be awaited before using its value. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
+     " In route /pages/headers a header property was accessed directly with `headers().get('component')`. `headers()` should be awaited before using its value. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
+     " In route /pages/headers a header property was accessed directly with `headers().has('component')`. `headers()` should be awaited before using its value. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
+     " In route /pages/headers headers were iterated over. `headers()` should be awaited before using its value. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
    ],
  }

  109 |       return line.includes('In route /pages/headers')
  110 |     })
> 111 |     expect({ browserConsoleErrors, terminalCookieErrors }).toEqual({
      |                                                            ^
  112 |       browserConsoleErrors: [
  113 |         expect.stringContaining(
  114 |           "In route /pages/headers a header property was accessed directly with `headers().get('page')`."

  at Object.toEqual (development/app-dir/dynamic-io-warnings/dynamic-io.warnings.test.ts:111:60)

● dynamic-requests warnings › warnings on sync params access

expect(received).toEqual(expected) // deep equality

- Expected  -  8
+ Received  + 16

  Object {
    "browserConsoleErrors": Array [
-     StringContaining "In route /pages/params/[slug] a param property was accessed directly with `params.slug`.",
-     StringContaining "In route /pages/params/[slug] a param property was accessed directly with `params.slug`.",
-     StringContaining "In route /pages/params/[slug] a param property was accessed directly with `params.slug`.",
-     StringContaining "In route /pages/params/[slug] params are being enumerated",
+     "%c%s%c  In route /pages/params/[slug] a searchParam property was accessed directly with `searchParams.toJSON`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/params/[slug] a searchParam property was accessed directly with `searchParams.$$typeof`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/params/[slug] a searchParam property was accessed directly with `searchParams.$$typeof`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/params/[slug] a searchParam property was accessed directly with `searchParams.status`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/params/[slug] a param property was accessed directly with `params.slug`. `params` should be awaited before accessing its properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/params/[slug] a param property was accessed directly with `params.slug`. `params` should be awaited before accessing its properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/params/[slug] a param property was accessed directly with `params.slug`. `params` should be awaited before accessing its properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/params/[slug] params are being enumerated. `params` should be awaited before accessing its properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
    ],
    "terminalCookieErrors": Array [
-     StringContaining "In route /pages/params/[slug] a param property was accessed directly with `params.slug`.",
-     StringContaining "In route /pages/params/[slug] a param property was accessed directly with `params.slug`.",
-     StringContaining "In route /pages/params/[slug] a param property was accessed directly with `params.slug`.",
-     StringContaining "In route /pages/params/[slug] params are being enumerated",
+     " In route /pages/params/[slug] a searchParam property was accessed directly with `searchParams.toJSON`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
+     " In route /pages/params/[slug] a searchParam property was accessed directly with `searchParams.$$typeof`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
+     " In route /pages/params/[slug] a searchParam property was accessed directly with `searchParams.$$typeof`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
+     " In route /pages/params/[slug] a searchParam property was accessed directly with `searchParams.status`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
+     " In route /pages/params/[slug] a param property was accessed directly with `params.slug`. `params` should be awaited before accessing its properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
+     " In route /pages/params/[slug] a param property was accessed directly with `params.slug`. `params` should be awaited before accessing its properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
+     " In route /pages/params/[slug] a param property was accessed directly with `params.slug`. `params` should be awaited before accessing its properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
+     " In route /pages/params/[slug] params are being enumerated. `params` should be awaited before accessing its properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
    ],
  }

  154 |       return line.includes('In route /pages/params/[slug]')
  155 |     })
> 156 |     expect({ browserConsoleErrors, terminalCookieErrors }).toEqual({
      |                                                            ^
  157 |       browserConsoleErrors: [
  158 |         expect.stringContaining(
  159 |           'In route /pages/params/[slug] a param property was accessed directly with `params.slug`.'

  at Object.toEqual (development/app-dir/dynamic-io-warnings/dynamic-io.warnings.test.ts:156:60)

● dynamic-requests warnings › warnings on sync searchParams access

expect(received).toEqual(expected) // deep equality

- Expected  -  8
+ Received  + 16

  Object {
    "browserConsoleErrors": Array [
-     StringContaining "In route /pages/searchParams a searchParam property was accessed directly with `searchParams.slug`.",
-     StringContaining "In route /pages/searchParams a searchParam property was accessed directly with `searchParams.slug`.",
-     StringContaining "In route /pages/searchParams a searchParam property was accessed directly with `searchParams.slug`.",
-     StringContaining "In route /pages/searchParams searchParams are being enumerated",
+     "%c%s%c  In route /pages/searchParams a searchParam property was accessed directly with `searchParams.toJSON`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/searchParams a searchParam property was accessed directly with `searchParams.$$typeof`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/searchParams a searchParam property was accessed directly with `searchParams.$$typeof`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/searchParams a searchParam property was accessed directly with `searchParams.status`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/searchParams a searchParam property was accessed directly with `searchParams.slug`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/searchParams a searchParam property was accessed directly with `searchParams.slug`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/searchParams a searchParam property was accessed directly with `searchParams.slug`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
+     "%c%s%c  In route /pages/searchParams searchParams are being enumerated. `searchParams` should be awaited before accessing its properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis background: #e6e6e6;background: light-dark(rgba(0,0,0,0.1), rgba(255,255,255,0.25));color: #000000;color: light-dark(#000000, #ffffff);border-radius: 2px  Server  ",
    ],
    "terminalCookieErrors": Array [
-     StringContaining "In route /pages/searchParams a searchParam property was accessed directly with `searchParams.slug`.",
-     StringContaining "In route /pages/searchParams a searchParam property was accessed directly with `searchParams.slug`.",
-     StringContaining "In route /pages/searchParams a searchParam property was accessed directly with `searchParams.slug`.",
-     StringContaining "In route /pages/searchParams searchParams are being enumerated",
+     " In route /pages/searchParams a searchParam property was accessed directly with `searchParams.toJSON`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
+     " In route /pages/searchParams a searchParam property was accessed directly with `searchParams.$$typeof`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
+     " In route /pages/searchParams a searchParam property was accessed directly with `searchParams.$$typeof`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
+     " In route /pages/searchParams a searchParam property was accessed directly with `searchParams.status`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
+     " In route /pages/searchParams a searchParam property was accessed directly with `searchParams.slug`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
+     " In route /pages/searchParams a searchParam property was accessed directly with `searchParams.slug`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
+     " In route /pages/searchParams a searchParam property was accessed directly with `searchParams.slug`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
+     " In route /pages/searchParams searchParams are being enumerated. `searchParams` should be awaited before accessing its properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis",
    ],
  }

  199 |       return line.includes('In route /pages/searchParams')
  200 |     })
> 201 |     expect({ browserConsoleErrors, terminalCookieErrors }).toEqual({
      |                                                            ^
  202 |       browserConsoleErrors: [
  203 |         expect.stringContaining(
  204 |           'In route /pages/searchParams a searchParam property was accessed directly with `searchParams.slug`.'

  at Object.toEqual (development/app-dir/dynamic-io-warnings/dynamic-io.warnings.test.ts:201:60)

Read more about building and testing Next.js in contributing.md.

pnpm test-dev test/development/basic/barrel-optimization/barrel-optimization.test.ts

  • Skipped in Turbopack > optimizePackageImports - basic > app - should render the icons correctly without creating all the modules
  • Skipped in Turbopack > optimizePackageImports - basic > should handle recursive wildcard exports
  • Skipped in Turbopack > optimizePackageImports - basic > should not break "use client" directive in optimized packages
  • Skipped in Turbopack > optimizePackageImports - basic > should support "use client" directive in barrel file
Expand output

● Skipped in Turbopack › optimizePackageImports - basic › app - should render the icons correctly without creating all the modules

expect(received).toContain(expected) // indexOf

Expected substring: "<svg xmlns=\"http://www.w3.org/2000/svg\""
Received string:    "<!DOCTYPE html><html id=\"__next_error__\"><head><meta charSet=\"utf-8\"/><meta name=\"viewport\" content=\"width=device-width, initial-scale=1\"/><link rel=\"preload\" as=\"script\" fetchPriority=\"low\" href=\"/_next/static/chunks/webpack.js\"/><script src=\"/_next/static/chunks/main-app.js\" async=\"\"></script><script src=\"/_next/static/chunks/app-pages-internals.js\" async=\"\"></script><meta name=\"robots\" content=\"noindex\"/><meta name=\"next-error\" content=\"not-found\"/><title>Next.js</title><meta name=\"description\" content=\"Generated by Next.js\"/><script src=\"/_next/static/chunks/polyfills.js\" noModule=\"\"></script></head><body><script src=\"/_next/static/chunks/webpack.js\" async=\"\"></script><script>(self.__next_f=self.__next_f||[]).push([0])</script><script>self.__next_f.push([1,\"3:\\\"$Sreact.fragment\\\"\\n5:\\\"$Sreact.transitional.element\\\"\\n6:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/client/components/layout-router.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-internals.js\\\"],\\\"\\\"]\\n7:\\\"$Sreact.transitional.element\\\"\\n8:\\\"$Sreact.transitional.element\\\"\\n9:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/client/components/render-from-template-context.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-internals.js\\\"],\\\"\\\"]\\na:\\\"$Sreact.transitional.element\\\"\\n1a:I[\\\"(app-pages-browser)/./components/slow-component.js\\\",[\\\"app/page\\\",\\\"static/chunks/app/page.js\\\"],\\\"Comp\\\",1]\\n1b:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/lib/metadata/metadata-boundary.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-internals.js\\\"],\\\"OutletBoundary\\\"]\\n1f:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/client/components/error-boundary.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-internals.js\\\"],\\\"\\\"]\\n20:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/client/components/client-page.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-internals.js\\\"],\\\"ClientPageRoot\\\"]\\n21:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/client/components/client-segment.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-i\"])</script><script>self.__next_f.push([1,\"nternals.js\\\"],\\\"ClientSegmentRoot\\\"]\\n22:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/lib/metadata/metadata-boundary.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-internals.js\\\"],\\\"MetadataBoundary\\\"]\\n23:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/client/components/not-found-boundary.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-internals.js\\\"],\\\"NotFoundBoundary\\\"]\\n24:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/lib/metadata/metadata-boundary.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-internals.js\\\"],\\\"ViewportBoundary\\\"]\\n2:{\\\"name\\\":\\\"Preloads\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":null,\\\"owner\\\":null,\\\"props\\\":{\\\"preloadCallbacks\\\":[]}}\\n1:D\\\"$2\\\"\\n1:null\\n\"])</script><script>self.__next_f.push([1,\"b:{\\\"name\\\":\\\"RootLayout\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":null,\\\"owner\\\":null,\\\"props\\\":{\\\"children\\\":[\\\"$5\\\",\\\"$L6\\\",null,{\\\"parallelRouterKey\\\":\\\"children\\\",\\\"segmentPath\\\":[\\\"children\\\"],\\\"error\\\":\\\"$undefined\\\",\\\"errorStyles\\\":\\\"$undefined\\\",\\\"errorScripts\\\":\\\"$undefined\\\",\\\"template\\\":[\\\"$7\\\",\\\"$3\\\",null,{\\\"children\\\":[\\\"$8\\\",\\\"$L9\\\",null,{},null]},null],\\\"templateStyles\\\":\\\"$undefined\\\",\\\"templateScripts\\\":\\\"$undefined\\\",\\\"notFound\\\":[\\\"$a\\\",\\\"$E(function NotFound() {\\\\n    return /*#__PURE__*/ (0, _jsxruntime.jsxs)(_jsxruntime.Fragment, {\\\\n        children: [\\\\n            /*#__PURE__*/ (0, _jsxruntime.jsx)(\\\\\\\"title\\\\\\\", {\\\\n                children: \\\\\\\"404: This page could not be found.\\\\\\\"\\\\n            }),\\\\n            /*#__PURE__*/ (0, _jsxruntime.jsx)(\\\\\\\"div\\\\\\\", {\\\\n                style: styles.error,\\\\n                children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(\\\\\\\"div\\\\\\\", {\\\\n                    children: [\\\\n                        /*#__PURE__*/ (0, _jsxruntime.jsx)(\\\\\\\"style\\\\\\\", {\\\\n                            dangerouslySetInnerHTML: {\\\\n                                /* Minified CSS from\\\\n                body { margin: 0; color: #000; background: #fff; }\\\\n                .next-error-h1 {\\\\n                  border-right: 1px solid rgba(0, 0, 0, .3);\\\\n                }\\\\n\\\\n                @media (prefers-color-scheme: dark) {\\\\n                  body { color: #fff; background: #000; }\\\\n                  .next-error-h1 {\\\\n                    border-right: 1px solid rgba(255, 255, 255, .3);\\\\n                  }\\\\n                }\\\\n              */ __html: \\\\\\\"body{color:#000;background:#fff;margin:0}.next-error-h1{border-right:1px solid rgba(0,0,0,.3)}@media (prefers-color-scheme:dark){body{color:#fff;background:#000}.next-error-h1{border-right:1px solid rgba(255,255,255,.3)}}\\\\\\\"\\\\n                            }\\\\n                        }),\\\\n                        /*#__PURE__*/ (0, _jsxruntime.jsx)(\\\\\\\"h1\\\\\\\", {\\\\n                            className: \\\\\\\"next-error-h1\\\\\\\",\\\\n                            style: styles.h1,\\\\n                            children: \\\\\\\"404\\\\\\\"\\\\n                        }),\\\\n                        /*#__PURE__*/ (0, _jsxruntime.jsx)(\\\\\\\"div\\\\\\\", {\\\\n                            style: styles.desc,\\\\n                            children: /*#__PURE__*/ (0, _jsxruntime.jsx)(\\\\\\\"h2\\\\\\\", {\\\\n                                style: styles.h2,\\\\n                                children: \\\\\\\"This page could not be found.\\\\\\\"\\\\n                            })\\\\n                        })\\\\n                    ]\\\\n                })\\\\n            })\\\\n        ]\\\\n    });\\\\n})\\\",null,\\\"$Y\\\",null],\\\"notFoundStyles\\\":\\\"$Y\\\"},null],\\\"params\\\":\\\"$Y\\\"}}\\n\"])</script><script>self.__next_f.push([1,\"4:D\\\"$b\\\"\\nd:{\\\"name\\\":\\\"NotFound\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":null,\\\"owner\\\":null,\\\"props\\\":{}}\\nc:D\\\"$d\\\"\\nc:[[\\\"$\\\",\\\"title\\\",null,{\\\"children\\\":\\\"404: This page could not be found.\\\"},\\\"$d\\\"],[\\\"$\\\",\\\"div\\\",null,{\\\"style\\\":{\\\"fontFamily\\\":\\\"system-ui,\\\\\\\"Segoe UI\\\\\\\",Roboto,Helvetica,Arial,sans-serif,\\\\\\\"Apple Color Emoji\\\\\\\",\\\\\\\"Segoe UI Emoji\\\\\\\"\\\",\\\"height\\\":\\\"100vh\\\",\\\"textAlign\\\":\\\"center\\\",\\\"display\\\":\\\"flex\\\",\\\"flexDirection\\\":\\\"column\\\",\\\"alignItems\\\":\\\"center\\\",\\\"justifyContent\\\":\\\"center\\\"},\\\"children\\\":[\\\"$\\\",\\\"div\\\",null,{\\\"children\\\":[[\\\"$\\\",\\\"style\\\",null,{\\\"dangerouslySetInnerHTML\\\":{\\\"__html\\\":\\\"body{color:#000;background:#fff;margin:0}.next-error-h1{border-right:1px solid rgba(0,0,0,.3)}@media (prefers-color-scheme:dark){body{color:#fff;background:#000}.next-error-h1{border-right:1px solid rgba(255,255,255,.3)}}\\\"}},\\\"$d\\\"],[\\\"$\\\",\\\"h1\\\",null,{\\\"className\\\":\\\"next-error-h1\\\",\\\"style\\\":{\\\"display\\\":\\\"inline-block\\\",\\\"margin\\\":\\\"0 20px 0 0\\\",\\\"padding\\\":\\\"0 23px 0 0\\\",\\\"fontSize\\\":24,\\\"fontWeight\\\":500,\\\"verticalAlign\\\":\\\"top\\\",\\\"lineHeight\\\":\\\"49px\\\"},\\\"children\\\":\\\"404\\\"},\\\"$d\\\"],[\\\"$\\\",\\\"div\\\",null,{\\\"style\\\":{\\\"display\\\":\\\"inline-block\\\"},\\\"children\\\":[\\\"$\\\",\\\"h2\\\",null,{\\\"style\\\":{\\\"fontSize\\\":14,\\\"fontWeight\\\":400,\\\"lineHeight\\\":\\\"49px\\\",\\\"margin\\\":0},\\\"children\\\":\\\"This page could not be found.\\\"},\\\"$d\\\"]},\\\"$d\\\"]]},\\\"$d\\\"]},\\\"$d\\\"]]\\n4:[\\\"$\\\",\\\"html\\\",null,{\\\"lang\\\":\\\"en\\\",\\\"children\\\":[\\\"$\\\",\\\"body\\\",null,{\\\"children\\\":[\\\"$\\\",\\\"$L6\\\",null,{\\\"parallelRouterKey\\\":\\\"children\\\",\\\"segmentPath\\\":[\\\"children\\\"],\\\"error\\\":\\\"$undefined\\\",\\\"errorStyles\\\":\\\"$undefined\\\",\\\"errorScripts\\\":\\\"$undefined\\\",\\\"template\\\":[\\\"$\\\",\\\"$L9\\\",null,{},null],\\\"templateStyles\\\":\\\"$undefined\\\",\\\"templateScripts\\\":\\\"$undefined\\\",\\\"notFound\\\":\\\"$c\\\",\\\"notFoundStyles\\\":[]},null]},\\\"$b\\\"]},\\\"$b\\\"]\\nf:W[\\\"error\\\",[],null,\\\"Server\\\",\\\" In route / a searchParam property was accessed directly with `searchParams.toJSON`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis\\\"]\\n10:W[\\\"error\\\",[],null,\\\"Server\\\",\\\" In route / a searchParam property was accessed directly with `searchParams.$$typeof`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages\"])</script><script>self.__next_f.push([1,\"/sync-dynamic-apis\\\"]\\n11:W[\\\"error\\\",[],null,\\\"Server\\\",\\\" In route / a searchParam property was accessed directly with `searchParams.$$typeof`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis\\\"]\\n12:W[\\\"error\\\",[],null,\\\"Server\\\",\\\" In route / a searchParam property was accessed directly with `searchParams.status`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis\\\"]\\n13:{\\\"name\\\":\\\"Page\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":null,\\\"owner\\\":null,\\\"props\\\":{\\\"params\\\":\\\"$@\\\",\\\"searchParams\\\":\\\"$@\\\"}}\\ne:D\\\"$13\\\"\\n15:{\\\"name\\\":\\\"AcademicCapIcon\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":null,\\\"owner\\\":\\\"$13\\\",\\\"props\\\":{}}\\n14:D\\\"$15\\\"\\n14:[\\\"$\\\",\\\"svg\\\",null,{\\\"xmlns\\\":\\\"http://www.w3.org/2000/svg\\\",\\\"viewBox\\\":\\\"0 0 20 20\\\",\\\"fill\\\":\\\"currentColor\\\",\\\"aria-hidden\\\":\\\"true\\\",\\\"ref\\\":\\\"$undefined\\\",\\\"aria-labelledby\\\":\\\"$undefined\\\",\\\"children\\\":[null,[\\\"$\\\",\\\"path\\\",null,{\\\"fillRule\\\":\\\"evenodd\\\",\\\"d\\\":\\\"M9.664 1.319a.75.75 0 01.672 0 41.059 41.059 0 018.198 5.424.75.75 0 01-.254 1.285 31.372 31.372 0 00-7.86 3.83.75.75 0 01-.84 0 31.508 31.508 0 00-2.08-1.287V9.394c0-.244.116-.463.302-.592a35.504 35.504 0 013.305-2.033.75.75 0 00-.714-1.319 37 37 0 00-3.446 2.12A2.216 2.216 0 006 9.393v.38a31.293 31.293 0 00-4.28-1.746.75.75 0 01-.254-1.285 41.059 41.059 0 018.198-5.424zM6 11.459a29.848 29.848 0 00-2.455-1.158 41.029 41.029 0 00-.39 3.114.75.75 0 00.419.74c.528.256 1.046.53 1.554.82-.21.324-.455.63-.739.914a.75.75 0 101.06 1.06c.37-.369.69-.77.96-1.193a26.61 26.61 0 013.095 2.348.75.75 0 00.992 0 26.547 26.547 0 015.93-3.95.75.75 0 00.42-.739 41.053 41.053 0 00-.39-3.114 29.925 29.925 0 00-5.199 2.801 2.25 2.25 0 01-2.514 0c-.41-.275-.826-.541-1.25-.797a6.985 6.985 0 01-1.084 3.45 26.503 26.503 0 00-1.281-.78A5.487 5.487 0 006 12v-.54z\\\",\\\"clipRule\\\":\\\"evenodd\\\"},\\\"$15\\\"]]},\\\"$15\\\"]\\n17:{\\\"name\\\":\\\"AcademicCapIcon\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":null,\\\"owner\\\":\\\"$13\\\",\\\"props\\\":{}}\\n16:D\\\"$17\\\"\\n16:[\\\"$\\\",\\\"svg\\\",null,{\\\"xmlns\\\":\\\"http://www.w3.org/2000/svg\\\",\\\"fill\\\":\\\"none\\\",\\\"viewBox\\\":\\\"0 0 24 24\\\",\\\"strokeWidth\\\":1.5,\\\"stroke\\\":\\\"curr\"])</script><script>self.__next_f.push([1,\"entColor\\\",\\\"aria-hidden\\\":\\\"true\\\",\\\"ref\\\":\\\"$undefined\\\",\\\"aria-labelledby\\\":\\\"$undefined\\\",\\\"children\\\":[null,[\\\"$\\\",\\\"path\\\",null,{\\\"strokeLinecap\\\":\\\"round\\\",\\\"strokeLinejoin\\\":\\\"round\\\",\\\"d\\\":\\\"M4.26 10.147a60.436 60.436 0 00-.491 6.347A48.627 48.627 0 0112 20.904a48.627 48.627 0 018.232-4.41 60.46 60.46 0 00-.491-6.347m-15.482 0a50.57 50.57 0 00-2.658-.813A59.905 59.905 0 0112 3.493a59.902 59.902 0 0110.399 5.84c-.896.248-1.783.52-2.658.814m-15.482 0A50.697 50.697 0 0112 13.489a50.702 50.702 0 017.74-3.342M6.75 15a.75.75 0 100-1.5.75.75 0 000 1.5zm0 0v-3.675A55.378 55.378 0 0112 8.443m-7.007 11.55A5.981 5.981 0 006.75 15.75v-1.5\\\"},\\\"$17\\\"]]},\\\"$17\\\"]\\n19:{\\\"name\\\":\\\"AcademicCapIcon\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":null,\\\"owner\\\":\\\"$13\\\",\\\"props\\\":{}}\\n18:D\\\"$19\\\"\\n18:[\\\"$\\\",\\\"svg\\\",null,{\\\"xmlns\\\":\\\"http://www.w3.org/2000/svg\\\",\\\"viewBox\\\":\\\"0 0 24 24\\\",\\\"fill\\\":\\\"currentColor\\\",\\\"aria-hidden\\\":\\\"true\\\",\\\"ref\\\":\\\"$undefined\\\",\\\"aria-labelledby\\\":\\\"$undefined\\\",\\\"children\\\":[null,[\\\"$\\\",\\\"path\\\",null,{\\\"d\\\":\\\"M11.7 2.805a.75.75 0 01.6 0A60.65 60.65 0 0122.83 8.72a.75.75 0 01-.231 1.337 49.949 49.949 0 00-9.902 3.912l-.003.002-.34.18a.75.75 0 01-.707 0A50.009 50.009 0 007.5 12.174v-.224c0-.131.067-.248.172-.311a54.614 54.614 0 014.653-2.52.75.75 0 00-.65-1.352 56.129 56.129 0 00-4.78 2.589 1.858 1.858 0 00-.859 1.228 49.803 49.803 0 00-4.634-1.527.75.75 0 01-.231-1.337A60.653 60.653 0 0111.7 2.805z\\\"},\\\"$19\\\"],[\\\"$\\\",\\\"path\\\",null,{\\\"d\\\":\\\"M13.06 15.473a48.45 48.45 0 017.666-3.282c.134 1.414.22 2.843.255 4.285a.75.75 0 01-.46.71 47.878 47.878 0 00-8.105 4.342.75.75 0 01-.832 0 47.877 47.877 0 00-8.104-4.342.75.75 0 01-.461-.71c.035-1.442.121-2.87.255-4.286A48.4 48.4 0 016 13.18v1.27a1.5 1.5 0 00-.14 2.508c-.09.38-.222.753-.397 1.11.452.213.901.434 1.346.661a6.729 6.729 0 00.551-1.608 1.5 1.5 0 00.14-2.67v-.645a48.549 48.549 0 013.44 1.668 2.25 2.25 0 002.12 0z\\\"},\\\"$19\\\"],[\\\"$\\\",\\\"path\\\",null,{\\\"d\\\":\\\"M4.462 19.462c.42-.419.753-.89 1-1.394.453.213.902.434 1.347.661a6.743 6.743 0 01-1.286 1.794.75.75 0 11-1.06-1.06z\\\"},\\\"$19\\\"]]},\\\"$19\\\"]\\ne:[\\\"$14\\\",\\\"$16\\\",\\\"$18\\\",[\\\"$\\\",\\\"$L1a\\\",null,{},\\\"$13\\\"]]\\n1d:{\\\"name\\\":\\\"MetadataOutlet\\\",\\\"env\\\":\\\"Server\"])</script><script>self.__next_f.push([1,\"\\\",\\\"key\\\":null,\\\"owner\\\":null,\\\"props\\\":{\\\"ready\\\":\\\"$E(async function getMetadataAndViewportReady() {\\\\n        await viewport();\\\\n        await metadata();\\\\n        return undefined;\\\\n    })\\\"}}\\n1c:D\\\"$1d\\\"\\n\"])</script><script>self.__next_f.push([1,\"25:{\\\"name\\\":\\\"NonIndex\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":null,\\\"owner\\\":null,\\\"props\\\":{\\\"ctx\\\":{\\\"componentMod\\\":{\\\"GlobalError\\\":\\\"$1f\\\",\\\"__next_app__\\\":{\\\"require\\\":\\\"$E(function __webpack_require__(moduleId) {\\\\n/******/ \\\\t\\\\t// Check if module is in cache\\\\n/******/ \\\\t\\\\tvar cachedModule = __webpack_module_cache__[moduleId];\\\\n/******/ \\\\t\\\\tif (cachedModule !== undefined) {\\\\n/******/ \\\\t\\\\t\\\\treturn cachedModule.exports;\\\\n/******/ \\\\t\\\\t}\\\\n/******/ \\\\t\\\\t// Create a new module (and put it into the cache)\\\\n/******/ \\\\t\\\\tvar module = __webpack_module_cache__[moduleId] = {\\\\n/******/ \\\\t\\\\t\\\\tid: moduleId,\\\\n/******/ \\\\t\\\\t\\\\tloaded: false,\\\\n/******/ \\\\t\\\\t\\\\texports: {}\\\\n/******/ \\\\t\\\\t};\\\\n/******/ \\\\t\\\\n/******/ \\\\t\\\\t// Execute the module function\\\\n/******/ \\\\t\\\\tvar threw = true;\\\\n/******/ \\\\t\\\\ttry {\\\\n/******/ \\\\t\\\\t\\\\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\\\\n/******/ \\\\t\\\\t\\\\tthrew = false;\\\\n/******/ \\\\t\\\\t} finally {\\\\n/******/ \\\\t\\\\t\\\\tif(threw) delete __webpack_module_cache__[moduleId];\\\\n/******/ \\\\t\\\\t}\\\\n/******/ \\\\t\\\\n/******/ \\\\t\\\\t// Flag the module as loaded\\\\n/******/ \\\\t\\\\tmodule.loaded = true;\\\\n/******/ \\\\t\\\\n/******/ \\\\t\\\\t// Return the exports of the module\\\\n/******/ \\\\t\\\\treturn module.exports;\\\\n/******/ \\\\t})\\\",\\\"loadChunk\\\":\\\"$E(() =\\u003e Promise.resolve())\\\"},\\\"pages\\\":[\\\"/tmp/next-install-e82693b0c1e2696ea71e6942fd12c5650a137067076e9c102681d62a5edd6227/app/page.js\\\"],\\\"routeModule\\\":{\\\"userland\\\":{\\\"loaderTree\\\":[\\\"\\\",{\\\"children\\\":\\\"$Y\\\"},\\\"$Y\\\"]},\\\"definition\\\":\\\"$Y\\\"},\\\"tree\\\":\\\"$Y\\\",\\\"ClientPageRoot\\\":\\\"$20\\\",\\\"ClientSegmentRoot\\\":\\\"$21\\\",\\\"LayoutRouter\\\":\\\"$6\\\",\\\"MetadataBoundary\\\":\\\"$22\\\",\\\"NotFoundBoundary\\\":\\\"$23\\\",\\\"OutletBoundary\\\":\\\"$1b\\\",\\\"Postpone\\\":\\\"$E(function Postpone({ reason, route }) {\\\\n    const prerenderStore = _prerenderasyncstorageexternal.prerenderAsyncStorage.getStore();\\\\n    const dynamicTracking = prerenderStore \\u0026\\u0026 prerenderStore.type === 'prerender' ? prerenderStore.dynamicTracking : null;\\\\n    postponeWithTracking(route, reason, dynamicTracking);\\\\n})\\\",\\\"RenderFromTemplateContext\\\":\\\"$9\\\",\\\"ViewportBoundary\\\":\\\"$24\\\",\\\"actionAsyncStorage\\\":\\\"$Y\\\",\\\"createMetadataComponents\\\":\\\"$E(function createMetadataComponents({ tree, searchParams, metadataContext, getDynamicParamFromSegment, appUsingSizeAdjustment, errorType, createServerParamsForMetadata, workStore, MetadataBoundary, ViewportBoundary }) {\\\\n    function MetadataRoot() {\\\\n        return /*#__PURE__*/ (0, _jsxruntime.jsxs)(_jsxruntime.Fragment, {\\\\n            children: [\\\\n                /*#__PURE__*/ (0, _jsxruntime.jsx)(MetadataBoundary, {\\\\n                    children: /*#__PURE__*/ (0, _jsxruntime.jsx)(Metadata, {})\\\\n                }),\\\\n                /*#__PURE__*/ (0, _jsxruntime.jsx)(ViewportBoundary, {\\\\n                    children: /*#__PURE__*/ (0, _jsxruntime.jsx)(Viewport, {})\\\\n                }),\\\\n                appUsingSizeAdjustment ? /*#__PURE__*/ (0, _jsxruntime.jsx)(\\\\\\\"meta\\\\\\\", {\\\\n                    name: \\\\\\\"next-size-adjust\\\\\\\"\\\\n                }) : null\\\\n            ]\\\\n        });\\\\n    }\\\\n    async function viewport() {\\\\n        return getResolvedViewport(tree, searchParams, getDynamicParamFromSegment, createServerParamsForMetadata, workStore, errorType);\\\\n    }\\\\n    async function Viewport() {\\\\n        try {\\\\n            return await viewport();\\\\n        } catch (error) {\\\\n            if (!errorType \\u0026\\u0026 (0, _notfound.isNotFoundError)(error)) {\\\\n                try {\\\\n                    return await getNotFoundViewport(tree, searchParams, getDynamicParamFromSegment, createServerParamsForMetadata, workStore);\\\\n                } catch  {}\\\\n            }\\\\n            // We don't actually want to error in this component. We will\\\\n            // also error in the MetadataOutlet which causes the error to\\\\n            // bubble from the right position in the page to be caught by the\\\\n            // appropriate boundaries\\\\n            return null;\\\\n        }\\\\n    }\\\\n    async function metadata() {\\\\n        return getResolvedMetadata(tree, searchParams, getDynamicParamFromSegment, metadataContext, createServerParamsForMetadata, workStore, errorType);\\\\n    }\\\\n    async function Metadata() {\\\\n        try {\\\\n            return await metadata();\\\\n        } catch (error) {\\\\n            if (!errorType \\u0026\\u0026 (0, _notfound.isNotFoundError)(error)) {\\\\n                try {\\\\n                    return await getNotFoundMetadata(tree, searchParams, getDynamicParamFromSegment, metadataContext, createServerParamsForMetadata, workStore);\\\\n                } catch  {}\\\\n            }\\\\n            // We don't actually want to error in this component. We will\\\\n            // also error in the MetadataOutlet which causes the error to\\\\n            // bubble from the right position in the page to be caught by the\\\\n            // appropriate boundaries\\\\n            return null;\\\\n        }\\\\n    }\\\\n    async function getMetadataAndViewportReady() {\\\\n        await viewport();\\\\n        await metadata();\\\\n        return undefined;\\\\n    }\\\\n    return [\\\\n        MetadataRoot,\\\\n        getMetadataAndViewportReady\\\\n    ];\\\\n})\\\",\\\"createPrerenderParamsForClientSegment\\\":\\\"$E(function createPrerenderParamsForClientSegment(underlyingParams, workStore) {\\\\n    const prerenderStore = _prerenderasyncstorageexternal.prerenderAsyncStorage.getStore();\\\\n    if (prerenderStore \\u0026\\u0026 prerenderStore.type === 'prerender') {\\\\n        if ((0, _prerenderasyncstorageexternal.isDynamicIOPrerender)(prerenderStore)) {\\\\n            const fallbackParams = workStore.fallbackRouteParams;\\\\n            if (fallbackParams) {\\\\n                for(let key in underlyingParams){\\\\n                    if (fallbackParams.has(key)) {\\\\n                        // This params object has one of more fallback params so we need to consider\\\\n                        // the awaiting of this params object \\\\\\\"dynamic\\\\\\\". Since we are in dynamicIO mode\\\\n                        // we encode this as a promise that never resolves\\\\n                        return (0, _dynamicrenderingutils.makeHangingPromise)();\\\\n                    }\\\\n                }\\\\n            }\\\\n        }\\\\n    }\\\\n    // We're prerendering in a mode that does not abort. We resolve the promise without\\\\n    // any tracking because we're just transporting a value from server to client where the tracking\\\\n    // will be applied.\\\\n    return (0, _utils.makeResolvedReactPromise)(underlyingParams);\\\\n})\\\",\\\"createPrerenderSearchParamsForClientPage\\\":\\\"$E(function createPrerenderSearchParamsForClientPage(workStore) {\\\\n    if (workStore.forceStatic) {\\\\n        // When using forceStatic we override all other logic and always just return an empty\\\\n        // dictionary object.\\\\n        return Promise.resolve({});\\\\n    }\\\\n    const prerenderStore = _prerenderasyncstorageexternal.prerenderAsyncStorage.getStore();\\\\n    if (prerenderStore) {\\\\n        if ((0, _prerenderasyncstorageexternal.isDynamicIOPrerender)(prerenderStore)) {\\\\n            // We're prerendering in a mode that aborts (dynamicIO) and should stall\\\\n            // the promise to ensure the RSC side is considered dynamic\\\\n            return (0, _dynamicrenderingutils.makeHangingPromise)();\\\\n        }\\\\n    }\\\\n    // We're prerendering in a mode that does not aborts. We resolve the promise without\\\\n    // any tracking because we're just transporting a value from server to client where the tracking\\\\n    // will be applied.\\\\n    return Promise.resolve({});\\\\n})\\\",\\\"createServerParamsForMetadata\\\":\\\"$E(function createServerParamsForServerSegment(underlyingParams, workStore) {\\\\n    if (workStore.isStaticGeneration) {\\\\n        return createPrerenderParams(underlyingParams, workStore);\\\\n    } else {\\\\n        return createRenderParams(underlyingParams, workStore);\\\\n    }\\\\n})\\\",\\\"createServerParamsForServerSegment\\\":\\\"$E(function createServerParamsForServerSegment(underlyingParams, workStore) {\\\\n    if (workStore.isStaticGeneration) {\\\\n        return createPrerenderParams(underlyingParams, workStore);\\\\n    } else {\\\\n        return createRenderParams(underlyingParams, workStore);\\\\n    }\\\\n})\\\",\\\"createServerSearchParamsForMetadata\\\":\\\"$E(function createServerSearchParamsForServerPage(underlyingSearchParams, workStore) {\\\\n    if (workStore.isStaticGeneration) {\\\\n        return createPrerenderSearchParams(workStore);\\\\n    } else {\\\\n        return createRenderSearchParams(underlyingSearchParams, workStore);\\\\n    }\\\\n})\\\",\\\"createServerSearchParamsForServerPage\\\":\\\"$E(function createServerSearchParamsForServerPage(underlyingSearchParams, workStore) {\\\\n    if (workStore.isStaticGeneration) {\\\\n        return createPrerenderSearchParams(workStore);\\\\n    } else {\\\\n        return createRenderSearchParams(underlyingSearchParams, workStore);\\\\n    }\\\\n})\\\",\\\"decodeAction\\\":\\\"$E(function(body,serverManifest){var formData=new FormData,action=null;return body.forEach(function(value,key){key.startsWith(\\\\\\\"$ACTION_\\\\\\\")?key.startsWith(\\\\\\\"$ACTION_REF_\\\\\\\")?(value=decodeBoundActionMetaData(body,serverManifest,value=\\\\\\\"$ACTION_\\\\\\\"+key.slice(12)+\\\\\\\":\\\\\\\"),action=loadServerReference(serverManifest,value.id,value.bound)):key.startsWith(\\\\\\\"$ACTION_ID_\\\\\\\")\\u0026\\u0026(action=loadServerReference(serverManifest,value=key.slice(11),null)):formData.append(key,value)}),null===action?null:action.then(function(fn){return fn.bind(null,formData)})})\\\",\\\"decodeFormState\\\":\\\"$E(function(actionResult,body,serverManifest){var keyPath=body.get(\\\\\\\"$ACTION_KEY\\\\\\\");if(\\\\\\\"string\\\\\\\"!=typeof keyPath)return Promise.resolve(null);var metaData=null;if(body.forEach(function(value,key){key.startsWith(\\\\\\\"$ACTION_REF_\\\\\\\")\\u0026\\u0026(metaData=decodeBoundActionMetaData(body,serverManifest,\\\\\\\"$ACTION_\\\\\\\"+key.slice(12)+\\\\\\\":\\\\\\\"))}),null===metaData)return Promise.resolve(null);var referenceId=metaData.id;return Promise.resolve(metaData.bound).then(function(bound){return null===bound?null:[actionResult,keyPath,referenceId,bound.length-1]})})\\\",\\\"decodeReply\\\":\\\"$E(function(body,webpackMap,options){if(\\\\\\\"string\\\\\\\"==typeof body){var form=new FormData;form.append(\\\\\\\"0\\\\\\\",body),body=form}return webpackMap=getChunk(body=createResponse(webpackMap,\\\\\\\"\\\\\\\",options?options.temporaryReferences:void 0,body),0),close(body),webpackMap})\\\",\\\"patchFetch\\\":\\\"$E(function patchFetch() {\\\\n    return (0, _patchfetch.patchFetch)({\\\\n        workAsyncStorage: _workasyncstorageexternal.workAsyncStorage,\\\\n        requestAsyncStorage: _requestasyncstorageexternal.requestAsyncStorage,\\\\n        prerenderAsyncStorage: _prerenderasyncstorageexternal.prerenderAsyncStorage\\\\n    });\\\\n})\\\",\\\"preconnect\\\":\\\"$E(function preconnect(href, crossOrigin, nonce) {\\\\n    const opts = {};\\\\n    if (typeof crossOrigin === 'string') {\\\\n        opts.crossOrigin = crossOrigin;\\\\n    }\\\\n    if (typeof nonce === 'string') {\\\\n        opts.nonce = nonce;\\\\n    }\\\\n    _reactdom.default.preconnect(href, opts);\\\\n})\\\",\\\"preloadFont\\\":\\\"$E(function preloadFont(href, type, crossOrigin, nonce) {\\\\n    const opts = {\\\\n        as: 'font',\\\\n        type\\\\n    };\\\\n    if (typeof crossOrigin === 'string') {\\\\n        opts.crossOrigin = crossOrigin;\\\\n    }\\\\n    if (typeof nonce === 'string') {\\\\n        opts.nonce = nonce;\\\\n    }\\\\n    _reactdom.default.preload(href, opts);\\\\n})\\\",\\\"preloadStyle\\\":\\\"$E(function preloadStyle(href, crossOrigin, nonce) {\\\\n    const opts = {\\\\n        as: 'style'\\\\n    };\\\\n    if (typeof crossOrigin === 'string') {\\\\n        opts.crossOrigin = crossOrigin;\\\\n    }\\\\n    if (typeof nonce === 'string') {\\\\n        opts.nonce = nonce;\\\\n    }\\\\n    _reactdom.default.preload(href, opts);\\\\n})\\\",\\\"prerender\\\":\\\"$undefined\\\",\\\"renderToReadableStream\\\":\\\"$E(function(model,webpackMap,options){var request=new RequestInstance(20,model,webpackMap,options?options.onError:void 0,options?options.identifierPrefix:void 0,options?options.onPostpone:void 0,options?options.temporaryReferences:void 0,options?options.environmentName:void 0,options?options.filterStackFrame:void 0,noop,noop);if(options\\u0026\\u0026options.signal){var signal=options.signal;if(signal.aborted)abort(request,signal.reason);else{var listener=function(){abort(request,signal.reason),signal.removeEventListener(\\\\\\\"abort\\\\\\\",listener)};signal.addEventListener(\\\\\\\"abort\\\\\\\",listener)}}return new ReadableStream({type:\\\\\\\"bytes\\\\\\\",start:function(){request.flushScheduled=null!==request.destination,supportsRequestStorage?scheduleMicrotask(function(){requestStorage.run(request,performWork,request)}):scheduleMicrotask(function(){return performWork(request)}),setTimeoutOrImmediate(function(){request.status===OPENING\\u0026\\u0026(request.status=11)},0)},pull:function(controller){if(request.status===CLOSING)request.status=CLOSED,closeWithError(controller,request.fatalError);else if(request.status!==CLOSED\\u0026\\u0026null===request.destination){request.destination=controller;try{flushCompletedChunks(request,controller)}catch(error){logRecoverableError(request,error,null),fatalError(request,error)}}},cancel:function(reason){request.destination=null,abort(request,reason)}},{highWaterMark:0})})\\\",\\\"requestAsyncStorage\\\":\\\"$Y\\\",\\\"serverHooks\\\":\\\"$Y\\\",\\\"taintObjectReference\\\":\\\"$E(function notImplemented() {\\\\n    throw new Error('Taint can only be used with the taint flag.');\\\\n})\\\",\\\"workAsyncStorage\\\":\\\"$Y\\\"},\\\"renderOpts\\\":\\\"$Y\\\",\\\"requestStore\\\":\\\"$Y\\\",\\\"workStore\\\":\\\"$Y\\\",\\\"parsedRequestHeaders\\\":\\\"$Y\\\",\\\"getDynamicParamFromSegment\\\":\\\"$E(function(segment){let segmentParam=getSegmentParam(segment);if(!segmentParam)return null;let key=segmentParam.param,value=params[key];if(fallbackRouteParams\\u0026\\u0026fallbackRouteParams.has(segmentParam.param)?value=fallbackRouteParams.get(segmentParam.param):Array.isArray(value)?value=value.map(i=\\u003eencodeURIComponent(i)):\\\\\\\"string\\\\\\\"==typeof value\\u0026\\u0026(value=encodeURIComponent(value)),!value){let isCatchall=\\\\\\\"catchall\\\\\\\"===segmentParam.type,isOptionalCatchall=\\\\\\\"optional-catchall\\\\\\\"===segmentParam.type;if(isCatchall||isOptionalCatchall){let dynamicParamType=dynamicParamTypes[segmentParam.type];return isOptionalCatchall?{param:key,value:null,type:dynamicParamType,treeSegment:[key,\\\\\\\"\\\\\\\",dynamicParamType]}:{param:key,value:value=pagePath.split(\\\\\\\"/\\\\\\\").slice(1).flatMap(pathSegment=\\u003e{let param=function(param){let match=param.match(PARAMETER_PATTERN);return match?parseMatchedParameter(match[1]):parseMatchedParameter(param)}(pathSegment);return params[param.key]??param.key}),type:dynamicParamType,treeSegment:[key,value.join(\\\\\\\"/\\\\\\\"),dynamicParamType]}}}let type=function(type){let short=dynamicParamTypes[type];if(!short)throw Error(\\\\\\\"Unknown dynamic param type\\\\\\\");return short}(segmentParam.type);return{param:key,value:value,treeSegment:[key,Array.isArray(value)?value.join(\\\\\\\"/\\\\\\\"):value,type],type:type}})\\\",\\\"query\\\":\\\"$Y\\\",\\\"isPrefetch\\\":false,\\\"isAction\\\":false,\\\"requestTimestamp\\\":1728059356294,\\\"appUsingSizeAdjustment\\\":false,\\\"flightRouterState\\\":\\\"$undefined\\\",\\\"requestId\\\":\\\"kjk-U4Ei1jBDlV1_xdlh-\\\",\\\"defaultRevalidate\\\":false,\\\"pagePath\\\":\\\"/\\\",\\\"clientReferenceManifest\\\":\\\"$Y\\\",\\\"assetPrefix\\\":\\\"\\\",\\\"isNotFoundPath\\\":false,\\\"nonce\\\":\\\"$undefined\\\",\\\"res\\\":\\\"$Y\\\"}}}\\n\"])</script><script>self.__next_f.push([1,\"1e:D\\\"$25\\\"\\n1e:null\\n27:{\\\"name\\\":\\\"MetadataRoot\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":\\\"kjk-U4Ei1jBDlV1_xdlh-\\\",\\\"owner\\\":null,\\\"props\\\":{}}\\n26:D\\\"$27\\\"\\n29:{\\\"name\\\":\\\"Metadata\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":null,\\\"owner\\\":\\\"$27\\\",\\\"props\\\":{}}\\n28:D\\\"$29\\\"\\n2b:{\\\"name\\\":\\\"Viewport\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":null,\\\"owner\\\":\\\"$27\\\",\\\"props\\\":{}}\\n2a:D\\\"$2b\\\"\\n26:[\\\"$\\\",\\\"$3\\\",\\\"kjk-U4Ei1jBDlV1_xdlh-\\\",{\\\"children\\\":[[\\\"$\\\",\\\"$L22\\\",null,{\\\"children\\\":\\\"$L28\\\"},\\\"$27\\\"],[\\\"$\\\",\\\"$L24\\\",null,{\\\"children\\\":\\\"$L2a\\\"},\\\"$27\\\"],null]},null]\\n2c:[]\\n0:{\\\"P\\\":\\\"$1\\\",\\\"b\\\":\\\"development\\\",\\\"p\\\":\\\"\\\",\\\"c\\\":[\\\"\\\",\\\"\\\"],\\\"i\\\":false,\\\"f\\\":[[[\\\"\\\",{\\\"children\\\":[\\\"__PAGE__\\\",{}]},\\\"$undefined\\\",\\\"$undefined\\\",true],[\\\"\\\",[\\\"$\\\",\\\"$3\\\",\\\"c\\\",{\\\"children\\\":[null,\\\"$4\\\"]},null],{\\\"children\\\":[\\\"__PAGE__\\\",[\\\"$\\\",\\\"$3\\\",\\\"c\\\",{\\\"children\\\":[\\\"$e\\\",null,[\\\"$\\\",\\\"$L1b\\\",null,{\\\"children\\\":\\\"$L1c\\\"},null]]},null],{},null]},null],[\\\"$\\\",\\\"$3\\\",\\\"h\\\",{\\\"children\\\":[\\\"$1e\\\",\\\"$26\\\"]},null]]],\\\"m\\\":\\\"$W2c\\\",\\\"G\\\":\\\"$1f\\\",\\\"s\\\":false,\\\"S\\\":false}\\n2a:[[\\\"$\\\",\\\"meta\\\",\\\"0\\\",{\\\"name\\\":\\\"viewport\\\",\\\"content\\\":\\\"width=device-width, initial-scale=1\\\"},\\\"$1d\\\"]]\\n28:[[\\\"$\\\",\\\"meta\\\",\\\"0\\\",{\\\"charSet\\\":\\\"utf-8\\\"},\\\"$29\\\"],[\\\"$\\\",\\\"title\\\",\\\"1\\\",{\\\"children\\\":\\\"Next.js\\\"},\\\"$29\\\"],[\\\"$\\\",\\\"meta\\\",\\\"2\\\",{\\\"name\\\":\\\"description\\\",\\\"content\\\":\\\"Generated by Next.js\\\"},\\\"$29\\\"]]\\n1c:null\\n\"])</script></body></html>"

  29 |
  30 |         // Ensure the icons are rendered
> 31 |         expect(html).toContain('<svg xmlns="http://www.w3.org/2000/svg"')
     |                      ^
  32 |
  33 |         const modules = [
  34 |           ...logs.matchAll(

  at Object.toContain (development/basic/barrel-optimization/barrel-optimization.test.ts:31:22)

● Skipped in Turbopack › optimizePackageImports - basic › should handle recursive wildcard exports

expect(received).toContain(expected) // indexOf

Expected substring: "<h1>42</h1>"
Received string:    "<!DOCTYPE html><html id=\"__next_error__\"><head><meta charSet=\"utf-8\"/><meta name=\"viewport\" content=\"width=device-width, initial-scale=1\"/><link rel=\"preload\" as=\"script\" fetchPriority=\"low\" href=\"/_next/static/chunks/webpack.js\"/><script src=\"/_next/static/chunks/main-app.js\" async=\"\"></script><script src=\"/_next/static/chunks/app-pages-internals.js\" async=\"\"></script><meta name=\"robots\" content=\"noindex\"/><meta name=\"next-error\" content=\"not-found\"/><title>Next.js</title><meta name=\"description\" content=\"Generated by Next.js\"/><script src=\"/_next/static/chunks/polyfills.js\" noModule=\"\"></script></head><body><script src=\"/_next/static/chunks/webpack.js\" async=\"\"></script><script>(self.__next_f=self.__next_f||[]).push([0])</script><script>self.__next_f.push([1,\"3:\\\"$Sreact.fragment\\\"\\n5:\\\"$Sreact.transitional.element\\\"\\n6:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/client/components/layout-router.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-internals.js\\\"],\\\"\\\"]\\n7:\\\"$Sreact.transitional.element\\\"\\n8:\\\"$Sreact.transitional.element\\\"\\n9:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/client/components/render-from-template-context.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-internals.js\\\"],\\\"\\\"]\\na:\\\"$Sreact.transitional.element\\\"\\n14:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/lib/metadata/metadata-boundary.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-internals.js\\\"],\\\"OutletBoundary\\\"]\\n18:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/client/components/error-boundary.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-internals.js\\\"],\\\"\\\"]\\n19:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/client/components/client-page.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-internals.js\\\"],\\\"ClientPageRoot\\\"]\\n1a:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/client/components/client-segment.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-internals.js\\\"],\\\"ClientSegmentRoot\\\"]\\n1b:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05\"])</script><script>self.__next_f.push([1,\"fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/lib/metadata/metadata-boundary.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-internals.js\\\"],\\\"MetadataBoundary\\\"]\\n1c:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/client/components/not-found-boundary.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-internals.js\\\"],\\\"NotFoundBoundary\\\"]\\n1d:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/lib/metadata/metadata-boundary.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-internals.js\\\"],\\\"ViewportBoundary\\\"]\\n2:{\\\"name\\\":\\\"Preloads\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":null,\\\"owner\\\":null,\\\"props\\\":{\\\"preloadCallbacks\\\":[]}}\\n1:D\\\"$2\\\"\\n1:null\\n\"])</script><script>self.__next_f.push([1,\"b:{\\\"name\\\":\\\"RootLayout\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":null,\\\"owner\\\":null,\\\"props\\\":{\\\"children\\\":[\\\"$5\\\",\\\"$L6\\\",null,{\\\"parallelRouterKey\\\":\\\"children\\\",\\\"segmentPath\\\":[\\\"children\\\"],\\\"error\\\":\\\"$undefined\\\",\\\"errorStyles\\\":\\\"$undefined\\\",\\\"errorScripts\\\":\\\"$undefined\\\",\\\"template\\\":[\\\"$7\\\",\\\"$3\\\",null,{\\\"children\\\":[\\\"$8\\\",\\\"$L9\\\",null,{},null]},null],\\\"templateStyles\\\":\\\"$undefined\\\",\\\"templateScripts\\\":\\\"$undefined\\\",\\\"notFound\\\":[\\\"$a\\\",\\\"$E(function NotFound() {\\\\n    return /*#__PURE__*/ (0, _jsxruntime.jsxs)(_jsxruntime.Fragment, {\\\\n        children: [\\\\n            /*#__PURE__*/ (0, _jsxruntime.jsx)(\\\\\\\"title\\\\\\\", {\\\\n                children: \\\\\\\"404: This page could not be found.\\\\\\\"\\\\n            }),\\\\n            /*#__PURE__*/ (0, _jsxruntime.jsx)(\\\\\\\"div\\\\\\\", {\\\\n                style: styles.error,\\\\n                children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(\\\\\\\"div\\\\\\\", {\\\\n                    children: [\\\\n                        /*#__PURE__*/ (0, _jsxruntime.jsx)(\\\\\\\"style\\\\\\\", {\\\\n                            dangerouslySetInnerHTML: {\\\\n                                /* Minified CSS from\\\\n                body { margin: 0; color: #000; background: #fff; }\\\\n                .next-error-h1 {\\\\n                  border-right: 1px solid rgba(0, 0, 0, .3);\\\\n                }\\\\n\\\\n                @media (prefers-color-scheme: dark) {\\\\n                  body { color: #fff; background: #000; }\\\\n                  .next-error-h1 {\\\\n                    border-right: 1px solid rgba(255, 255, 255, .3);\\\\n                  }\\\\n                }\\\\n              */ __html: \\\\\\\"body{color:#000;background:#fff;margin:0}.next-error-h1{border-right:1px solid rgba(0,0,0,.3)}@media (prefers-color-scheme:dark){body{color:#fff;background:#000}.next-error-h1{border-right:1px solid rgba(255,255,255,.3)}}\\\\\\\"\\\\n                            }\\\\n                        }),\\\\n                        /*#__PURE__*/ (0, _jsxruntime.jsx)(\\\\\\\"h1\\\\\\\", {\\\\n                            className: \\\\\\\"next-error-h1\\\\\\\",\\\\n                            style: styles.h1,\\\\n                            children: \\\\\\\"404\\\\\\\"\\\\n                        }),\\\\n                        /*#__PURE__*/ (0, _jsxruntime.jsx)(\\\\\\\"div\\\\\\\", {\\\\n                            style: styles.desc,\\\\n                            children: /*#__PURE__*/ (0, _jsxruntime.jsx)(\\\\\\\"h2\\\\\\\", {\\\\n                                style: styles.h2,\\\\n                                children: \\\\\\\"This page could not be found.\\\\\\\"\\\\n                            })\\\\n                        })\\\\n                    ]\\\\n                })\\\\n            })\\\\n        ]\\\\n    });\\\\n})\\\",null,\\\"$Y\\\",null],\\\"notFoundStyles\\\":\\\"$Y\\\"},null],\\\"params\\\":\\\"$Y\\\"}}\\n\"])</script><script>self.__next_f.push([1,\"4:D\\\"$b\\\"\\nd:{\\\"name\\\":\\\"NotFound\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":null,\\\"owner\\\":null,\\\"props\\\":{}}\\nc:D\\\"$d\\\"\\nc:[[\\\"$\\\",\\\"title\\\",null,{\\\"children\\\":\\\"404: This page could not be found.\\\"},\\\"$d\\\"],[\\\"$\\\",\\\"div\\\",null,{\\\"style\\\":{\\\"fontFamily\\\":\\\"system-ui,\\\\\\\"Segoe UI\\\\\\\",Roboto,Helvetica,Arial,sans-serif,\\\\\\\"Apple Color Emoji\\\\\\\",\\\\\\\"Segoe UI Emoji\\\\\\\"\\\",\\\"height\\\":\\\"100vh\\\",\\\"textAlign\\\":\\\"center\\\",\\\"display\\\":\\\"flex\\\",\\\"flexDirection\\\":\\\"column\\\",\\\"alignItems\\\":\\\"center\\\",\\\"justifyContent\\\":\\\"center\\\"},\\\"children\\\":[\\\"$\\\",\\\"div\\\",null,{\\\"children\\\":[[\\\"$\\\",\\\"style\\\",null,{\\\"dangerouslySetInnerHTML\\\":{\\\"__html\\\":\\\"body{color:#000;background:#fff;margin:0}.next-error-h1{border-right:1px solid rgba(0,0,0,.3)}@media (prefers-color-scheme:dark){body{color:#fff;background:#000}.next-error-h1{border-right:1px solid rgba(255,255,255,.3)}}\\\"}},\\\"$d\\\"],[\\\"$\\\",\\\"h1\\\",null,{\\\"className\\\":\\\"next-error-h1\\\",\\\"style\\\":{\\\"display\\\":\\\"inline-block\\\",\\\"margin\\\":\\\"0 20px 0 0\\\",\\\"padding\\\":\\\"0 23px 0 0\\\",\\\"fontSize\\\":24,\\\"fontWeight\\\":500,\\\"verticalAlign\\\":\\\"top\\\",\\\"lineHeight\\\":\\\"49px\\\"},\\\"children\\\":\\\"404\\\"},\\\"$d\\\"],[\\\"$\\\",\\\"div\\\",null,{\\\"style\\\":{\\\"display\\\":\\\"inline-block\\\"},\\\"children\\\":[\\\"$\\\",\\\"h2\\\",null,{\\\"style\\\":{\\\"fontSize\\\":14,\\\"fontWeight\\\":400,\\\"lineHeight\\\":\\\"49px\\\",\\\"margin\\\":0},\\\"children\\\":\\\"This page could not be found.\\\"},\\\"$d\\\"]},\\\"$d\\\"]]},\\\"$d\\\"]},\\\"$d\\\"]]\\n4:[\\\"$\\\",\\\"html\\\",null,{\\\"lang\\\":\\\"en\\\",\\\"children\\\":[\\\"$\\\",\\\"body\\\",null,{\\\"children\\\":[\\\"$\\\",\\\"$L6\\\",null,{\\\"parallelRouterKey\\\":\\\"children\\\",\\\"segmentPath\\\":[\\\"children\\\"],\\\"error\\\":\\\"$undefined\\\",\\\"errorStyles\\\":\\\"$undefined\\\",\\\"errorScripts\\\":\\\"$undefined\\\",\\\"template\\\":[\\\"$\\\",\\\"$L9\\\",null,{},null],\\\"templateStyles\\\":\\\"$undefined\\\",\\\"templateScripts\\\":\\\"$undefined\\\",\\\"notFound\\\":\\\"$c\\\",\\\"notFoundStyles\\\":[]},null]},\\\"$b\\\"]},\\\"$b\\\"]\\nf:W[\\\"error\\\",[],null,\\\"Server\\\",\\\" In route /recursive a searchParam property was accessed directly with `searchParams.toJSON`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis\\\"]\\n10:W[\\\"error\\\",[],null,\\\"Server\\\",\\\" In route /recursive a searchParam property was accessed directly with `searchParams.$$typeof`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs\"])</script><script>self.__next_f.push([1,\".org/docs/messages/sync-dynamic-apis\\\"]\\n11:W[\\\"error\\\",[],null,\\\"Server\\\",\\\" In route /recursive a searchParam property was accessed directly with `searchParams.$$typeof`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis\\\"]\\n12:W[\\\"error\\\",[],null,\\\"Server\\\",\\\" In route /recursive a searchParam property was accessed directly with `searchParams.status`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis\\\"]\\n13:{\\\"name\\\":\\\"Page\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":null,\\\"owner\\\":null,\\\"props\\\":{\\\"params\\\":\\\"$@\\\",\\\"searchParams\\\":\\\"$@\\\"}}\\ne:D\\\"$13\\\"\\ne:[\\\"$\\\",\\\"h1\\\",null,{\\\"children\\\":42},\\\"$13\\\"]\\n16:{\\\"name\\\":\\\"MetadataOutlet\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":null,\\\"owner\\\":null,\\\"props\\\":{\\\"ready\\\":\\\"$E(async function getMetadataAndViewportReady() {\\\\n        await viewport();\\\\n        await metadata();\\\\n        return undefined;\\\\n    })\\\"}}\\n15:D\\\"$16\\\"\\n\"])</script><script>self.__next_f.push([1,\"1e:{\\\"name\\\":\\\"NonIndex\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":null,\\\"owner\\\":null,\\\"props\\\":{\\\"ctx\\\":{\\\"componentMod\\\":{\\\"GlobalError\\\":\\\"$18\\\",\\\"__next_app__\\\":{\\\"require\\\":\\\"$E(function __webpack_require__(moduleId) {\\\\n/******/ \\\\t\\\\t// Check if module is in cache\\\\n/******/ \\\\t\\\\tvar cachedModule = __webpack_module_cache__[moduleId];\\\\n/******/ \\\\t\\\\tif (cachedModule !== undefined) {\\\\n/******/ \\\\t\\\\t\\\\treturn cachedModule.exports;\\\\n/******/ \\\\t\\\\t}\\\\n/******/ \\\\t\\\\t// Create a new module (and put it into the cache)\\\\n/******/ \\\\t\\\\tvar module = __webpack_module_cache__[moduleId] = {\\\\n/******/ \\\\t\\\\t\\\\tid: moduleId,\\\\n/******/ \\\\t\\\\t\\\\tloaded: false,\\\\n/******/ \\\\t\\\\t\\\\texports: {}\\\\n/******/ \\\\t\\\\t};\\\\n/******/ \\\\t\\\\n/******/ \\\\t\\\\t// Execute the module function\\\\n/******/ \\\\t\\\\tvar threw = true;\\\\n/******/ \\\\t\\\\ttry {\\\\n/******/ \\\\t\\\\t\\\\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\\\\n/******/ \\\\t\\\\t\\\\tthrew = false;\\\\n/******/ \\\\t\\\\t} finally {\\\\n/******/ \\\\t\\\\t\\\\tif(threw) delete __webpack_module_cache__[moduleId];\\\\n/******/ \\\\t\\\\t}\\\\n/******/ \\\\t\\\\n/******/ \\\\t\\\\t// Flag the module as loaded\\\\n/******/ \\\\t\\\\tmodule.loaded = true;\\\\n/******/ \\\\t\\\\n/******/ \\\\t\\\\t// Return the exports of the module\\\\n/******/ \\\\t\\\\treturn module.exports;\\\\n/******/ \\\\t})\\\",\\\"loadChunk\\\":\\\"$E(() =\\u003e Promise.resolve())\\\"},\\\"pages\\\":[\\\"/tmp/next-install-e82693b0c1e2696ea71e6942fd12c5650a137067076e9c102681d62a5edd6227/app/recursive/page.js\\\"],\\\"routeModule\\\":{\\\"userland\\\":{\\\"loaderTree\\\":[\\\"\\\",{\\\"children\\\":\\\"$Y\\\"},\\\"$Y\\\"]},\\\"definition\\\":\\\"$Y\\\"},\\\"tree\\\":\\\"$Y\\\",\\\"ClientPageRoot\\\":\\\"$19\\\",\\\"ClientSegmentRoot\\\":\\\"$1a\\\",\\\"LayoutRouter\\\":\\\"$6\\\",\\\"MetadataBoundary\\\":\\\"$1b\\\",\\\"NotFoundBoundary\\\":\\\"$1c\\\",\\\"OutletBoundary\\\":\\\"$14\\\",\\\"Postpone\\\":\\\"$E(function Postpone({ reason, route }) {\\\\n    const prerenderStore = _prerenderasyncstorageexternal.prerenderAsyncStorage.getStore();\\\\n    const dynamicTracking = prerenderStore \\u0026\\u0026 prerenderStore.type === 'prerender' ? prerenderStore.dynamicTracking : null;\\\\n    postponeWithTracking(route, reason, dynamicTracking);\\\\n})\\\",\\\"RenderFromTemplateContext\\\":\\\"$9\\\",\\\"ViewportBoundary\\\":\\\"$1d\\\",\\\"actionAsyncStorage\\\":\\\"$Y\\\",\\\"createMetadataComponents\\\":\\\"$E(function createMetadataComponents({ tree, searchParams, metadataContext, getDynamicParamFromSegment, appUsingSizeAdjustment, errorType, createServerParamsForMetadata, workStore, MetadataBoundary, ViewportBoundary }) {\\\\n    function MetadataRoot() {\\\\n        return /*#__PURE__*/ (0, _jsxruntime.jsxs)(_jsxruntime.Fragment, {\\\\n            children: [\\\\n                /*#__PURE__*/ (0, _jsxruntime.jsx)(MetadataBoundary, {\\\\n                    children: /*#__PURE__*/ (0, _jsxruntime.jsx)(Metadata, {})\\\\n                }),\\\\n                /*#__PURE__*/ (0, _jsxruntime.jsx)(ViewportBoundary, {\\\\n                    children: /*#__PURE__*/ (0, _jsxruntime.jsx)(Viewport, {})\\\\n                }),\\\\n                appUsingSizeAdjustment ? /*#__PURE__*/ (0, _jsxruntime.jsx)(\\\\\\\"meta\\\\\\\", {\\\\n                    name: \\\\\\\"next-size-adjust\\\\\\\"\\\\n                }) : null\\\\n            ]\\\\n        });\\\\n    }\\\\n    async function viewport() {\\\\n        return getResolvedViewport(tree, searchParams, getDynamicParamFromSegment, createServerParamsForMetadata, workStore, errorType);\\\\n    }\\\\n    async function Viewport() {\\\\n        try {\\\\n            return await viewport();\\\\n        } catch (error) {\\\\n            if (!errorType \\u0026\\u0026 (0, _notfound.isNotFoundError)(error)) {\\\\n                try {\\\\n                    return await getNotFoundViewport(tree, searchParams, getDynamicParamFromSegment, createServerParamsForMetadata, workStore);\\\\n                } catch  {}\\\\n            }\\\\n            // We don't actually want to error in this component. We will\\\\n            // also error in the MetadataOutlet which causes the error to\\\\n            // bubble from the right position in the page to be caught by the\\\\n            // appropriate boundaries\\\\n            return null;\\\\n        }\\\\n    }\\\\n    async function metadata() {\\\\n        return getResolvedMetadata(tree, searchParams, getDynamicParamFromSegment, metadataContext, createServerParamsForMetadata, workStore, errorType);\\\\n    }\\\\n    async function Metadata() {\\\\n        try {\\\\n            return await metadata();\\\\n        } catch (error) {\\\\n            if (!errorType \\u0026\\u0026 (0, _notfound.isNotFoundError)(error)) {\\\\n                try {\\\\n                    return await getNotFoundMetadata(tree, searchParams, getDynamicParamFromSegment, metadataContext, createServerParamsForMetadata, workStore);\\\\n                } catch  {}\\\\n            }\\\\n            // We don't actually want to error in this component. We will\\\\n            // also error in the MetadataOutlet which causes the error to\\\\n            // bubble from the right position in the page to be caught by the\\\\n            // appropriate boundaries\\\\n            return null;\\\\n        }\\\\n    }\\\\n    async function getMetadataAndViewportReady() {\\\\n        await viewport();\\\\n        await metadata();\\\\n        return undefined;\\\\n    }\\\\n    return [\\\\n        MetadataRoot,\\\\n        getMetadataAndViewportReady\\\\n    ];\\\\n})\\\",\\\"createPrerenderParamsForClientSegment\\\":\\\"$E(function createPrerenderParamsForClientSegment(underlyingParams, workStore) {\\\\n    const prerenderStore = _prerenderasyncstorageexternal.prerenderAsyncStorage.getStore();\\\\n    if (prerenderStore \\u0026\\u0026 prerenderStore.type === 'prerender') {\\\\n        if ((0, _prerenderasyncstorageexternal.isDynamicIOPrerender)(prerenderStore)) {\\\\n            const fallbackParams = workStore.fallbackRouteParams;\\\\n            if (fallbackParams) {\\\\n                for(let key in underlyingParams){\\\\n                    if (fallbackParams.has(key)) {\\\\n                        // This params object has one of more fallback params so we need to consider\\\\n                        // the awaiting of this params object \\\\\\\"dynamic\\\\\\\". Since we are in dynamicIO mode\\\\n                        // we encode this as a promise that never resolves\\\\n                        return (0, _dynamicrenderingutils.makeHangingPromise)();\\\\n                    }\\\\n                }\\\\n            }\\\\n        }\\\\n    }\\\\n    // We're prerendering in a mode that does not abort. We resolve the promise without\\\\n    // any tracking because we're just transporting a value from server to client where the tracking\\\\n    // will be applied.\\\\n    return (0, _utils.makeResolvedReactPromise)(underlyingParams);\\\\n})\\\",\\\"createPrerenderSearchParamsForClientPage\\\":\\\"$E(function createPrerenderSearchParamsForClientPage(workStore) {\\\\n    if (workStore.forceStatic) {\\\\n        // When using forceStatic we override all other logic and always just return an empty\\\\n        // dictionary object.\\\\n        return Promise.resolve({});\\\\n    }\\\\n    const prerenderStore = _prerenderasyncstorageexternal.prerenderAsyncStorage.getStore();\\\\n    if (prerenderStore) {\\\\n        if ((0, _prerenderasyncstorageexternal.isDynamicIOPrerender)(prerenderStore)) {\\\\n            // We're prerendering in a mode that aborts (dynamicIO) and should stall\\\\n            // the promise to ensure the RSC side is considered dynamic\\\\n            return (0, _dynamicrenderingutils.makeHangingPromise)();\\\\n        }\\\\n    }\\\\n    // We're prerendering in a mode that does not aborts. We resolve the promise without\\\\n    // any tracking because we're just transporting a value from server to client where the tracking\\\\n    // will be applied.\\\\n    return Promise.resolve({});\\\\n})\\\",\\\"createServerParamsForMetadata\\\":\\\"$E(function createServerParamsForServerSegment(underlyingParams, workStore) {\\\\n    if (workStore.isStaticGeneration) {\\\\n        return createPrerenderParams(underlyingParams, workStore);\\\\n    } else {\\\\n        return createRenderParams(underlyingParams, workStore);\\\\n    }\\\\n})\\\",\\\"createServerParamsForServerSegment\\\":\\\"$E(function createServerParamsForServerSegment(underlyingParams, workStore) {\\\\n    if (workStore.isStaticGeneration) {\\\\n        return createPrerenderParams(underlyingParams, workStore);\\\\n    } else {\\\\n        return createRenderParams(underlyingParams, workStore);\\\\n    }\\\\n})\\\",\\\"createServerSearchParamsForMetadata\\\":\\\"$E(function createServerSearchParamsForServerPage(underlyingSearchParams, workStore) {\\\\n    if (workStore.isStaticGeneration) {\\\\n        return createPrerenderSearchParams(workStore);\\\\n    } else {\\\\n        return createRenderSearchParams(underlyingSearchParams, workStore);\\\\n    }\\\\n})\\\",\\\"createServerSearchParamsForServerPage\\\":\\\"$E(function createServerSearchParamsForServerPage(underlyingSearchParams, workStore) {\\\\n    if (workStore.isStaticGeneration) {\\\\n        return createPrerenderSearchParams(workStore);\\\\n    } else {\\\\n        return createRenderSearchParams(underlyingSearchParams, workStore);\\\\n    }\\\\n})\\\",\\\"decodeAction\\\":\\\"$E(function(body,serverManifest){var formData=new FormData,action=null;return body.forEach(function(value,key){key.startsWith(\\\\\\\"$ACTION_\\\\\\\")?key.startsWith(\\\\\\\"$ACTION_REF_\\\\\\\")?(value=decodeBoundActionMetaData(body,serverManifest,value=\\\\\\\"$ACTION_\\\\\\\"+key.slice(12)+\\\\\\\":\\\\\\\"),action=loadServerReference(serverManifest,value.id,value.bound)):key.startsWith(\\\\\\\"$ACTION_ID_\\\\\\\")\\u0026\\u0026(action=loadServerReference(serverManifest,value=key.slice(11),null)):formData.append(key,value)}),null===action?null:action.then(function(fn){return fn.bind(null,formData)})})\\\",\\\"decodeFormState\\\":\\\"$E(function(actionResult,body,serverManifest){var keyPath=body.get(\\\\\\\"$ACTION_KEY\\\\\\\");if(\\\\\\\"string\\\\\\\"!=typeof keyPath)return Promise.resolve(null);var metaData=null;if(body.forEach(function(value,key){key.startsWith(\\\\\\\"$ACTION_REF_\\\\\\\")\\u0026\\u0026(metaData=decodeBoundActionMetaData(body,serverManifest,\\\\\\\"$ACTION_\\\\\\\"+key.slice(12)+\\\\\\\":\\\\\\\"))}),null===metaData)return Promise.resolve(null);var referenceId=metaData.id;return Promise.resolve(metaData.bound).then(function(bound){return null===bound?null:[actionResult,keyPath,referenceId,bound.length-1]})})\\\",\\\"decodeReply\\\":\\\"$E(function(body,webpackMap,options){if(\\\\\\\"string\\\\\\\"==typeof body){var form=new FormData;form.append(\\\\\\\"0\\\\\\\",body),body=form}return webpackMap=getChunk(body=createResponse(webpackMap,\\\\\\\"\\\\\\\",options?options.temporaryReferences:void 0,body),0),close(body),webpackMap})\\\",\\\"patchFetch\\\":\\\"$E(function patchFetch() {\\\\n    return (0, _patchfetch.patchFetch)({\\\\n        workAsyncStorage: _workasyncstorageexternal.workAsyncStorage,\\\\n        requestAsyncStorage: _requestasyncstorageexternal.requestAsyncStorage,\\\\n        prerenderAsyncStorage: _prerenderasyncstorageexternal.prerenderAsyncStorage\\\\n    });\\\\n})\\\",\\\"preconnect\\\":\\\"$E(function preconnect(href, crossOrigin, nonce) {\\\\n    const opts = {};\\\\n    if (typeof crossOrigin === 'string') {\\\\n        opts.crossOrigin = crossOrigin;\\\\n    }\\\\n    if (typeof nonce === 'string') {\\\\n        opts.nonce = nonce;\\\\n    }\\\\n    _reactdom.default.preconnect(href, opts);\\\\n})\\\",\\\"preloadFont\\\":\\\"$E(function preloadFont(href, type, crossOrigin, nonce) {\\\\n    const opts = {\\\\n        as: 'font',\\\\n        type\\\\n    };\\\\n    if (typeof crossOrigin === 'string') {\\\\n        opts.crossOrigin = crossOrigin;\\\\n    }\\\\n    if (typeof nonce === 'string') {\\\\n        opts.nonce = nonce;\\\\n    }\\\\n    _reactdom.default.preload(href, opts);\\\\n})\\\",\\\"preloadStyle\\\":\\\"$E(function preloadStyle(href, crossOrigin, nonce) {\\\\n    const opts = {\\\\n        as: 'style'\\\\n    };\\\\n    if (typeof crossOrigin === 'string') {\\\\n        opts.crossOrigin = crossOrigin;\\\\n    }\\\\n    if (typeof nonce === 'string') {\\\\n        opts.nonce = nonce;\\\\n    }\\\\n    _reactdom.default.preload(href, opts);\\\\n})\\\",\\\"prerender\\\":\\\"$undefined\\\",\\\"renderToReadableStream\\\":\\\"$E(function(model,webpackMap,options){var request=new RequestInstance(20,model,webpackMap,options?options.onError:void 0,options?options.identifierPrefix:void 0,options?options.onPostpone:void 0,options?options.temporaryReferences:void 0,options?options.environmentName:void 0,options?options.filterStackFrame:void 0,noop,noop);if(options\\u0026\\u0026options.signal){var signal=options.signal;if(signal.aborted)abort(request,signal.reason);else{var listener=function(){abort(request,signal.reason),signal.removeEventListener(\\\\\\\"abort\\\\\\\",listener)};signal.addEventListener(\\\\\\\"abort\\\\\\\",listener)}}return new ReadableStream({type:\\\\\\\"bytes\\\\\\\",start:function(){request.flushScheduled=null!==request.destination,supportsRequestStorage?scheduleMicrotask(function(){requestStorage.run(request,performWork,request)}):scheduleMicrotask(function(){return performWork(request)}),setTimeoutOrImmediate(function(){request.status===OPENING\\u0026\\u0026(request.status=11)},0)},pull:function(controller){if(request.status===CLOSING)request.status=CLOSED,closeWithError(controller,request.fatalError);else if(request.status!==CLOSED\\u0026\\u0026null===request.destination){request.destination=controller;try{flushCompletedChunks(request,controller)}catch(error){logRecoverableError(request,error,null),fatalError(request,error)}}},cancel:function(reason){request.destination=null,abort(request,reason)}},{highWaterMark:0})})\\\",\\\"requestAsyncStorage\\\":\\\"$Y\\\",\\\"serverHooks\\\":\\\"$Y\\\",\\\"taintObjectReference\\\":\\\"$E(function notImplemented() {\\\\n    throw new Error('Taint can only be used with the taint flag.');\\\\n})\\\",\\\"workAsyncStorage\\\":\\\"$Y\\\"},\\\"renderOpts\\\":\\\"$Y\\\",\\\"requestStore\\\":\\\"$Y\\\",\\\"workStore\\\":\\\"$Y\\\",\\\"parsedRequestHeaders\\\":\\\"$Y\\\",\\\"getDynamicParamFromSegment\\\":\\\"$E(function(segment){let segmentParam=getSegmentParam(segment);if(!segmentParam)return null;let key=segmentParam.param,value=params[key];if(fallbackRouteParams\\u0026\\u0026fallbackRouteParams.has(segmentParam.param)?value=fallbackRouteParams.get(segmentParam.param):Array.isArray(value)?value=value.map(i=\\u003eencodeURIComponent(i)):\\\\\\\"string\\\\\\\"==typeof value\\u0026\\u0026(value=encodeURIComponent(value)),!value){let isCatchall=\\\\\\\"catchall\\\\\\\"===segmentParam.type,isOptionalCatchall=\\\\\\\"optional-catchall\\\\\\\"===segmentParam.type;if(isCatchall||isOptionalCatchall){let dynamicParamType=dynamicParamTypes[segmentParam.type];return isOptionalCatchall?{param:key,value:null,type:dynamicParamType,treeSegment:[key,\\\\\\\"\\\\\\\",dynamicParamType]}:{param:key,value:value=pagePath.split(\\\\\\\"/\\\\\\\").slice(1).flatMap(pathSegment=\\u003e{let param=function(param){let match=param.match(PARAMETER_PATTERN);return match?parseMatchedParameter(match[1]):parseMatchedParameter(param)}(pathSegment);return params[param.key]??param.key}),type:dynamicParamType,treeSegment:[key,value.join(\\\\\\\"/\\\\\\\"),dynamicParamType]}}}let type=function(type){let short=dynamicParamTypes[type];if(!short)throw Error(\\\\\\\"Unknown dynamic param type\\\\\\\");return short}(segmentParam.type);return{param:key,value:value,treeSegment:[key,Array.isArray(value)?value.join(\\\\\\\"/\\\\\\\"):value,type],type:type}})\\\",\\\"query\\\":\\\"$Y\\\",\\\"isPrefetch\\\":false,\\\"isAction\\\":false,\\\"requestTimestamp\\\":1728059368972,\\\"appUsingSizeAdjustment\\\":false,\\\"flightRouterState\\\":\\\"$undefined\\\",\\\"requestId\\\":\\\"mOZ6tLhy5xElsJqklPjn5\\\",\\\"defaultRevalidate\\\":false,\\\"pagePath\\\":\\\"/recursive\\\",\\\"clientReferenceManifest\\\":\\\"$Y\\\",\\\"assetPrefix\\\":\\\"\\\",\\\"isNotFoundPath\\\":false,\\\"nonce\\\":\\\"$undefined\\\",\\\"res\\\":\\\"$Y\\\"}}}\\n\"])</script><script>self.__next_f.push([1,\"17:D\\\"$1e\\\"\\n17:null\\n20:{\\\"name\\\":\\\"MetadataRoot\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":\\\"mOZ6tLhy5xElsJqklPjn5\\\",\\\"owner\\\":null,\\\"props\\\":{}}\\n1f:D\\\"$20\\\"\\n22:{\\\"name\\\":\\\"Metadata\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":null,\\\"owner\\\":\\\"$20\\\",\\\"props\\\":{}}\\n21:D\\\"$22\\\"\\n24:{\\\"name\\\":\\\"Viewport\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":null,\\\"owner\\\":\\\"$20\\\",\\\"props\\\":{}}\\n23:D\\\"$24\\\"\\n1f:[\\\"$\\\",\\\"$3\\\",\\\"mOZ6tLhy5xElsJqklPjn5\\\",{\\\"children\\\":[[\\\"$\\\",\\\"$L1b\\\",null,{\\\"children\\\":\\\"$L21\\\"},\\\"$20\\\"],[\\\"$\\\",\\\"$L1d\\\",null,{\\\"children\\\":\\\"$L23\\\"},\\\"$20\\\"],null]},null]\\n25:[]\\n0:{\\\"P\\\":\\\"$1\\\",\\\"b\\\":\\\"development\\\",\\\"p\\\":\\\"\\\",\\\"c\\\":[\\\"\\\",\\\"recursive\\\"],\\\"i\\\":false,\\\"f\\\":[[[\\\"\\\",{\\\"children\\\":[\\\"recursive\\\",{\\\"children\\\":[\\\"__PAGE__\\\",{}]}]},\\\"$undefined\\\",\\\"$undefined\\\",true],[\\\"\\\",[\\\"$\\\",\\\"$3\\\",\\\"c\\\",{\\\"children\\\":[null,\\\"$4\\\"]},null],{\\\"children\\\":[\\\"recursive\\\",[\\\"$\\\",\\\"$3\\\",\\\"c\\\",{\\\"children\\\":[null,[\\\"$\\\",\\\"$L6\\\",null,{\\\"parallelRouterKey\\\":\\\"children\\\",\\\"segmentPath\\\":[\\\"children\\\",\\\"recursive\\\",\\\"children\\\"],\\\"error\\\":\\\"$undefined\\\",\\\"errorStyles\\\":\\\"$undefined\\\",\\\"errorScripts\\\":\\\"$undefined\\\",\\\"template\\\":[\\\"$\\\",\\\"$L9\\\",null,{},null],\\\"templateStyles\\\":\\\"$undefined\\\",\\\"templateScripts\\\":\\\"$undefined\\\",\\\"notFound\\\":\\\"$undefined\\\",\\\"notFoundStyles\\\":\\\"$undefined\\\"},null]]},null],{\\\"children\\\":[\\\"__PAGE__\\\",[\\\"$\\\",\\\"$3\\\",\\\"c\\\",{\\\"children\\\":[\\\"$e\\\",null,[\\\"$\\\",\\\"$L14\\\",null,{\\\"children\\\":\\\"$L15\\\"},null]]},null],{},null]},null]},null],[\\\"$\\\",\\\"$3\\\",\\\"h\\\",{\\\"children\\\":[\\\"$17\\\",\\\"$1f\\\"]},null]]],\\\"m\\\":\\\"$W25\\\",\\\"G\\\":\\\"$18\\\",\\\"s\\\":false,\\\"S\\\":false}\\n23:[[\\\"$\\\",\\\"meta\\\",\\\"0\\\",{\\\"name\\\":\\\"viewport\\\",\\\"content\\\":\\\"width=device-width, initial-scale=1\\\"},\\\"$16\\\"]]\\n21:[[\\\"$\\\",\\\"meta\\\",\\\"0\\\",{\\\"charSet\\\":\\\"utf-8\\\"},\\\"$22\\\"],[\\\"$\\\",\\\"title\\\",\\\"1\\\",{\\\"children\\\":\\\"Next.js\\\"},\\\"$22\\\"],[\\\"$\\\",\\\"meta\\\",\\\"2\\\",{\\\"name\\\":\\\"description\\\",\\\"content\\\":\\\"Generated by Next.js\\\"},\\\"$22\\\"]]\\n15:null\\n\"])</script></body></html>"

  108 |       it('should handle recursive wildcard exports', async () => {
  109 |         const html = await next.render('/recursive')
> 110 |         expect(html).toContain('<h1>42</h1>')
      |                      ^
  111 |       })
  112 |
  113 |       it('should support visx', async () => {

  at Object.toContain (development/basic/barrel-optimization/barrel-optimization.test.ts:110:22)

● Skipped in Turbopack › optimizePackageImports - basic › should not break "use client" directive in optimized packages

expect(received).toContain(expected) // indexOf

Expected substring: "this is a client component"
Received string:    "<!DOCTYPE html><html id=\"__next_error__\"><head><meta charSet=\"utf-8\"/><meta name=\"viewport\" content=\"width=device-width, initial-scale=1\"/><link rel=\"preload\" as=\"script\" fetchPriority=\"low\" href=\"/_next/static/chunks/webpack.js\"/><script src=\"/_next/static/chunks/main-app.js\" async=\"\"></script><script src=\"/_next/static/chunks/app-pages-internals.js\" async=\"\"></script><meta name=\"robots\" content=\"noindex\"/><meta name=\"next-error\" content=\"not-found\"/><title>Next.js</title><meta name=\"description\" content=\"Generated by Next.js\"/><script src=\"/_next/static/chunks/polyfills.js\" noModule=\"\"></script></head><body><script src=\"/_next/static/chunks/webpack.js\" async=\"\"></script><script>(self.__next_f=self.__next_f||[]).push([0])</script><script>self.__next_f.push([1,\"3:\\\"$Sreact.fragment\\\"\\n5:\\\"$Sreact.transitional.element\\\"\\n6:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/client/components/layout-router.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-internals.js\\\"],\\\"\\\"]\\n7:\\\"$Sreact.transitional.element\\\"\\n8:\\\"$Sreact.transitional.element\\\"\\n9:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/client/components/render-from-template-context.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-internals.js\\\"],\\\"\\\"]\\na:\\\"$Sreact.transitional.element\\\"\\n14:I[\\\"(app-pages-browser)/./node_modules/my-lib/client.js\\\",[\\\"app/client/page\\\",\\\"static/chunks/app/client/page.js\\\"],\\\"Client\\\",1]\\n15:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/lib/metadata/metadata-boundary.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-internals.js\\\"],\\\"OutletBoundary\\\"]\\n19:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/client/components/error-boundary.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-internals.js\\\"],\\\"\\\"]\\n1a:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/client/components/client-page.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-internals.js\\\"],\\\"ClientPageRoot\\\"]\\n1b:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/client/components/client-segment.js\\\",[\\\"app-pages-internals\\\",\\\"static/c\"])</script><script>self.__next_f.push([1,\"hunks/app-pages-internals.js\\\"],\\\"ClientSegmentRoot\\\"]\\n1c:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/lib/metadata/metadata-boundary.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-internals.js\\\"],\\\"MetadataBoundary\\\"]\\n1d:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/client/components/not-found-boundary.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-internals.js\\\"],\\\"NotFoundBoundary\\\"]\\n1e:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/lib/metadata/metadata-boundary.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-internals.js\\\"],\\\"ViewportBoundary\\\"]\\n2:{\\\"name\\\":\\\"Preloads\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":null,\\\"owner\\\":null,\\\"props\\\":{\\\"preloadCallbacks\\\":[]}}\\n1:D\\\"$2\\\"\\n1:null\\n\"])</script><script>self.__next_f.push([1,\"b:{\\\"name\\\":\\\"RootLayout\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":null,\\\"owner\\\":null,\\\"props\\\":{\\\"children\\\":[\\\"$5\\\",\\\"$L6\\\",null,{\\\"parallelRouterKey\\\":\\\"children\\\",\\\"segmentPath\\\":[\\\"children\\\"],\\\"error\\\":\\\"$undefined\\\",\\\"errorStyles\\\":\\\"$undefined\\\",\\\"errorScripts\\\":\\\"$undefined\\\",\\\"template\\\":[\\\"$7\\\",\\\"$3\\\",null,{\\\"children\\\":[\\\"$8\\\",\\\"$L9\\\",null,{},null]},null],\\\"templateStyles\\\":\\\"$undefined\\\",\\\"templateScripts\\\":\\\"$undefined\\\",\\\"notFound\\\":[\\\"$a\\\",\\\"$E(function NotFound() {\\\\n    return /*#__PURE__*/ (0, _jsxruntime.jsxs)(_jsxruntime.Fragment, {\\\\n        children: [\\\\n            /*#__PURE__*/ (0, _jsxruntime.jsx)(\\\\\\\"title\\\\\\\", {\\\\n                children: \\\\\\\"404: This page could not be found.\\\\\\\"\\\\n            }),\\\\n            /*#__PURE__*/ (0, _jsxruntime.jsx)(\\\\\\\"div\\\\\\\", {\\\\n                style: styles.error,\\\\n                children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(\\\\\\\"div\\\\\\\", {\\\\n                    children: [\\\\n                        /*#__PURE__*/ (0, _jsxruntime.jsx)(\\\\\\\"style\\\\\\\", {\\\\n                            dangerouslySetInnerHTML: {\\\\n                                /* Minified CSS from\\\\n                body { margin: 0; color: #000; background: #fff; }\\\\n                .next-error-h1 {\\\\n                  border-right: 1px solid rgba(0, 0, 0, .3);\\\\n                }\\\\n\\\\n                @media (prefers-color-scheme: dark) {\\\\n                  body { color: #fff; background: #000; }\\\\n                  .next-error-h1 {\\\\n                    border-right: 1px solid rgba(255, 255, 255, .3);\\\\n                  }\\\\n                }\\\\n              */ __html: \\\\\\\"body{color:#000;background:#fff;margin:0}.next-error-h1{border-right:1px solid rgba(0,0,0,.3)}@media (prefers-color-scheme:dark){body{color:#fff;background:#000}.next-error-h1{border-right:1px solid rgba(255,255,255,.3)}}\\\\\\\"\\\\n                            }\\\\n                        }),\\\\n                        /*#__PURE__*/ (0, _jsxruntime.jsx)(\\\\\\\"h1\\\\\\\", {\\\\n                            className: \\\\\\\"next-error-h1\\\\\\\",\\\\n                            style: styles.h1,\\\\n                            children: \\\\\\\"404\\\\\\\"\\\\n                        }),\\\\n                        /*#__PURE__*/ (0, _jsxruntime.jsx)(\\\\\\\"div\\\\\\\", {\\\\n                            style: styles.desc,\\\\n                            children: /*#__PURE__*/ (0, _jsxruntime.jsx)(\\\\\\\"h2\\\\\\\", {\\\\n                                style: styles.h2,\\\\n                                children: \\\\\\\"This page could not be found.\\\\\\\"\\\\n                            })\\\\n                        })\\\\n                    ]\\\\n                })\\\\n            })\\\\n        ]\\\\n    });\\\\n})\\\",null,\\\"$Y\\\",null],\\\"notFoundStyles\\\":\\\"$Y\\\"},null],\\\"params\\\":\\\"$Y\\\"}}\\n\"])</script><script>self.__next_f.push([1,\"4:D\\\"$b\\\"\\nd:{\\\"name\\\":\\\"NotFound\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":null,\\\"owner\\\":null,\\\"props\\\":{}}\\nc:D\\\"$d\\\"\\nc:[[\\\"$\\\",\\\"title\\\",null,{\\\"children\\\":\\\"404: This page could not be found.\\\"},\\\"$d\\\"],[\\\"$\\\",\\\"div\\\",null,{\\\"style\\\":{\\\"fontFamily\\\":\\\"system-ui,\\\\\\\"Segoe UI\\\\\\\",Roboto,Helvetica,Arial,sans-serif,\\\\\\\"Apple Color Emoji\\\\\\\",\\\\\\\"Segoe UI Emoji\\\\\\\"\\\",\\\"height\\\":\\\"100vh\\\",\\\"textAlign\\\":\\\"center\\\",\\\"display\\\":\\\"flex\\\",\\\"flexDirection\\\":\\\"column\\\",\\\"alignItems\\\":\\\"center\\\",\\\"justifyContent\\\":\\\"center\\\"},\\\"children\\\":[\\\"$\\\",\\\"div\\\",null,{\\\"children\\\":[[\\\"$\\\",\\\"style\\\",null,{\\\"dangerouslySetInnerHTML\\\":{\\\"__html\\\":\\\"body{color:#000;background:#fff;margin:0}.next-error-h1{border-right:1px solid rgba(0,0,0,.3)}@media (prefers-color-scheme:dark){body{color:#fff;background:#000}.next-error-h1{border-right:1px solid rgba(255,255,255,.3)}}\\\"}},\\\"$d\\\"],[\\\"$\\\",\\\"h1\\\",null,{\\\"className\\\":\\\"next-error-h1\\\",\\\"style\\\":{\\\"display\\\":\\\"inline-block\\\",\\\"margin\\\":\\\"0 20px 0 0\\\",\\\"padding\\\":\\\"0 23px 0 0\\\",\\\"fontSize\\\":24,\\\"fontWeight\\\":500,\\\"verticalAlign\\\":\\\"top\\\",\\\"lineHeight\\\":\\\"49px\\\"},\\\"children\\\":\\\"404\\\"},\\\"$d\\\"],[\\\"$\\\",\\\"div\\\",null,{\\\"style\\\":{\\\"display\\\":\\\"inline-block\\\"},\\\"children\\\":[\\\"$\\\",\\\"h2\\\",null,{\\\"style\\\":{\\\"fontSize\\\":14,\\\"fontWeight\\\":400,\\\"lineHeight\\\":\\\"49px\\\",\\\"margin\\\":0},\\\"children\\\":\\\"This page could not be found.\\\"},\\\"$d\\\"]},\\\"$d\\\"]]},\\\"$d\\\"]},\\\"$d\\\"]]\\n4:[\\\"$\\\",\\\"html\\\",null,{\\\"lang\\\":\\\"en\\\",\\\"children\\\":[\\\"$\\\",\\\"body\\\",null,{\\\"children\\\":[\\\"$\\\",\\\"$L6\\\",null,{\\\"parallelRouterKey\\\":\\\"children\\\",\\\"segmentPath\\\":[\\\"children\\\"],\\\"error\\\":\\\"$undefined\\\",\\\"errorStyles\\\":\\\"$undefined\\\",\\\"errorScripts\\\":\\\"$undefined\\\",\\\"template\\\":[\\\"$\\\",\\\"$L9\\\",null,{},null],\\\"templateStyles\\\":\\\"$undefined\\\",\\\"templateScripts\\\":\\\"$undefined\\\",\\\"notFound\\\":\\\"$c\\\",\\\"notFoundStyles\\\":[]},null]},\\\"$b\\\"]},\\\"$b\\\"]\\nf:W[\\\"error\\\",[],null,\\\"Server\\\",\\\" In route /client a searchParam property was accessed directly with `searchParams.toJSON`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis\\\"]\\n10:W[\\\"error\\\",[],null,\\\"Server\\\",\\\" In route /client a searchParam property was accessed directly with `searchParams.$$typeof`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/d\"])</script><script>self.__next_f.push([1,\"ocs/messages/sync-dynamic-apis\\\"]\\n11:W[\\\"error\\\",[],null,\\\"Server\\\",\\\" In route /client a searchParam property was accessed directly with `searchParams.$$typeof`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis\\\"]\\n12:W[\\\"error\\\",[],null,\\\"Server\\\",\\\" In route /client a searchParam property was accessed directly with `searchParams.status`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis\\\"]\\n13:{\\\"name\\\":\\\"Page\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":null,\\\"owner\\\":null,\\\"props\\\":{\\\"params\\\":\\\"$@\\\",\\\"searchParams\\\":\\\"$@\\\"}}\\ne:D\\\"$13\\\"\\ne:[\\\"$\\\",\\\"h1\\\",null,{\\\"children\\\":[\\\"$\\\",\\\"$L14\\\",null,{},\\\"$13\\\"]},\\\"$13\\\"]\\n17:{\\\"name\\\":\\\"MetadataOutlet\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":null,\\\"owner\\\":null,\\\"props\\\":{\\\"ready\\\":\\\"$E(async function getMetadataAndViewportReady() {\\\\n        await viewport();\\\\n        await metadata();\\\\n        return undefined;\\\\n    })\\\"}}\\n16:D\\\"$17\\\"\\n\"])</script><script>self.__next_f.push([1,\"1f:{\\\"name\\\":\\\"NonIndex\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":null,\\\"owner\\\":null,\\\"props\\\":{\\\"ctx\\\":{\\\"componentMod\\\":{\\\"GlobalError\\\":\\\"$19\\\",\\\"__next_app__\\\":{\\\"require\\\":\\\"$E(function __webpack_require__(moduleId) {\\\\n/******/ \\\\t\\\\t// Check if module is in cache\\\\n/******/ \\\\t\\\\tvar cachedModule = __webpack_module_cache__[moduleId];\\\\n/******/ \\\\t\\\\tif (cachedModule !== undefined) {\\\\n/******/ \\\\t\\\\t\\\\treturn cachedModule.exports;\\\\n/******/ \\\\t\\\\t}\\\\n/******/ \\\\t\\\\t// Create a new module (and put it into the cache)\\\\n/******/ \\\\t\\\\tvar module = __webpack_module_cache__[moduleId] = {\\\\n/******/ \\\\t\\\\t\\\\tid: moduleId,\\\\n/******/ \\\\t\\\\t\\\\tloaded: false,\\\\n/******/ \\\\t\\\\t\\\\texports: {}\\\\n/******/ \\\\t\\\\t};\\\\n/******/ \\\\t\\\\n/******/ \\\\t\\\\t// Execute the module function\\\\n/******/ \\\\t\\\\tvar threw = true;\\\\n/******/ \\\\t\\\\ttry {\\\\n/******/ \\\\t\\\\t\\\\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\\\\n/******/ \\\\t\\\\t\\\\tthrew = false;\\\\n/******/ \\\\t\\\\t} finally {\\\\n/******/ \\\\t\\\\t\\\\tif(threw) delete __webpack_module_cache__[moduleId];\\\\n/******/ \\\\t\\\\t}\\\\n/******/ \\\\t\\\\n/******/ \\\\t\\\\t// Flag the module as loaded\\\\n/******/ \\\\t\\\\tmodule.loaded = true;\\\\n/******/ \\\\t\\\\n/******/ \\\\t\\\\t// Return the exports of the module\\\\n/******/ \\\\t\\\\treturn module.exports;\\\\n/******/ \\\\t})\\\",\\\"loadChunk\\\":\\\"$E(() =\\u003e Promise.resolve())\\\"},\\\"pages\\\":[\\\"/tmp/next-install-e82693b0c1e2696ea71e6942fd12c5650a137067076e9c102681d62a5edd6227/app/client/page.js\\\"],\\\"routeModule\\\":{\\\"userland\\\":{\\\"loaderTree\\\":[\\\"\\\",{\\\"children\\\":\\\"$Y\\\"},\\\"$Y\\\"]},\\\"definition\\\":\\\"$Y\\\"},\\\"tree\\\":\\\"$Y\\\",\\\"ClientPageRoot\\\":\\\"$1a\\\",\\\"ClientSegmentRoot\\\":\\\"$1b\\\",\\\"LayoutRouter\\\":\\\"$6\\\",\\\"MetadataBoundary\\\":\\\"$1c\\\",\\\"NotFoundBoundary\\\":\\\"$1d\\\",\\\"OutletBoundary\\\":\\\"$15\\\",\\\"Postpone\\\":\\\"$E(function Postpone({ reason, route }) {\\\\n    const prerenderStore = _prerenderasyncstorageexternal.prerenderAsyncStorage.getStore();\\\\n    const dynamicTracking = prerenderStore \\u0026\\u0026 prerenderStore.type === 'prerender' ? prerenderStore.dynamicTracking : null;\\\\n    postponeWithTracking(route, reason, dynamicTracking);\\\\n})\\\",\\\"RenderFromTemplateContext\\\":\\\"$9\\\",\\\"ViewportBoundary\\\":\\\"$1e\\\",\\\"actionAsyncStorage\\\":\\\"$Y\\\",\\\"createMetadataComponents\\\":\\\"$E(function createMetadataComponents({ tree, searchParams, metadataContext, getDynamicParamFromSegment, appUsingSizeAdjustment, errorType, createServerParamsForMetadata, workStore, MetadataBoundary, ViewportBoundary }) {\\\\n    function MetadataRoot() {\\\\n        return /*#__PURE__*/ (0, _jsxruntime.jsxs)(_jsxruntime.Fragment, {\\\\n            children: [\\\\n                /*#__PURE__*/ (0, _jsxruntime.jsx)(MetadataBoundary, {\\\\n                    children: /*#__PURE__*/ (0, _jsxruntime.jsx)(Metadata, {})\\\\n                }),\\\\n                /*#__PURE__*/ (0, _jsxruntime.jsx)(ViewportBoundary, {\\\\n                    children: /*#__PURE__*/ (0, _jsxruntime.jsx)(Viewport, {})\\\\n                }),\\\\n                appUsingSizeAdjustment ? /*#__PURE__*/ (0, _jsxruntime.jsx)(\\\\\\\"meta\\\\\\\", {\\\\n                    name: \\\\\\\"next-size-adjust\\\\\\\"\\\\n                }) : null\\\\n            ]\\\\n        });\\\\n    }\\\\n    async function viewport() {\\\\n        return getResolvedViewport(tree, searchParams, getDynamicParamFromSegment, createServerParamsForMetadata, workStore, errorType);\\\\n    }\\\\n    async function Viewport() {\\\\n        try {\\\\n            return await viewport();\\\\n        } catch (error) {\\\\n            if (!errorType \\u0026\\u0026 (0, _notfound.isNotFoundError)(error)) {\\\\n                try {\\\\n                    return await getNotFoundViewport(tree, searchParams, getDynamicParamFromSegment, createServerParamsForMetadata, workStore);\\\\n                } catch  {}\\\\n            }\\\\n            // We don't actually want to error in this component. We will\\\\n            // also error in the MetadataOutlet which causes the error to\\\\n            // bubble from the right position in the page to be caught by the\\\\n            // appropriate boundaries\\\\n            return null;\\\\n        }\\\\n    }\\\\n    async function metadata() {\\\\n        return getResolvedMetadata(tree, searchParams, getDynamicParamFromSegment, metadataContext, createServerParamsForMetadata, workStore, errorType);\\\\n    }\\\\n    async function Metadata() {\\\\n        try {\\\\n            return await metadata();\\\\n        } catch (error) {\\\\n            if (!errorType \\u0026\\u0026 (0, _notfound.isNotFoundError)(error)) {\\\\n                try {\\\\n                    return await getNotFoundMetadata(tree, searchParams, getDynamicParamFromSegment, metadataContext, createServerParamsForMetadata, workStore);\\\\n                } catch  {}\\\\n            }\\\\n            // We don't actually want to error in this component. We will\\\\n            // also error in the MetadataOutlet which causes the error to\\\\n            // bubble from the right position in the page to be caught by the\\\\n            // appropriate boundaries\\\\n            return null;\\\\n        }\\\\n    }\\\\n    async function getMetadataAndViewportReady() {\\\\n        await viewport();\\\\n        await metadata();\\\\n        return undefined;\\\\n    }\\\\n    return [\\\\n        MetadataRoot,\\\\n        getMetadataAndViewportReady\\\\n    ];\\\\n})\\\",\\\"createPrerenderParamsForClientSegment\\\":\\\"$E(function createPrerenderParamsForClientSegment(underlyingParams, workStore) {\\\\n    const prerenderStore = _prerenderasyncstorageexternal.prerenderAsyncStorage.getStore();\\\\n    if (prerenderStore \\u0026\\u0026 prerenderStore.type === 'prerender') {\\\\n        if ((0, _prerenderasyncstorageexternal.isDynamicIOPrerender)(prerenderStore)) {\\\\n            const fallbackParams = workStore.fallbackRouteParams;\\\\n            if (fallbackParams) {\\\\n                for(let key in underlyingParams){\\\\n                    if (fallbackParams.has(key)) {\\\\n                        // This params object has one of more fallback params so we need to consider\\\\n                        // the awaiting of this params object \\\\\\\"dynamic\\\\\\\". Since we are in dynamicIO mode\\\\n                        // we encode this as a promise that never resolves\\\\n                        return (0, _dynamicrenderingutils.makeHangingPromise)();\\\\n                    }\\\\n                }\\\\n            }\\\\n        }\\\\n    }\\\\n    // We're prerendering in a mode that does not abort. We resolve the promise without\\\\n    // any tracking because we're just transporting a value from server to client where the tracking\\\\n    // will be applied.\\\\n    return (0, _utils.makeResolvedReactPromise)(underlyingParams);\\\\n})\\\",\\\"createPrerenderSearchParamsForClientPage\\\":\\\"$E(function createPrerenderSearchParamsForClientPage(workStore) {\\\\n    if (workStore.forceStatic) {\\\\n        // When using forceStatic we override all other logic and always just return an empty\\\\n        // dictionary object.\\\\n        return Promise.resolve({});\\\\n    }\\\\n    const prerenderStore = _prerenderasyncstorageexternal.prerenderAsyncStorage.getStore();\\\\n    if (prerenderStore) {\\\\n        if ((0, _prerenderasyncstorageexternal.isDynamicIOPrerender)(prerenderStore)) {\\\\n            // We're prerendering in a mode that aborts (dynamicIO) and should stall\\\\n            // the promise to ensure the RSC side is considered dynamic\\\\n            return (0, _dynamicrenderingutils.makeHangingPromise)();\\\\n        }\\\\n    }\\\\n    // We're prerendering in a mode that does not aborts. We resolve the promise without\\\\n    // any tracking because we're just transporting a value from server to client where the tracking\\\\n    // will be applied.\\\\n    return Promise.resolve({});\\\\n})\\\",\\\"createServerParamsForMetadata\\\":\\\"$E(function createServerParamsForServerSegment(underlyingParams, workStore) {\\\\n    if (workStore.isStaticGeneration) {\\\\n        return createPrerenderParams(underlyingParams, workStore);\\\\n    } else {\\\\n        return createRenderParams(underlyingParams, workStore);\\\\n    }\\\\n})\\\",\\\"createServerParamsForServerSegment\\\":\\\"$E(function createServerParamsForServerSegment(underlyingParams, workStore) {\\\\n    if (workStore.isStaticGeneration) {\\\\n        return createPrerenderParams(underlyingParams, workStore);\\\\n    } else {\\\\n        return createRenderParams(underlyingParams, workStore);\\\\n    }\\\\n})\\\",\\\"createServerSearchParamsForMetadata\\\":\\\"$E(function createServerSearchParamsForServerPage(underlyingSearchParams, workStore) {\\\\n    if (workStore.isStaticGeneration) {\\\\n        return createPrerenderSearchParams(workStore);\\\\n    } else {\\\\n        return createRenderSearchParams(underlyingSearchParams, workStore);\\\\n    }\\\\n})\\\",\\\"createServerSearchParamsForServerPage\\\":\\\"$E(function createServerSearchParamsForServerPage(underlyingSearchParams, workStore) {\\\\n    if (workStore.isStaticGeneration) {\\\\n        return createPrerenderSearchParams(workStore);\\\\n    } else {\\\\n        return createRenderSearchParams(underlyingSearchParams, workStore);\\\\n    }\\\\n})\\\",\\\"decodeAction\\\":\\\"$E(function(body,serverManifest){var formData=new FormData,action=null;return body.forEach(function(value,key){key.startsWith(\\\\\\\"$ACTION_\\\\\\\")?key.startsWith(\\\\\\\"$ACTION_REF_\\\\\\\")?(value=decodeBoundActionMetaData(body,serverManifest,value=\\\\\\\"$ACTION_\\\\\\\"+key.slice(12)+\\\\\\\":\\\\\\\"),action=loadServerReference(serverManifest,value.id,value.bound)):key.startsWith(\\\\\\\"$ACTION_ID_\\\\\\\")\\u0026\\u0026(action=loadServerReference(serverManifest,value=key.slice(11),null)):formData.append(key,value)}),null===action?null:action.then(function(fn){return fn.bind(null,formData)})})\\\",\\\"decodeFormState\\\":\\\"$E(function(actionResult,body,serverManifest){var keyPath=body.get(\\\\\\\"$ACTION_KEY\\\\\\\");if(\\\\\\\"string\\\\\\\"!=typeof keyPath)return Promise.resolve(null);var metaData=null;if(body.forEach(function(value,key){key.startsWith(\\\\\\\"$ACTION_REF_\\\\\\\")\\u0026\\u0026(metaData=decodeBoundActionMetaData(body,serverManifest,\\\\\\\"$ACTION_\\\\\\\"+key.slice(12)+\\\\\\\":\\\\\\\"))}),null===metaData)return Promise.resolve(null);var referenceId=metaData.id;return Promise.resolve(metaData.bound).then(function(bound){return null===bound?null:[actionResult,keyPath,referenceId,bound.length-1]})})\\\",\\\"decodeReply\\\":\\\"$E(function(body,webpackMap,options){if(\\\\\\\"string\\\\\\\"==typeof body){var form=new FormData;form.append(\\\\\\\"0\\\\\\\",body),body=form}return webpackMap=getChunk(body=createResponse(webpackMap,\\\\\\\"\\\\\\\",options?options.temporaryReferences:void 0,body),0),close(body),webpackMap})\\\",\\\"patchFetch\\\":\\\"$E(function patchFetch() {\\\\n    return (0, _patchfetch.patchFetch)({\\\\n        workAsyncStorage: _workasyncstorageexternal.workAsyncStorage,\\\\n        requestAsyncStorage: _requestasyncstorageexternal.requestAsyncStorage,\\\\n        prerenderAsyncStorage: _prerenderasyncstorageexternal.prerenderAsyncStorage\\\\n    });\\\\n})\\\",\\\"preconnect\\\":\\\"$E(function preconnect(href, crossOrigin, nonce) {\\\\n    const opts = {};\\\\n    if (typeof crossOrigin === 'string') {\\\\n        opts.crossOrigin = crossOrigin;\\\\n    }\\\\n    if (typeof nonce === 'string') {\\\\n        opts.nonce = nonce;\\\\n    }\\\\n    _reactdom.default.preconnect(href, opts);\\\\n})\\\",\\\"preloadFont\\\":\\\"$E(function preloadFont(href, type, crossOrigin, nonce) {\\\\n    const opts = {\\\\n        as: 'font',\\\\n        type\\\\n    };\\\\n    if (typeof crossOrigin === 'string') {\\\\n        opts.crossOrigin = crossOrigin;\\\\n    }\\\\n    if (typeof nonce === 'string') {\\\\n        opts.nonce = nonce;\\\\n    }\\\\n    _reactdom.default.preload(href, opts);\\\\n})\\\",\\\"preloadStyle\\\":\\\"$E(function preloadStyle(href, crossOrigin, nonce) {\\\\n    const opts = {\\\\n        as: 'style'\\\\n    };\\\\n    if (typeof crossOrigin === 'string') {\\\\n        opts.crossOrigin = crossOrigin;\\\\n    }\\\\n    if (typeof nonce === 'string') {\\\\n        opts.nonce = nonce;\\\\n    }\\\\n    _reactdom.default.preload(href, opts);\\\\n})\\\",\\\"prerender\\\":\\\"$undefined\\\",\\\"renderToReadableStream\\\":\\\"$E(function(model,webpackMap,options){var request=new RequestInstance(20,model,webpackMap,options?options.onError:void 0,options?options.identifierPrefix:void 0,options?options.onPostpone:void 0,options?options.temporaryReferences:void 0,options?options.environmentName:void 0,options?options.filterStackFrame:void 0,noop,noop);if(options\\u0026\\u0026options.signal){var signal=options.signal;if(signal.aborted)abort(request,signal.reason);else{var listener=function(){abort(request,signal.reason),signal.removeEventListener(\\\\\\\"abort\\\\\\\",listener)};signal.addEventListener(\\\\\\\"abort\\\\\\\",listener)}}return new ReadableStream({type:\\\\\\\"bytes\\\\\\\",start:function(){request.flushScheduled=null!==request.destination,supportsRequestStorage?scheduleMicrotask(function(){requestStorage.run(request,performWork,request)}):scheduleMicrotask(function(){return performWork(request)}),setTimeoutOrImmediate(function(){request.status===OPENING\\u0026\\u0026(request.status=11)},0)},pull:function(controller){if(request.status===CLOSING)request.status=CLOSED,closeWithError(controller,request.fatalError);else if(request.status!==CLOSED\\u0026\\u0026null===request.destination){request.destination=controller;try{flushCompletedChunks(request,controller)}catch(error){logRecoverableError(request,error,null),fatalError(request,error)}}},cancel:function(reason){request.destination=null,abort(request,reason)}},{highWaterMark:0})})\\\",\\\"requestAsyncStorage\\\":\\\"$Y\\\",\\\"serverHooks\\\":\\\"$Y\\\",\\\"taintObjectReference\\\":\\\"$E(function notImplemented() {\\\\n    throw new Error('Taint can only be used with the taint flag.');\\\\n})\\\",\\\"workAsyncStorage\\\":\\\"$Y\\\"},\\\"renderOpts\\\":\\\"$Y\\\",\\\"requestStore\\\":\\\"$Y\\\",\\\"workStore\\\":\\\"$Y\\\",\\\"parsedRequestHeaders\\\":\\\"$Y\\\",\\\"getDynamicParamFromSegment\\\":\\\"$E(function(segment){let segmentParam=getSegmentParam(segment);if(!segmentParam)return null;let key=segmentParam.param,value=params[key];if(fallbackRouteParams\\u0026\\u0026fallbackRouteParams.has(segmentParam.param)?value=fallbackRouteParams.get(segmentParam.param):Array.isArray(value)?value=value.map(i=\\u003eencodeURIComponent(i)):\\\\\\\"string\\\\\\\"==typeof value\\u0026\\u0026(value=encodeURIComponent(value)),!value){let isCatchall=\\\\\\\"catchall\\\\\\\"===segmentParam.type,isOptionalCatchall=\\\\\\\"optional-catchall\\\\\\\"===segmentParam.type;if(isCatchall||isOptionalCatchall){let dynamicParamType=dynamicParamTypes[segmentParam.type];return isOptionalCatchall?{param:key,value:null,type:dynamicParamType,treeSegment:[key,\\\\\\\"\\\\\\\",dynamicParamType]}:{param:key,value:value=pagePath.split(\\\\\\\"/\\\\\\\").slice(1).flatMap(pathSegment=\\u003e{let param=function(param){let match=param.match(PARAMETER_PATTERN);return match?parseMatchedParameter(match[1]):parseMatchedParameter(param)}(pathSegment);return params[param.key]??param.key}),type:dynamicParamType,treeSegment:[key,value.join(\\\\\\\"/\\\\\\\"),dynamicParamType]}}}let type=function(type){let short=dynamicParamTypes[type];if(!short)throw Error(\\\\\\\"Unknown dynamic param type\\\\\\\");return short}(segmentParam.type);return{param:key,value:value,treeSegment:[key,Array.isArray(value)?value.join(\\\\\\\"/\\\\\\\"):value,type],type:type}})\\\",\\\"query\\\":\\\"$Y\\\",\\\"isPrefetch\\\":false,\\\"isAction\\\":false,\\\"requestTimestamp\\\":1728059369436,\\\"appUsingSizeAdjustment\\\":false,\\\"flightRouterState\\\":\\\"$undefined\\\",\\\"requestId\\\":\\\"Ys4W_iM7jcLubMRBhfFx9\\\",\\\"defaultRevalidate\\\":false,\\\"pagePath\\\":\\\"/client\\\",\\\"clientReferenceManifest\\\":\\\"$Y\\\",\\\"assetPrefix\\\":\\\"\\\",\\\"isNotFoundPath\\\":false,\\\"nonce\\\":\\\"$undefined\\\",\\\"res\\\":\\\"$Y\\\"}}}\\n\"])</script><script>self.__next_f.push([1,\"18:D\\\"$1f\\\"\\n18:null\\n21:{\\\"name\\\":\\\"MetadataRoot\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":\\\"Ys4W_iM7jcLubMRBhfFx9\\\",\\\"owner\\\":null,\\\"props\\\":{}}\\n20:D\\\"$21\\\"\\n23:{\\\"name\\\":\\\"Metadata\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":null,\\\"owner\\\":\\\"$21\\\",\\\"props\\\":{}}\\n22:D\\\"$23\\\"\\n25:{\\\"name\\\":\\\"Viewport\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":null,\\\"owner\\\":\\\"$21\\\",\\\"props\\\":{}}\\n24:D\\\"$25\\\"\\n20:[\\\"$\\\",\\\"$3\\\",\\\"Ys4W_iM7jcLubMRBhfFx9\\\",{\\\"children\\\":[[\\\"$\\\",\\\"$L1c\\\",null,{\\\"children\\\":\\\"$L22\\\"},\\\"$21\\\"],[\\\"$\\\",\\\"$L1e\\\",null,{\\\"children\\\":\\\"$L24\\\"},\\\"$21\\\"],null]},null]\\n26:[]\\n0:{\\\"P\\\":\\\"$1\\\",\\\"b\\\":\\\"development\\\",\\\"p\\\":\\\"\\\",\\\"c\\\":[\\\"\\\",\\\"client\\\"],\\\"i\\\":false,\\\"f\\\":[[[\\\"\\\",{\\\"children\\\":[\\\"client\\\",{\\\"children\\\":[\\\"__PAGE__\\\",{}]}]},\\\"$undefined\\\",\\\"$undefined\\\",true],[\\\"\\\",[\\\"$\\\",\\\"$3\\\",\\\"c\\\",{\\\"children\\\":[null,\\\"$4\\\"]},null],{\\\"children\\\":[\\\"client\\\",[\\\"$\\\",\\\"$3\\\",\\\"c\\\",{\\\"children\\\":[null,[\\\"$\\\",\\\"$L6\\\",null,{\\\"parallelRouterKey\\\":\\\"children\\\",\\\"segmentPath\\\":[\\\"children\\\",\\\"client\\\",\\\"children\\\"],\\\"error\\\":\\\"$undefined\\\",\\\"errorStyles\\\":\\\"$undefined\\\",\\\"errorScripts\\\":\\\"$undefined\\\",\\\"template\\\":[\\\"$\\\",\\\"$L9\\\",null,{},null],\\\"templateStyles\\\":\\\"$undefined\\\",\\\"templateScripts\\\":\\\"$undefined\\\",\\\"notFound\\\":\\\"$undefined\\\",\\\"notFoundStyles\\\":\\\"$undefined\\\"},null]]},null],{\\\"children\\\":[\\\"__PAGE__\\\",[\\\"$\\\",\\\"$3\\\",\\\"c\\\",{\\\"children\\\":[\\\"$e\\\",null,[\\\"$\\\",\\\"$L15\\\",null,{\\\"children\\\":\\\"$L16\\\"},null]]},null],{},null]},null]},null],[\\\"$\\\",\\\"$3\\\",\\\"h\\\",{\\\"children\\\":[\\\"$18\\\",\\\"$20\\\"]},null]]],\\\"m\\\":\\\"$W26\\\",\\\"G\\\":\\\"$19\\\",\\\"s\\\":false,\\\"S\\\":false}\\n24:[[\\\"$\\\",\\\"meta\\\",\\\"0\\\",{\\\"name\\\":\\\"viewport\\\",\\\"content\\\":\\\"width=device-width, initial-scale=1\\\"},\\\"$17\\\"]]\\n22:[[\\\"$\\\",\\\"meta\\\",\\\"0\\\",{\\\"charSet\\\":\\\"utf-8\\\"},\\\"$23\\\"],[\\\"$\\\",\\\"title\\\",\\\"1\\\",{\\\"children\\\":\\\"Next.js\\\"},\\\"$23\\\"],[\\\"$\\\",\\\"meta\\\",\\\"2\\\",{\\\"name\\\":\\\"description\\\",\\\"content\\\":\\\"Generated by Next.js\\\"},\\\"$23\\\"]]\\n16:null\\n\"])</script></body></html>"

  118 |       it('should not break "use client" directive in optimized packages', async () => {
  119 |         const html = await next.render('/client')
> 120 |         expect(html).toContain('this is a client component')
      |                      ^
  121 |       })
  122 |
  123 |       it('should support "use client" directive in barrel file', async () => {

  at Object.toContain (development/basic/barrel-optimization/barrel-optimization.test.ts:120:22)

● Skipped in Turbopack › optimizePackageImports - basic › should support "use client" directive in barrel file

expect(received).toContain(expected) // indexOf

Expected substring: "<button>0</button>"
Received string:    "<!DOCTYPE html><html id=\"__next_error__\"><head><meta charSet=\"utf-8\"/><meta name=\"viewport\" content=\"width=device-width, initial-scale=1\"/><link rel=\"preload\" as=\"script\" fetchPriority=\"low\" href=\"/_next/static/chunks/webpack.js\"/><script src=\"/_next/static/chunks/main-app.js\" async=\"\"></script><script src=\"/_next/static/chunks/app-pages-internals.js\" async=\"\"></script><meta name=\"robots\" content=\"noindex\"/><meta name=\"next-error\" content=\"not-found\"/><title>Next.js</title><meta name=\"description\" content=\"Generated by Next.js\"/><script src=\"/_next/static/chunks/polyfills.js\" noModule=\"\"></script></head><body><script src=\"/_next/static/chunks/webpack.js\" async=\"\"></script><script>(self.__next_f=self.__next_f||[]).push([0])</script><script>self.__next_f.push([1,\"3:\\\"$Sreact.fragment\\\"\\n5:\\\"$Sreact.transitional.element\\\"\\n6:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/client/components/layout-router.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-internals.js\\\"],\\\"\\\"]\\n7:\\\"$Sreact.transitional.element\\\"\\n8:\\\"$Sreact.transitional.element\\\"\\n9:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/client/components/render-from-template-context.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-internals.js\\\"],\\\"\\\"]\\na:\\\"$Sreact.transitional.element\\\"\\n14:I[\\\"(app-pages-browser)/__barrel_optimize__?names=Button!=!./node_modules/my-client-lib/index.js\\\",[\\\"app/client-boundary/page\\\",\\\"static/chunks/app/client-boundary/page.js\\\"],\\\"Button\\\",1]\\n15:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/lib/metadata/metadata-boundary.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-internals.js\\\"],\\\"OutletBoundary\\\"]\\n19:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/client/components/error-boundary.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-internals.js\\\"],\\\"\\\"]\\n1a:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/client/components/client-page.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-internals.js\\\"],\\\"ClientPageRoot\\\"]\\n1b:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/client/com\"])</script><script>self.__next_f.push([1,\"ponents/client-segment.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-internals.js\\\"],\\\"ClientSegmentRoot\\\"]\\n1c:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/lib/metadata/metadata-boundary.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-internals.js\\\"],\\\"MetadataBoundary\\\"]\\n1d:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/client/components/not-found-boundary.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-internals.js\\\"],\\\"NotFoundBoundary\\\"]\\n1e:I[\\\"(app-pages-browser)/./node_modules/.pnpm/file+..+next-repo-b28ea5b05fccdc544d8defc63c2adafcb02e357dd6548163ce85400df023ab94+packages+n_ronhpzfqnlkocyy74bg7f4guoi/node_modules/next/dist/lib/metadata/metadata-boundary.js\\\",[\\\"app-pages-internals\\\",\\\"static/chunks/app-pages-internals.js\\\"],\\\"ViewportBoundary\\\"]\\n2:{\\\"name\\\":\\\"Preloads\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":null,\\\"owner\\\":null,\\\"props\\\":{\\\"preloadCallbacks\\\":[]}}\\n1:D\\\"$2\\\"\\n1:null\\n\"])</script><script>self.__next_f.push([1,\"b:{\\\"name\\\":\\\"RootLayout\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":null,\\\"owner\\\":null,\\\"props\\\":{\\\"children\\\":[\\\"$5\\\",\\\"$L6\\\",null,{\\\"parallelRouterKey\\\":\\\"children\\\",\\\"segmentPath\\\":[\\\"children\\\"],\\\"error\\\":\\\"$undefined\\\",\\\"errorStyles\\\":\\\"$undefined\\\",\\\"errorScripts\\\":\\\"$undefined\\\",\\\"template\\\":[\\\"$7\\\",\\\"$3\\\",null,{\\\"children\\\":[\\\"$8\\\",\\\"$L9\\\",null,{},null]},null],\\\"templateStyles\\\":\\\"$undefined\\\",\\\"templateScripts\\\":\\\"$undefined\\\",\\\"notFound\\\":[\\\"$a\\\",\\\"$E(function NotFound() {\\\\n    return /*#__PURE__*/ (0, _jsxruntime.jsxs)(_jsxruntime.Fragment, {\\\\n        children: [\\\\n            /*#__PURE__*/ (0, _jsxruntime.jsx)(\\\\\\\"title\\\\\\\", {\\\\n                children: \\\\\\\"404: This page could not be found.\\\\\\\"\\\\n            }),\\\\n            /*#__PURE__*/ (0, _jsxruntime.jsx)(\\\\\\\"div\\\\\\\", {\\\\n                style: styles.error,\\\\n                children: /*#__PURE__*/ (0, _jsxruntime.jsxs)(\\\\\\\"div\\\\\\\", {\\\\n                    children: [\\\\n                        /*#__PURE__*/ (0, _jsxruntime.jsx)(\\\\\\\"style\\\\\\\", {\\\\n                            dangerouslySetInnerHTML: {\\\\n                                /* Minified CSS from\\\\n                body { margin: 0; color: #000; background: #fff; }\\\\n                .next-error-h1 {\\\\n                  border-right: 1px solid rgba(0, 0, 0, .3);\\\\n                }\\\\n\\\\n                @media (prefers-color-scheme: dark) {\\\\n                  body { color: #fff; background: #000; }\\\\n                  .next-error-h1 {\\\\n                    border-right: 1px solid rgba(255, 255, 255, .3);\\\\n                  }\\\\n                }\\\\n              */ __html: \\\\\\\"body{color:#000;background:#fff;margin:0}.next-error-h1{border-right:1px solid rgba(0,0,0,.3)}@media (prefers-color-scheme:dark){body{color:#fff;background:#000}.next-error-h1{border-right:1px solid rgba(255,255,255,.3)}}\\\\\\\"\\\\n                            }\\\\n                        }),\\\\n                        /*#__PURE__*/ (0, _jsxruntime.jsx)(\\\\\\\"h1\\\\\\\", {\\\\n                            className: \\\\\\\"next-error-h1\\\\\\\",\\\\n                            style: styles.h1,\\\\n                            children: \\\\\\\"404\\\\\\\"\\\\n                        }),\\\\n                        /*#__PURE__*/ (0, _jsxruntime.jsx)(\\\\\\\"div\\\\\\\", {\\\\n                            style: styles.desc,\\\\n                            children: /*#__PURE__*/ (0, _jsxruntime.jsx)(\\\\\\\"h2\\\\\\\", {\\\\n                                style: styles.h2,\\\\n                                children: \\\\\\\"This page could not be found.\\\\\\\"\\\\n                            })\\\\n                        })\\\\n                    ]\\\\n                })\\\\n            })\\\\n        ]\\\\n    });\\\\n})\\\",null,\\\"$Y\\\",null],\\\"notFoundStyles\\\":\\\"$Y\\\"},null],\\\"params\\\":\\\"$Y\\\"}}\\n\"])</script><script>self.__next_f.push([1,\"4:D\\\"$b\\\"\\nd:{\\\"name\\\":\\\"NotFound\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":null,\\\"owner\\\":null,\\\"props\\\":{}}\\nc:D\\\"$d\\\"\\nc:[[\\\"$\\\",\\\"title\\\",null,{\\\"children\\\":\\\"404: This page could not be found.\\\"},\\\"$d\\\"],[\\\"$\\\",\\\"div\\\",null,{\\\"style\\\":{\\\"fontFamily\\\":\\\"system-ui,\\\\\\\"Segoe UI\\\\\\\",Roboto,Helvetica,Arial,sans-serif,\\\\\\\"Apple Color Emoji\\\\\\\",\\\\\\\"Segoe UI Emoji\\\\\\\"\\\",\\\"height\\\":\\\"100vh\\\",\\\"textAlign\\\":\\\"center\\\",\\\"display\\\":\\\"flex\\\",\\\"flexDirection\\\":\\\"column\\\",\\\"alignItems\\\":\\\"center\\\",\\\"justifyContent\\\":\\\"center\\\"},\\\"children\\\":[\\\"$\\\",\\\"div\\\",null,{\\\"children\\\":[[\\\"$\\\",\\\"style\\\",null,{\\\"dangerouslySetInnerHTML\\\":{\\\"__html\\\":\\\"body{color:#000;background:#fff;margin:0}.next-error-h1{border-right:1px solid rgba(0,0,0,.3)}@media (prefers-color-scheme:dark){body{color:#fff;background:#000}.next-error-h1{border-right:1px solid rgba(255,255,255,.3)}}\\\"}},\\\"$d\\\"],[\\\"$\\\",\\\"h1\\\",null,{\\\"className\\\":\\\"next-error-h1\\\",\\\"style\\\":{\\\"display\\\":\\\"inline-block\\\",\\\"margin\\\":\\\"0 20px 0 0\\\",\\\"padding\\\":\\\"0 23px 0 0\\\",\\\"fontSize\\\":24,\\\"fontWeight\\\":500,\\\"verticalAlign\\\":\\\"top\\\",\\\"lineHeight\\\":\\\"49px\\\"},\\\"children\\\":\\\"404\\\"},\\\"$d\\\"],[\\\"$\\\",\\\"div\\\",null,{\\\"style\\\":{\\\"display\\\":\\\"inline-block\\\"},\\\"children\\\":[\\\"$\\\",\\\"h2\\\",null,{\\\"style\\\":{\\\"fontSize\\\":14,\\\"fontWeight\\\":400,\\\"lineHeight\\\":\\\"49px\\\",\\\"margin\\\":0},\\\"children\\\":\\\"This page could not be found.\\\"},\\\"$d\\\"]},\\\"$d\\\"]]},\\\"$d\\\"]},\\\"$d\\\"]]\\n4:[\\\"$\\\",\\\"html\\\",null,{\\\"lang\\\":\\\"en\\\",\\\"children\\\":[\\\"$\\\",\\\"body\\\",null,{\\\"children\\\":[\\\"$\\\",\\\"$L6\\\",null,{\\\"parallelRouterKey\\\":\\\"children\\\",\\\"segmentPath\\\":[\\\"children\\\"],\\\"error\\\":\\\"$undefined\\\",\\\"errorStyles\\\":\\\"$undefined\\\",\\\"errorScripts\\\":\\\"$undefined\\\",\\\"template\\\":[\\\"$\\\",\\\"$L9\\\",null,{},null],\\\"templateStyles\\\":\\\"$undefined\\\",\\\"templateScripts\\\":\\\"$undefined\\\",\\\"notFound\\\":\\\"$c\\\",\\\"notFoundStyles\\\":[]},null]},\\\"$b\\\"]},\\\"$b\\\"]\\nf:W[\\\"error\\\",[],null,\\\"Server\\\",\\\" In route /client-boundary a searchParam property was accessed directly with `searchParams.toJSON`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis\\\"]\\n10:W[\\\"error\\\",[],null,\\\"Server\\\",\\\" In route /client-boundary a searchParam property was accessed directly with `searchParams.$$typeof`. `searchParams` should be awaited before accessing properties. Learn more: ht\"])</script><script>self.__next_f.push([1,\"tps://nextjs.org/docs/messages/sync-dynamic-apis\\\"]\\n11:W[\\\"error\\\",[],null,\\\"Server\\\",\\\" In route /client-boundary a searchParam property was accessed directly with `searchParams.$$typeof`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis\\\"]\\n12:W[\\\"error\\\",[],null,\\\"Server\\\",\\\" In route /client-boundary a searchParam property was accessed directly with `searchParams.status`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis\\\"]\\n13:{\\\"name\\\":\\\"Page\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":null,\\\"owner\\\":null,\\\"props\\\":{\\\"params\\\":\\\"$@\\\",\\\"searchParams\\\":\\\"$@\\\"}}\\ne:D\\\"$13\\\"\\ne:[\\\"$\\\",\\\"$L14\\\",null,{},\\\"$13\\\"]\\n17:{\\\"name\\\":\\\"MetadataOutlet\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":null,\\\"owner\\\":null,\\\"props\\\":{\\\"ready\\\":\\\"$E(async function getMetadataAndViewportReady() {\\\\n        await viewport();\\\\n        await metadata();\\\\n        return undefined;\\\\n    })\\\"}}\\n16:D\\\"$17\\\"\\n\"])</script><script>self.__next_f.push([1,\"1f:{\\\"name\\\":\\\"NonIndex\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":null,\\\"owner\\\":null,\\\"props\\\":{\\\"ctx\\\":{\\\"componentMod\\\":{\\\"GlobalError\\\":\\\"$19\\\",\\\"__next_app__\\\":{\\\"require\\\":\\\"$E(function __webpack_require__(moduleId) {\\\\n/******/ \\\\t\\\\t// Check if module is in cache\\\\n/******/ \\\\t\\\\tvar cachedModule = __webpack_module_cache__[moduleId];\\\\n/******/ \\\\t\\\\tif (cachedModule !== undefined) {\\\\n/******/ \\\\t\\\\t\\\\treturn cachedModule.exports;\\\\n/******/ \\\\t\\\\t}\\\\n/******/ \\\\t\\\\t// Create a new module (and put it into the cache)\\\\n/******/ \\\\t\\\\tvar module = __webpack_module_cache__[moduleId] = {\\\\n/******/ \\\\t\\\\t\\\\tid: moduleId,\\\\n/******/ \\\\t\\\\t\\\\tloaded: false,\\\\n/******/ \\\\t\\\\t\\\\texports: {}\\\\n/******/ \\\\t\\\\t};\\\\n/******/ \\\\t\\\\n/******/ \\\\t\\\\t// Execute the module function\\\\n/******/ \\\\t\\\\tvar threw = true;\\\\n/******/ \\\\t\\\\ttry {\\\\n/******/ \\\\t\\\\t\\\\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\\\\n/******/ \\\\t\\\\t\\\\tthrew = false;\\\\n/******/ \\\\t\\\\t} finally {\\\\n/******/ \\\\t\\\\t\\\\tif(threw) delete __webpack_module_cache__[moduleId];\\\\n/******/ \\\\t\\\\t}\\\\n/******/ \\\\t\\\\n/******/ \\\\t\\\\t// Flag the module as loaded\\\\n/******/ \\\\t\\\\tmodule.loaded = true;\\\\n/******/ \\\\t\\\\n/******/ \\\\t\\\\t// Return the exports of the module\\\\n/******/ \\\\t\\\\treturn module.exports;\\\\n/******/ \\\\t})\\\",\\\"loadChunk\\\":\\\"$E(() =\\u003e Promise.resolve())\\\"},\\\"pages\\\":[\\\"/tmp/next-install-e82693b0c1e2696ea71e6942fd12c5650a137067076e9c102681d62a5edd6227/app/client-boundary/page.js\\\"],\\\"routeModule\\\":{\\\"userland\\\":{\\\"loaderTree\\\":[\\\"\\\",{\\\"children\\\":\\\"$Y\\\"},\\\"$Y\\\"]},\\\"definition\\\":\\\"$Y\\\"},\\\"tree\\\":\\\"$Y\\\",\\\"ClientPageRoot\\\":\\\"$1a\\\",\\\"ClientSegmentRoot\\\":\\\"$1b\\\",\\\"LayoutRouter\\\":\\\"$6\\\",\\\"MetadataBoundary\\\":\\\"$1c\\\",\\\"NotFoundBoundary\\\":\\\"$1d\\\",\\\"OutletBoundary\\\":\\\"$15\\\",\\\"Postpone\\\":\\\"$E(function Postpone({ reason, route }) {\\\\n    const prerenderStore = _prerenderasyncstorageexternal.prerenderAsyncStorage.getStore();\\\\n    const dynamicTracking = prerenderStore \\u0026\\u0026 prerenderStore.type === 'prerender' ? prerenderStore.dynamicTracking : null;\\\\n    postponeWithTracking(route, reason, dynamicTracking);\\\\n})\\\",\\\"RenderFromTemplateContext\\\":\\\"$9\\\",\\\"ViewportBoundary\\\":\\\"$1e\\\",\\\"actionAsyncStorage\\\":\\\"$Y\\\",\\\"createMetadataComponents\\\":\\\"$E(function createMetadataComponents({ tree, searchParams, metadataContext, getDynamicParamFromSegment, appUsingSizeAdjustment, errorType, createServerParamsForMetadata, workStore, MetadataBoundary, ViewportBoundary }) {\\\\n    function MetadataRoot() {\\\\n        return /*#__PURE__*/ (0, _jsxruntime.jsxs)(_jsxruntime.Fragment, {\\\\n            children: [\\\\n                /*#__PURE__*/ (0, _jsxruntime.jsx)(MetadataBoundary, {\\\\n                    children: /*#__PURE__*/ (0, _jsxruntime.jsx)(Metadata, {})\\\\n                }),\\\\n                /*#__PURE__*/ (0, _jsxruntime.jsx)(ViewportBoundary, {\\\\n                    children: /*#__PURE__*/ (0, _jsxruntime.jsx)(Viewport, {})\\\\n                }),\\\\n                appUsingSizeAdjustment ? /*#__PURE__*/ (0, _jsxruntime.jsx)(\\\\\\\"meta\\\\\\\", {\\\\n                    name: \\\\\\\"next-size-adjust\\\\\\\"\\\\n                }) : null\\\\n            ]\\\\n        });\\\\n    }\\\\n    async function viewport() {\\\\n        return getResolvedViewport(tree, searchParams, getDynamicParamFromSegment, createServerParamsForMetadata, workStore, errorType);\\\\n    }\\\\n    async function Viewport() {\\\\n        try {\\\\n            return await viewport();\\\\n        } catch (error) {\\\\n            if (!errorType \\u0026\\u0026 (0, _notfound.isNotFoundError)(error)) {\\\\n                try {\\\\n                    return await getNotFoundViewport(tree, searchParams, getDynamicParamFromSegment, createServerParamsForMetadata, workStore);\\\\n                } catch  {}\\\\n            }\\\\n            // We don't actually want to error in this component. We will\\\\n            // also error in the MetadataOutlet which causes the error to\\\\n            // bubble from the right position in the page to be caught by the\\\\n            // appropriate boundaries\\\\n            return null;\\\\n        }\\\\n    }\\\\n    async function metadata() {\\\\n        return getResolvedMetadata(tree, searchParams, getDynamicParamFromSegment, metadataContext, createServerParamsForMetadata, workStore, errorType);\\\\n    }\\\\n    async function Metadata() {\\\\n        try {\\\\n            return await metadata();\\\\n        } catch (error) {\\\\n            if (!errorType \\u0026\\u0026 (0, _notfound.isNotFoundError)(error)) {\\\\n                try {\\\\n                    return await getNotFoundMetadata(tree, searchParams, getDynamicParamFromSegment, metadataContext, createServerParamsForMetadata, workStore);\\\\n                } catch  {}\\\\n            }\\\\n            // We don't actually want to error in this component. We will\\\\n            // also error in the MetadataOutlet which causes the error to\\\\n            // bubble from the right position in the page to be caught by the\\\\n            // appropriate boundaries\\\\n            return null;\\\\n        }\\\\n    }\\\\n    async function getMetadataAndViewportReady() {\\\\n        await viewport();\\\\n        await metadata();\\\\n        return undefined;\\\\n    }\\\\n    return [\\\\n        MetadataRoot,\\\\n        getMetadataAndViewportReady\\\\n    ];\\\\n})\\\",\\\"createPrerenderParamsForClientSegment\\\":\\\"$E(function createPrerenderParamsForClientSegment(underlyingParams, workStore) {\\\\n    const prerenderStore = _prerenderasyncstorageexternal.prerenderAsyncStorage.getStore();\\\\n    if (prerenderStore \\u0026\\u0026 prerenderStore.type === 'prerender') {\\\\n        if ((0, _prerenderasyncstorageexternal.isDynamicIOPrerender)(prerenderStore)) {\\\\n            const fallbackParams = workStore.fallbackRouteParams;\\\\n            if (fallbackParams) {\\\\n                for(let key in underlyingParams){\\\\n                    if (fallbackParams.has(key)) {\\\\n                        // This params object has one of more fallback params so we need to consider\\\\n                        // the awaiting of this params object \\\\\\\"dynamic\\\\\\\". Since we are in dynamicIO mode\\\\n                        // we encode this as a promise that never resolves\\\\n                        return (0, _dynamicrenderingutils.makeHangingPromise)();\\\\n                    }\\\\n                }\\\\n            }\\\\n        }\\\\n    }\\\\n    // We're prerendering in a mode that does not abort. We resolve the promise without\\\\n    // any tracking because we're just transporting a value from server to client where the tracking\\\\n    // will be applied.\\\\n    return (0, _utils.makeResolvedReactPromise)(underlyingParams);\\\\n})\\\",\\\"createPrerenderSearchParamsForClientPage\\\":\\\"$E(function createPrerenderSearchParamsForClientPage(workStore) {\\\\n    if (workStore.forceStatic) {\\\\n        // When using forceStatic we override all other logic and always just return an empty\\\\n        // dictionary object.\\\\n        return Promise.resolve({});\\\\n    }\\\\n    const prerenderStore = _prerenderasyncstorageexternal.prerenderAsyncStorage.getStore();\\\\n    if (prerenderStore) {\\\\n        if ((0, _prerenderasyncstorageexternal.isDynamicIOPrerender)(prerenderStore)) {\\\\n            // We're prerendering in a mode that aborts (dynamicIO) and should stall\\\\n            // the promise to ensure the RSC side is considered dynamic\\\\n            return (0, _dynamicrenderingutils.makeHangingPromise)();\\\\n        }\\\\n    }\\\\n    // We're prerendering in a mode that does not aborts. We resolve the promise without\\\\n    // any tracking because we're just transporting a value from server to client where the tracking\\\\n    // will be applied.\\\\n    return Promise.resolve({});\\\\n})\\\",\\\"createServerParamsForMetadata\\\":\\\"$E(function createServerParamsForServerSegment(underlyingParams, workStore) {\\\\n    if (workStore.isStaticGeneration) {\\\\n        return createPrerenderParams(underlyingParams, workStore);\\\\n    } else {\\\\n        return createRenderParams(underlyingParams, workStore);\\\\n    }\\\\n})\\\",\\\"createServerParamsForServerSegment\\\":\\\"$E(function createServerParamsForServerSegment(underlyingParams, workStore) {\\\\n    if (workStore.isStaticGeneration) {\\\\n        return createPrerenderParams(underlyingParams, workStore);\\\\n    } else {\\\\n        return createRenderParams(underlyingParams, workStore);\\\\n    }\\\\n})\\\",\\\"createServerSearchParamsForMetadata\\\":\\\"$E(function createServerSearchParamsForServerPage(underlyingSearchParams, workStore) {\\\\n    if (workStore.isStaticGeneration) {\\\\n        return createPrerenderSearchParams(workStore);\\\\n    } else {\\\\n        return createRenderSearchParams(underlyingSearchParams, workStore);\\\\n    }\\\\n})\\\",\\\"createServerSearchParamsForServerPage\\\":\\\"$E(function createServerSearchParamsForServerPage(underlyingSearchParams, workStore) {\\\\n    if (workStore.isStaticGeneration) {\\\\n        return createPrerenderSearchParams(workStore);\\\\n    } else {\\\\n        return createRenderSearchParams(underlyingSearchParams, workStore);\\\\n    }\\\\n})\\\",\\\"decodeAction\\\":\\\"$E(function(body,serverManifest){var formData=new FormData,action=null;return body.forEach(function(value,key){key.startsWith(\\\\\\\"$ACTION_\\\\\\\")?key.startsWith(\\\\\\\"$ACTION_REF_\\\\\\\")?(value=decodeBoundActionMetaData(body,serverManifest,value=\\\\\\\"$ACTION_\\\\\\\"+key.slice(12)+\\\\\\\":\\\\\\\"),action=loadServerReference(serverManifest,value.id,value.bound)):key.startsWith(\\\\\\\"$ACTION_ID_\\\\\\\")\\u0026\\u0026(action=loadServerReference(serverManifest,value=key.slice(11),null)):formData.append(key,value)}),null===action?null:action.then(function(fn){return fn.bind(null,formData)})})\\\",\\\"decodeFormState\\\":\\\"$E(function(actionResult,body,serverManifest){var keyPath=body.get(\\\\\\\"$ACTION_KEY\\\\\\\");if(\\\\\\\"string\\\\\\\"!=typeof keyPath)return Promise.resolve(null);var metaData=null;if(body.forEach(function(value,key){key.startsWith(\\\\\\\"$ACTION_REF_\\\\\\\")\\u0026\\u0026(metaData=decodeBoundActionMetaData(body,serverManifest,\\\\\\\"$ACTION_\\\\\\\"+key.slice(12)+\\\\\\\":\\\\\\\"))}),null===metaData)return Promise.resolve(null);var referenceId=metaData.id;return Promise.resolve(metaData.bound).then(function(bound){return null===bound?null:[actionResult,keyPath,referenceId,bound.length-1]})})\\\",\\\"decodeReply\\\":\\\"$E(function(body,webpackMap,options){if(\\\\\\\"string\\\\\\\"==typeof body){var form=new FormData;form.append(\\\\\\\"0\\\\\\\",body),body=form}return webpackMap=getChunk(body=createResponse(webpackMap,\\\\\\\"\\\\\\\",options?options.temporaryReferences:void 0,body),0),close(body),webpackMap})\\\",\\\"patchFetch\\\":\\\"$E(function patchFetch() {\\\\n    return (0, _patchfetch.patchFetch)({\\\\n        workAsyncStorage: _workasyncstorageexternal.workAsyncStorage,\\\\n        requestAsyncStorage: _requestasyncstorageexternal.requestAsyncStorage,\\\\n        prerenderAsyncStorage: _prerenderasyncstorageexternal.prerenderAsyncStorage\\\\n    });\\\\n})\\\",\\\"preconnect\\\":\\\"$E(function preconnect(href, crossOrigin, nonce) {\\\\n    const opts = {};\\\\n    if (typeof crossOrigin === 'string') {\\\\n        opts.crossOrigin = crossOrigin;\\\\n    }\\\\n    if (typeof nonce === 'string') {\\\\n        opts.nonce = nonce;\\\\n    }\\\\n    _reactdom.default.preconnect(href, opts);\\\\n})\\\",\\\"preloadFont\\\":\\\"$E(function preloadFont(href, type, crossOrigin, nonce) {\\\\n    const opts = {\\\\n        as: 'font',\\\\n        type\\\\n    };\\\\n    if (typeof crossOrigin === 'string') {\\\\n        opts.crossOrigin = crossOrigin;\\\\n    }\\\\n    if (typeof nonce === 'string') {\\\\n        opts.nonce = nonce;\\\\n    }\\\\n    _reactdom.default.preload(href, opts);\\\\n})\\\",\\\"preloadStyle\\\":\\\"$E(function preloadStyle(href, crossOrigin, nonce) {\\\\n    const opts = {\\\\n        as: 'style'\\\\n    };\\\\n    if (typeof crossOrigin === 'string') {\\\\n        opts.crossOrigin = crossOrigin;\\\\n    }\\\\n    if (typeof nonce === 'string') {\\\\n        opts.nonce = nonce;\\\\n    }\\\\n    _reactdom.default.preload(href, opts);\\\\n})\\\",\\\"prerender\\\":\\\"$undefined\\\",\\\"renderToReadableStream\\\":\\\"$E(function(model,webpackMap,options){var request=new RequestInstance(20,model,webpackMap,options?options.onError:void 0,options?options.identifierPrefix:void 0,options?options.onPostpone:void 0,options?options.temporaryReferences:void 0,options?options.environmentName:void 0,options?options.filterStackFrame:void 0,noop,noop);if(options\\u0026\\u0026options.signal){var signal=options.signal;if(signal.aborted)abort(request,signal.reason);else{var listener=function(){abort(request,signal.reason),signal.removeEventListener(\\\\\\\"abort\\\\\\\",listener)};signal.addEventListener(\\\\\\\"abort\\\\\\\",listener)}}return new ReadableStream({type:\\\\\\\"bytes\\\\\\\",start:function(){request.flushScheduled=null!==request.destination,supportsRequestStorage?scheduleMicrotask(function(){requestStorage.run(request,performWork,request)}):scheduleMicrotask(function(){return performWork(request)}),setTimeoutOrImmediate(function(){request.status===OPENING\\u0026\\u0026(request.status=11)},0)},pull:function(controller){if(request.status===CLOSING)request.status=CLOSED,closeWithError(controller,request.fatalError);else if(request.status!==CLOSED\\u0026\\u0026null===request.destination){request.destination=controller;try{flushCompletedChunks(request,controller)}catch(error){logRecoverableError(request,error,null),fatalError(request,error)}}},cancel:function(reason){request.destination=null,abort(request,reason)}},{highWaterMark:0})})\\\",\\\"requestAsyncStorage\\\":\\\"$Y\\\",\\\"serverHooks\\\":\\\"$Y\\\",\\\"taintObjectReference\\\":\\\"$E(function notImplemented() {\\\\n    throw new Error('Taint can only be used with the taint flag.');\\\\n})\\\",\\\"workAsyncStorage\\\":\\\"$Y\\\"},\\\"renderOpts\\\":\\\"$Y\\\",\\\"requestStore\\\":\\\"$Y\\\",\\\"workStore\\\":\\\"$Y\\\",\\\"parsedRequestHeaders\\\":\\\"$Y\\\",\\\"getDynamicParamFromSegment\\\":\\\"$E(function(segment){let segmentParam=getSegmentParam(segment);if(!segmentParam)return null;let key=segmentParam.param,value=params[key];if(fallbackRouteParams\\u0026\\u0026fallbackRouteParams.has(segmentParam.param)?value=fallbackRouteParams.get(segmentParam.param):Array.isArray(value)?value=value.map(i=\\u003eencodeURIComponent(i)):\\\\\\\"string\\\\\\\"==typeof value\\u0026\\u0026(value=encodeURIComponent(value)),!value){let isCatchall=\\\\\\\"catchall\\\\\\\"===segmentParam.type,isOptionalCatchall=\\\\\\\"optional-catchall\\\\\\\"===segmentParam.type;if(isCatchall||isOptionalCatchall){let dynamicParamType=dynamicParamTypes[segmentParam.type];return isOptionalCatchall?{param:key,value:null,type:dynamicParamType,treeSegment:[key,\\\\\\\"\\\\\\\",dynamicParamType]}:{param:key,value:value=pagePath.split(\\\\\\\"/\\\\\\\").slice(1).flatMap(pathSegment=\\u003e{let param=function(param){let match=param.match(PARAMETER_PATTERN);return match?parseMatchedParameter(match[1]):parseMatchedParameter(param)}(pathSegment);return params[param.key]??param.key}),type:dynamicParamType,treeSegment:[key,value.join(\\\\\\\"/\\\\\\\"),dynamicParamType]}}}let type=function(type){let short=dynamicParamTypes[type];if(!short)throw Error(\\\\\\\"Unknown dynamic param type\\\\\\\");return short}(segmentParam.type);return{param:key,value:value,treeSegment:[key,Array.isArray(value)?value.join(\\\\\\\"/\\\\\\\"):value,type],type:type}})\\\",\\\"query\\\":\\\"$Y\\\",\\\"isPrefetch\\\":false,\\\"isAction\\\":false,\\\"requestTimestamp\\\":1728059369914,\\\"appUsingSizeAdjustment\\\":false,\\\"flightRouterState\\\":\\\"$undefined\\\",\\\"requestId\\\":\\\"76AETHhACXBiCuiff08Ex\\\",\\\"defaultRevalidate\\\":false,\\\"pagePath\\\":\\\"/client-boundary\\\",\\\"clientReferenceManifest\\\":\\\"$Y\\\",\\\"assetPrefix\\\":\\\"\\\",\\\"isNotFoundPath\\\":false,\\\"nonce\\\":\\\"$undefined\\\",\\\"res\\\":\\\"$Y\\\"}}}\\n\"])</script><script>self.__next_f.push([1,\"18:D\\\"$1f\\\"\\n18:null\\n21:{\\\"name\\\":\\\"MetadataRoot\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":\\\"76AETHhACXBiCuiff08Ex\\\",\\\"owner\\\":null,\\\"props\\\":{}}\\n20:D\\\"$21\\\"\\n23:{\\\"name\\\":\\\"Metadata\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":null,\\\"owner\\\":\\\"$21\\\",\\\"props\\\":{}}\\n22:D\\\"$23\\\"\\n25:{\\\"name\\\":\\\"Viewport\\\",\\\"env\\\":\\\"Server\\\",\\\"key\\\":null,\\\"owner\\\":\\\"$21\\\",\\\"props\\\":{}}\\n24:D\\\"$25\\\"\\n20:[\\\"$\\\",\\\"$3\\\",\\\"76AETHhACXBiCuiff08Ex\\\",{\\\"children\\\":[[\\\"$\\\",\\\"$L1c\\\",null,{\\\"children\\\":\\\"$L22\\\"},\\\"$21\\\"],[\\\"$\\\",\\\"$L1e\\\",null,{\\\"children\\\":\\\"$L24\\\"},\\\"$21\\\"],null]},null]\\n26:[]\\n0:{\\\"P\\\":\\\"$1\\\",\\\"b\\\":\\\"development\\\",\\\"p\\\":\\\"\\\",\\\"c\\\":[\\\"\\\",\\\"client-boundary\\\"],\\\"i\\\":false,\\\"f\\\":[[[\\\"\\\",{\\\"children\\\":[\\\"client-boundary\\\",{\\\"children\\\":[\\\"__PAGE__\\\",{}]}]},\\\"$undefined\\\",\\\"$undefined\\\",true],[\\\"\\\",[\\\"$\\\",\\\"$3\\\",\\\"c\\\",{\\\"children\\\":[null,\\\"$4\\\"]},null],{\\\"children\\\":[\\\"client-boundary\\\",[\\\"$\\\",\\\"$3\\\",\\\"c\\\",{\\\"children\\\":[null,[\\\"$\\\",\\\"$L6\\\",null,{\\\"parallelRouterKey\\\":\\\"children\\\",\\\"segmentPath\\\":[\\\"children\\\",\\\"client-boundary\\\",\\\"children\\\"],\\\"error\\\":\\\"$undefined\\\",\\\"errorStyles\\\":\\\"$undefined\\\",\\\"errorScripts\\\":\\\"$undefined\\\",\\\"template\\\":[\\\"$\\\",\\\"$L9\\\",null,{},null],\\\"templateStyles\\\":\\\"$undefined\\\",\\\"templateScripts\\\":\\\"$undefined\\\",\\\"notFound\\\":\\\"$undefined\\\",\\\"notFoundStyles\\\":\\\"$undefined\\\"},null]]},null],{\\\"children\\\":[\\\"__PAGE__\\\",[\\\"$\\\",\\\"$3\\\",\\\"c\\\",{\\\"children\\\":[\\\"$e\\\",null,[\\\"$\\\",\\\"$L15\\\",null,{\\\"children\\\":\\\"$L16\\\"},null]]},null],{},null]},null]},null],[\\\"$\\\",\\\"$3\\\",\\\"h\\\",{\\\"children\\\":[\\\"$18\\\",\\\"$20\\\"]},null]]],\\\"m\\\":\\\"$W26\\\",\\\"G\\\":\\\"$19\\\",\\\"s\\\":false,\\\"S\\\":false}\\n24:[[\\\"$\\\",\\\"meta\\\",\\\"0\\\",{\\\"name\\\":\\\"viewport\\\",\\\"content\\\":\\\"width=device-width, initial-scale=1\\\"},\\\"$17\\\"]]\\n22:[[\\\"$\\\",\\\"meta\\\",\\\"0\\\",{\\\"charSet\\\":\\\"utf-8\\\"},\\\"$23\\\"],[\\\"$\\\",\\\"title\\\",\\\"1\\\",{\\\"children\\\":\\\"Next.js\\\"},\\\"$23\\\"],[\\\"$\\\",\\\"meta\\\",\\\"2\\\",{\\\"name\\\":\\\"description\\\",\\\"content\\\":\\\"Generated by Next.js\\\"},\\\"$23\\\"]]\\n16:null\\n\"])</script></body></html>"

  123 |       it('should support "use client" directive in barrel file', async () => {
  124 |         const html = await next.render('/client-boundary')
> 125 |         expect(html).toContain('<button>0</button>')
      |                      ^
  126 |       })
  127 |     })
  128 |   }

  at Object.toContain (development/basic/barrel-optimization/barrel-optimization.test.ts:125:22)

Read more about building and testing Next.js in contributing.md.

TURBOPACK=1 pnpm test-dev test/development/acceptance-app/editor-links.test.ts (turbopack)

  • Error overlay - editor links > should be possible to open source file on build error
Expand output

● Error overlay - editor links › should be possible to open source file on build error

Application is in inconsistent state: timeout.

  90 |           }
  91 |           if (status !== 'pending') {
> 92 |             throw new Error(`Application is in inconsistent state: ${status}.`)
     |                   ^
  93 |           }
  94 |
  95 |           await waitFor(30)

  at Object.patch (lib/development-sandbox.ts:92:19)
  at Object.<anonymous> (development/acceptance-app/editor-links.test.ts:60:5)

Read more about building and testing Next.js in contributing.md.

TURBOPACK=1 pnpm test-dev test/development/acceptance-app/app-hmr-changes.test.ts (turbopack)

  • Error overlay - RSC build errors > Skipped in webpack > should handle successive HMR changes with errors correctly
Expand output

● Error overlay - RSC build errors › Skipped in webpack › should handle successive HMR changes with errors correctly

Application is in inconsistent state: timeout.

  90 |           }
  91 |           if (status !== 'pending') {
> 92 |             throw new Error(`Application is in inconsistent state: ${status}.`)
     |                   ^
  93 |           }
  94 |
  95 |           await waitFor(30)

  at Object.patch (lib/development-sandbox.ts:92:19)
  at Object.<anonymous> (development/acceptance-app/app-hmr-changes.test.ts:44:9)

Read more about building and testing Next.js in contributing.md.

TURBOPACK=1 pnpm test-dev test/development/acceptance-app/error-message-url.test.ts (turbopack)

  • Error overlay - error message urls > should be possible to click url in build error
  • Error overlay - error message urls > should be possible to click url in runtime error
Expand output

● Error overlay - error message urls › should be possible to click url in build error

Application is in inconsistent state: timeout.

  90 |           }
  91 |           if (status !== 'pending') {
> 92 |             throw new Error(`Application is in inconsistent state: ${status}.`)
     |                   ^
  93 |           }
  94 |
  95 |           await waitFor(30)

  at Object.patch (lib/development-sandbox.ts:92:19)
  at Object.<anonymous> (development/acceptance-app/error-message-url.test.ts:17:5)

● Error overlay - error message urls › should be possible to click url in runtime error

page.waitForSelector: Timeout 5000ms exceeded.
Call log:
  - waiting for locator('[data-nextjs-toast]')

  423 |     return this.chain(() => {
  424 |       return page
> 425 |         .waitForSelector(selector, { timeout, state: 'attached' })
      |          ^
  426 |         .then(async (el) => {
  427 |           // it seems selenium waits longer and tests rely on this behavior
  428 |           // so we wait for the load event fire before returning

  at waitForSelector (lib/browsers/playwright.ts:425:10)

Read more about building and testing Next.js in contributing.md.

pnpm test-dev test/development/acceptance-app/ReactRefreshModule.test.ts

  • ReactRefreshModule app > should allow any variable names
Expand output

● ReactRefreshModule app › should allow any variable names

Application is in inconsistent state: timeout.

  90 |           }
  91 |           if (status !== 'pending') {
> 92 |             throw new Error(`Application is in inconsistent state: ${status}.`)
     |                   ^
  93 |           }
  94 |
  95 |           await waitFor(30)

  at Object.patch (lib/development-sandbox.ts:92:19)
  at Object.<anonymous> (development/acceptance-app/ReactRefreshModule.test.ts:25:7)

Read more about building and testing Next.js in contributing.md.

__NEXT_EXPERIMENTAL_PPR=true pnpm test-dev test/e2e/app-dir/app-edge/app-edge.test.ts (PPR)

  • app-dir edge SSR > should resolve client component without error
Expand output

● app-dir edge SSR › should resolve client component without error

expect(received).toEqual(expected) // deep equality

- Expected  -  1
+ Received  + 10

- Array []
+ Array [
+   " In route /with-client a searchParam property was accessed directly with `searchParams.toJSON`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis
+ ",
+   " In route /with-client a searchParam property was accessed directly with `searchParams.$$typeof`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis
+ ",
+   " In route /with-client a searchParam property was accessed directly with `searchParams.$$typeof`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis
+ ",
+   " In route /with-client a searchParam property was accessed directly with `searchParams.status`. `searchParams` should be awaited before accessing properties. Learn more: https://nextjs.org/docs/messages/sync-dynamic-apis
+ ",
+ ]

  77 |       const html = await next.render('/with-client')
  78 |       expect(html).toContain('My Button')
> 79 |       expect(logs).toEqual([])
     |                    ^
  80 |     })
  81 |
  82 |     it('should handle edge rsc hmr', async () => {

  at Object.toEqual (e2e/app-dir/app-edge/app-edge.test.ts:79:20)

Read more about building and testing Next.js in contributing.md.

TURBOPACK=1 pnpm test test/integration/app-config-asset-prefix/test/index.test.js (turbopack)

  • App assetPrefix config > should render correctly with assetPrefix: "/"
Expand output

● App assetPrefix config › should render correctly with assetPrefix: "/"

thrown: "Exceeded timeout of 60000 ms for a test.
Add a timeout value to this test to increase the timeout, if this is a long-running test. See https://jestjs.io/docs/api#testname-fn-timeout."

  22 |   afterAll(() => killApp(app))
  23 |
> 24 |   it('should render correctly with assetPrefix: "/"', async () => {
     |   ^
  25 |     const browser = await webdriver(appPort, '/')
  26 |     try {
  27 |       await waitFor(2000)

  at it (integration/app-config-asset-prefix/test/index.test.js:24:3)
  at Object.describe (integration/app-config-asset-prefix/test/index.test.js:14:1)

Read more about building and testing Next.js in contributing.md.

pnpm test test/integration/app-dir-export/test/dynamicpage-dev.test.ts

  • app dir - with output export - dynamic page dev > development mode > should work in dev with dynamicPage undefined
  • app dir - with output export - dynamic page dev > development mode > should work in dev with dynamicPage 'error'
  • app dir - with output export - dynamic page dev > development mode > should work in dev with dynamicPage 'force-static'
  • app dir - with output export - dynamic page dev > development mode > should work in dev with dynamicPage 'force-dynamic'
Expand output

● app dir - with output export - dynamic page dev › development mode › should work in dev with dynamicPage undefined

thrown: "Exceeded timeout of 60000 ms for a test.
Add a timeout value to this test to increase the timeout, if this is a long-running test. See https://jestjs.io/docs/api#testname-fn-timeout."

  14 |             'Page with `dynamic = "force-dynamic"` couldn\'t be exported. `output: "export"` requires all pages be renderable statically',
  15 |         },
> 16 |       ])(
     |        ^
  17 |         'should work in dev with dynamicPage $dynamicPage',
  18 |         async ({ dynamicPage, expectedErrMsg }) => {
  19 |           await runTests({ isDev: true, dynamicPage, expectedErrMsg })

  at ../node_modules/.pnpm/jest-each@29.7.0/node_modules/jest-each/build/bind.js:47:15
      at Array.forEach (<anonymous>)
  at integration/app-dir-export/test/dynamicpage-dev.test.ts:16:8
  at integration/app-dir-export/test/dynamicpage-dev.test.ts:4:58
  at Object.describe (integration/app-dir-export/test/dynamicpage-dev.test.ts:3:1)

● app dir - with output export - dynamic page dev › development mode › should work in dev with dynamicPage 'error'

Failed to replace content.

Pattern: const dynamic = 'force-static'

Content: import Link from 'next/link'

export const dynamic = undefined

export function generateStaticParams() {
  return [{ slug: 'first' }, { slug: 'second' }]
}

export default function Page({ params }) {
  return (
    <main>
      <h1>{params.slug}</h1>
      <ul>
        <li>
          <Link href="/another">Visit another page</Link>
        </li>
      </ul>
    </main>
  )
}

  751 |     } else if (typeof pattern === 'string') {
  752 |       if (!currentContent.includes(pattern)) {
> 753 |         throw new Error(
      |               ^
  754 |           `Failed to replace content.\n\nPattern: ${pattern}\n\nContent: ${currentContent}`
  755 |         )
  756 |       }

  at File.replace (lib/next-test-utils.ts:753:15)
  at replace (integration/app-dir-export/test/utils.ts:129:14)
  at integration/app-dir-export/test/dynamicpage-dev.test.ts:19:25

● app dir - with output export - dynamic page dev › development mode › should work in dev with dynamicPage 'force-static'

Failed to replace content.

Pattern: const dynamic = 'force-static'

Content: import Link from 'next/link'

export const dynamic = undefined

export function generateStaticParams() {
  return [{ slug: 'first' }, { slug: 'second' }]
}

export default function Page({ params }) {
  return (
    <main>
      <h1>{params.slug}</h1>
      <ul>
        <li>
          <Link href="/another">Visit another page</Link>
        </li>
      </ul>
    </main>
  )
}

  751 |     } else if (typeof pattern === 'string') {
  752 |       if (!currentContent.includes(pattern)) {
> 753 |         throw new Error(
      |               ^
  754 |           `Failed to replace content.\n\nPattern: ${pattern}\n\nContent: ${currentContent}`
  755 |         )
  756 |       }

  at File.replace (lib/next-test-utils.ts:753:15)
  at replace (integration/app-dir-export/test/utils.ts:129:14)
  at integration/app-dir-export/test/dynamicpage-dev.test.ts:19:25

● app dir - with output export - dynamic page dev › development mode › should work in dev with dynamicPage 'force-dynamic'

Failed to replace content.

Pattern: const dynamic = 'force-static'

Content: import Link from 'next/link'

export const dynamic = undefined

export function generateStaticParams() {
  return [{ slug: 'first' }, { slug: 'second' }]
}

export default function Page({ params }) {
  return (
    <main>
      <h1>{params.slug}</h1>
      <ul>
        <li>
          <Link href="/another">Visit another page</Link>
        </li>
      </ul>
    </main>
  )
}

  751 |     } else if (typeof pattern === 'string') {
  752 |       if (!currentContent.includes(pattern)) {
> 753 |         throw new Error(
      |               ^
  754 |           `Failed to replace content.\n\nPattern: ${pattern}\n\nContent: ${currentContent}`
  755 |         )
  756 |       }

  at File.replace (lib/next-test-utils.ts:753:15)
  at replace (integration/app-dir-export/test/utils.ts:129:14)
  at integration/app-dir-export/test/dynamicpage-dev.test.ts:19:25

Read more about building and testing Next.js in contributing.md.

pnpm test-dev test/development/next-config-ts/hmr/index.test.ts

  • next-config-ts - dev-hmr > should output config file change
Expand output

● next-config-ts - dev-hmr › should output config file change

TIMED OUT: 200

500

undefined

  718 |
  719 |   if (hardError) {
> 720 |     throw new Error('TIMED OUT: ' + regex + '\n\n' + content + '\n\n' + lastErr)
      |           ^
  721 |   }
  722 |   return false
  723 | }

  at check (lib/next-test-utils.ts:720:11)
  at Object.<anonymous> (development/next-config-ts/hmr/index.test.ts:29:5)

Read more about building and testing Next.js in contributing.md.

TURBOPACK=1 pnpm test test/integration/app-dir-export/test/dynamicapiroute-dev.test.ts (turbopack)

  • app dir - with output export - dynamic api route dev > development mode > should work in dev with dynamicApiRoute 'error'
  • app dir - with output export - dynamic api route dev > development mode > should work in dev with dynamicApiRoute 'force-static'
  • app dir - with output export - dynamic api route dev > development mode > should work in dev with dynamicApiRoute 'force-dynamic'
Expand output

● app dir - with output export - dynamic api route dev › development mode › should work in dev with dynamicApiRoute 'error'

thrown: "Exceeded timeout of 60000 ms for a test.
Add a timeout value to this test to increase the timeout, if this is a long-running test. See https://jestjs.io/docs/api#testname-fn-timeout."

  18 |             'export const dynamic = "force-dynamic" on page "/api/json" cannot be used with "output: export".',
  19 |         },
> 20 |       ])(
     |        ^
  21 |         'should work in dev with dynamicApiRoute $dynamicApiRoute',
  22 |         async ({ dynamicApiRoute, expectedErrMsg }) => {
  23 |           await runTests({ isDev: true, dynamicApiRoute, expectedErrMsg })

  at ../node_modules/.pnpm/jest-each@29.7.0/node_modules/jest-each/build/bind.js:47:15
      at Array.forEach (<anonymous>)
  at integration/app-dir-export/test/dynamicapiroute-dev.test.ts:20:8
  at integration/app-dir-export/test/dynamicapiroute-dev.test.ts:4:58
  at Object.describe (integration/app-dir-export/test/dynamicapiroute-dev.test.ts:3:1)

● app dir - with output export - dynamic api route dev › development mode › should work in dev with dynamicApiRoute 'force-static'

Failed to replace content.

Pattern: const dynamic = 'force-static'

Content: export const dynamic = 'error'

export async function GET() {
  return Response.json({ answer: 42 })
}

  751 |     } else if (typeof pattern === 'string') {
  752 |       if (!currentContent.includes(pattern)) {
> 753 |         throw new Error(
      |               ^
  754 |           `Failed to replace content.\n\nPattern: ${pattern}\n\nContent: ${currentContent}`
  755 |         )
  756 |       }

  at File.replace (lib/next-test-utils.ts:753:15)
  at replace (integration/app-dir-export/test/utils.ts:136:13)
  at integration/app-dir-export/test/dynamicapiroute-dev.test.ts:23:25

● app dir - with output export - dynamic api route dev › development mode › should work in dev with dynamicApiRoute 'force-dynamic'

Failed to replace content.

Pattern: const dynamic = 'force-static'

Content: export const dynamic = 'error'

export async function GET() {
  return Response.json({ answer: 42 })
}

  751 |     } else if (typeof pattern === 'string') {
  752 |       if (!currentContent.includes(pattern)) {
> 753 |         throw new Error(
      |               ^
  754 |           `Failed to replace content.\n\nPattern: ${pattern}\n\nContent: ${currentContent}`
  755 |         )
  756 |       }

  at File.replace (lib/next-test-utils.ts:753:15)
  at replace (integration/app-dir-export/test/utils.ts:136:13)
  at integration/app-dir-export/test/dynamicapiroute-dev.test.ts:23:25

Read more about building and testing Next.js in contributing.md.

TURBOPACK=1 pnpm test test/integration/app-dir-export/test/trailing-slash-dev.test.ts (turbopack)

  • app dir - with output export - trailing slash dev > development mode > should work in dev with trailingSlash 'false'
  • app dir - with output export - trailing slash dev > development mode > should work in dev with trailingSlash 'true'
Expand output

● app dir - with output export - trailing slash dev › development mode › should work in dev with trailingSlash 'false'

thrown: "Exceeded timeout of 60000 ms for a test.
Add a timeout value to this test to increase the timeout, if this is a long-running test. See https://jestjs.io/docs/api#testname-fn-timeout."

   5 |     'development mode',
   6 |     () => {
>  7 |       it.each([{ trailingSlash: false }, { trailingSlash: true }])(
     |                                                                  ^
   8 |         "should work in dev with trailingSlash '$trailingSlash'",
   9 |         async ({ trailingSlash }) => {
  10 |           await runTests({ isDev: true, trailingSlash })

  at ../node_modules/.pnpm/jest-each@29.7.0/node_modules/jest-each/build/bind.js:47:15
      at Array.forEach (<anonymous>)
  at integration/app-dir-export/test/trailing-slash-dev.test.ts:7:66
  at integration/app-dir-export/test/trailing-slash-dev.test.ts:4:58
  at Object.describe (integration/app-dir-export/test/trailing-slash-dev.test.ts:3:1)

● app dir - with output export - trailing slash dev › development mode › should work in dev with trailingSlash 'true'

Failed to replace content.

Pattern: trailingSlash: true,

Content: /** @type {import('next').NextConfig} */
const nextConfig = {
  output: 'export',
  // distDir: '.next-custom',
  trailingSlash: false,
  generateBuildId() {
    return 'test-build-id'
  },
}

module.exports = nextConfig

  751 |     } else if (typeof pattern === 'string') {
  752 |       if (!currentContent.includes(pattern)) {
> 753 |         throw new Error(
      |               ^
  754 |           `Failed to replace content.\n\nPattern: ${pattern}\n\nContent: ${currentContent}`
  755 |         )
  756 |       }

  at File.replace (lib/next-test-utils.ts:753:15)
  at replace (integration/app-dir-export/test/utils.ts:123:16)
  at integration/app-dir-export/test/trailing-slash-dev.test.ts:10:25

Read more about building and testing Next.js in contributing.md.

pnpm test test/integration/next-image-new/app-dir-image-from-node-modules/test/index.test.ts

  • Image Component from node_modules development mode > should apply image config for node_modules
Expand output

● Image Component from node_modules development mode › should apply image config for node_modules

thrown: "Exceeded timeout of 60000 ms for a test.
Add a timeout value to this test to increase the timeout, if this is a long-running test. See https://jestjs.io/docs/api#testname-fn-timeout."

  15 |
  16 | function runTests() {
> 17 |   it('should apply image config for node_modules', async () => {
     |   ^
  18 |     const browser = await webdriver(appPort, '/')
  19 |     const src = await browser
  20 |       .elementById('image-from-node-modules')

  at it (integration/next-image-new/app-dir-image-from-node-modules/test/index.test.ts:17:3)
  at runTests (integration/next-image-new/app-dir-image-from-node-modules/test/index.test.ts:58:3)
  at Object.describe (integration/next-image-new/app-dir-image-from-node-modules/test/index.test.ts:49:1)

Read more about building and testing Next.js in contributing.md.

pnpm test test/integration/link-ref-app/test/index.test.js

  • Invalid hrefs > development mode > should not have a race condition with a click handler
Expand output

● Invalid hrefs › development mode › should not have a race condition with a click handler

thrown: "Exceeded timeout of 60000 ms for a test.
Add a timeout value to this test to increase the timeout, if this is a long-running test. See https://jestjs.io/docs/api#testname-fn-timeout."

  61 | function runCommonTests() {
  62 |   // See https://github.com/vercel/next.js/issues/18437
> 63 |   it('should not have a race condition with a click handler', async () => {
     |   ^
  64 |     const browser = await webdriver(appPort, '/click-away-race-condition')
  65 |     await browser.elementByCss('#click-me').click()
  66 |     await browser.waitForElementByCss('#the-menu')

  at it (integration/link-ref-app/test/index.test.js:63:3)
  at runCommonTests (integration/link-ref-app/test/index.test.js:80:7)
  at integration/link-ref-app/test/index.test.js:71:58
  at Object.describe (integration/link-ref-app/test/index.test.js:70:1)

Read more about building and testing Next.js in contributing.md.

pnpm test test/integration/next-image-new/app-dir-localpatterns/test/index.test.ts

  • Image localPatterns config > development mode > should load matching images
  • Image localPatterns config > development mode > should block unmatched image does-not-exist
  • Image localPatterns config > development mode > should block unmatched image nested-assets-query
  • Image localPatterns config > development mode > should block unmatched image nested-blocked
  • Image localPatterns config > development mode > should block unmatched image top-level
Expand output

● Image localPatterns config › development mode › should load matching images

thrown: "Exceeded timeout of 60000 ms for a test.
Add a timeout value to this test to increase the timeout, if this is a long-running test. See https://jestjs.io/docs/api#testname-fn-timeout."

  33 |
  34 | function runTests(mode: 'dev' | 'server') {
> 35 |   it('should load matching images', async () => {
     |   ^
  36 |     const browser = await webdriver(appPort, '/')
  37 |     if (mode === 'dev') {
  38 |       await assertNoRedbox(browser)

  at it (integration/next-image-new/app-dir-localpatterns/test/index.test.ts:35:3)
  at runTests (integration/next-image-new/app-dir-localpatterns/test/index.test.ts:124:7)
  at integration/next-image-new/app-dir-localpatterns/test/index.test.ts:113:58
  at Object.describe (integration/next-image-new/app-dir-localpatterns/test/index.test.ts:112:1)

● Image localPatterns config › development mode › should block unmatched image does-not-exist

Expected Redbox but found none

  56 |     const browser = await webdriver(appPort, page)
  57 |     if (mode === 'dev') {
> 58 |       await assertHasRedbox(browser)
     |       ^
  59 |       expect(await getRedboxHeader(browser)).toMatch(
  60 |         /Invalid src prop (.+) on `next\/image` does not match `images.localPatterns` configured/g
  61 |       )

  at integration/next-image-new/app-dir-localpatterns/test/index.test.ts:58:7

● Image localPatterns config › development mode › should block unmatched image nested-assets-query

Expected Redbox but found none

  56 |     const browser = await webdriver(appPort, page)
  57 |     if (mode === 'dev') {
> 58 |       await assertHasRedbox(browser)
     |       ^
  59 |       expect(await getRedboxHeader(browser)).toMatch(
  60 |         /Invalid src prop (.+) on `next\/image` does not match `images.localPatterns` configured/g
  61 |       )

  at integration/next-image-new/app-dir-localpatterns/test/index.test.ts:58:7

● Image localPatterns config › development mode › should block unmatched image nested-blocked

Expected Redbox but found none

  56 |     const browser = await webdriver(appPort, page)
  57 |     if (mode === 'dev') {
> 58 |       await assertHasRedbox(browser)
     |       ^
  59 |       expect(await getRedboxHeader(browser)).toMatch(
  60 |         /Invalid src prop (.+) on `next\/image` does not match `images.localPatterns` configured/g
  61 |       )

  at integration/next-image-new/app-dir-localpatterns/test/index.test.ts:58:7

● Image localPatterns config › development mode › should block unmatched image top-level

Expected Redbox but found none

  56 |     const browser = await webdriver(appPort, page)
  57 |     if (mode === 'dev') {
> 58 |       await assertHasRedbox(browser)
     |       ^
  59 |       expect(await getRedboxHeader(browser)).toMatch(
  60 |         /Invalid src prop (.+) on `next\/image` does not match `images.localPatterns` configured/g
  61 |       )

  at integration/next-image-new/app-dir-localpatterns/test/index.test.ts:58:7

Read more about building and testing Next.js in contributing.md.

pnpm test test/integration/create-next-app/templates/app.test.ts

  • create-next-app --app (App Router) > should create JavaScript project with --js flag
  • create-next-app --app (App Router) > should create TypeScript project with --ts flag
  • create-next-app --app (App Router) > should create project inside "src" directory with --src-dir flag
  • create-next-app --app (App Router) > should create TailwindCSS project with --tailwind flag
  • create-next-app --app (App Router) > should create an empty project with --empty flag
  • create-next-app --app (App Router) > should create an empty TailwindCSS project with --empty flag
Expand output

● create-next-app --app (App Router) › should create JavaScript project with --js flag

expect(received).toBe(expected) // Object.is equality

Expected: 200
Received: 500

  67 |       expect(await res.text()).toContain('Get started by editing')
  68 |     }
> 69 |     expect(res.status).toBe(200)
     |                        ^
  70 |
  71 |     if (!isApp && !isEmpty) {
  72 |       const apiRes = await fetchViaHTTP(port, '/api/hello')

  at toBe (integration/create-next-app/utils.ts:69:24)
  at integration/create-next-app/templates/app.test.ts:47:7
  at useTempDir (lib/use-temp-dir.ts:24:5)
  at Object.<anonymous> (integration/create-next-app/templates/app.test.ts:26:5)

● create-next-app --app (App Router) › should create TypeScript project with --ts flag

expect(received).toBe(expected) // Object.is equality

Expected: 200
Received: 500

  67 |       expect(await res.text()).toContain('Get started by editing')
  68 |     }
> 69 |     expect(res.status).toBe(200)
     |                        ^
  70 |
  71 |     if (!isApp && !isEmpty) {
  72 |       const apiRes = await fetchViaHTTP(port, '/api/hello')

  at toBe (integration/create-next-app/utils.ts:69:24)
  at integration/create-next-app/templates/app.test.ts:76:7
  at useTempDir (lib/use-temp-dir.ts:24:5)
  at Object.<anonymous> (integration/create-next-app/templates/app.test.ts:55:5)

● create-next-app --app (App Router) › should create project inside "src" directory with --src-dir flag

expect(received).toBe(expected) // Object.is equality

Expected: 200
Received: 500

  67 |       expect(await res.text()).toContain('Get started by editing')
  68 |     }
> 69 |     expect(res.status).toBe(200)
     |                        ^
  70 |
  71 |     if (!isApp && !isEmpty) {
  72 |       const apiRes = await fetchViaHTTP(port, '/api/hello')

  at toBe (integration/create-next-app/utils.ts:69:24)
  at integration/create-next-app/templates/app.test.ts:110:7
  at useTempDir (lib/use-temp-dir.ts:24:5)
  at Object.<anonymous> (integration/create-next-app/templates/app.test.ts:82:5)

● create-next-app --app (App Router) › should create TailwindCSS project with --tailwind flag

expect(received).toBe(expected) // Object.is equality

Expected: 200
Received: 500

  67 |       expect(await res.text()).toContain('Get started by editing')
  68 |     }
> 69 |     expect(res.status).toBe(200)
     |                        ^
  70 |
  71 |     if (!isApp && !isEmpty) {
  72 |       const apiRes = await fetchViaHTTP(port, '/api/hello')

  at toBe (integration/create-next-app/utils.ts:69:24)
  at integration/create-next-app/templates/app.test.ts:145:7
  at useTempDir (lib/use-temp-dir.ts:24:5)
  at Object.<anonymous> (integration/create-next-app/templates/app.test.ts:118:5)

● create-next-app --app (App Router) › should create an empty project with --empty flag

expect(received).toBe(expected) // Object.is equality

Expected: 200
Received: 500

  67 |       expect(await res.text()).toContain('Get started by editing')
  68 |     }
> 69 |     expect(res.status).toBe(200)
     |                        ^
  70 |
  71 |     if (!isApp && !isEmpty) {
  72 |       const apiRes = await fetchViaHTTP(port, '/api/hello')

  at toBe (integration/create-next-app/utils.ts:69:24)
  at integration/create-next-app/templates/app.test.ts:182:7
  at useTempDir (lib/use-temp-dir.ts:24:5)
  at Object.<anonymous> (integration/create-next-app/templates/app.test.ts:153:5)

● create-next-app --app (App Router) › should create an empty TailwindCSS project with --empty flag

expect(received).toBe(expected) // Object.is equality

Expected: 200
Received: 500

  67 |       expect(await res.text()).toContain('Get started by editing')
  68 |     }
> 69 |     expect(res.status).toBe(200)
     |                        ^
  70 |
  71 |     if (!isApp && !isEmpty) {
  72 |       const apiRes = await fetchViaHTTP(port, '/api/hello')

  at toBe (integration/create-next-app/utils.ts:69:24)
  at integration/create-next-app/templates/app.test.ts:220:7
  at useTempDir (lib/use-temp-dir.ts:24:5)
  at Object.<anonymous> (integration/create-next-app/templates/app.test.ts:191:5)

Read more about building and testing Next.js in contributing.md.

__NEXT_EXPERIMENTAL_PPR=true pnpm test-dev test/e2e/app-dir/error-boundary-navigation/index.test.ts (PPR)

  • app dir - not found navigation > should allow navigation on not-found
  • app dir - not found navigation > should allow navigation on error
Expand output

● app dir - not found navigation › should allow navigation on not-found

page.waitForSelector: Timeout 60000ms exceeded.
Call log:
  - waiting for locator('#not-found-component')

  423 |     return this.chain(() => {
  424 |       return page
> 425 |         .waitForSelector(selector, { timeout, state: 'attached' })
      |          ^
  426 |         .then(async (el) => {
  427 |           // it seems selenium waits longer and tests rely on this behavior
  428 |           // so we wait for the load event fire before returning

  at waitForSelector (lib/browsers/playwright.ts:425:10)

● app dir - not found navigation › should allow navigation on error

page.waitForSelector: Timeout 60000ms exceeded.
Call log:
  - waiting for locator('#error-component')

  423 |     return this.chain(() => {
  424 |       return page
> 425 |         .waitForSelector(selector, { timeout, state: 'attached' })
      |          ^
  426 |         .then(async (el) => {
  427 |           // it seems selenium waits longer and tests rely on this behavior
  428 |           // so we wait for the load event fire before returning

  at waitForSelector (lib/browsers/playwright.ts:425:10)

Read more about building and testing Next.js in contributing.md.

pnpm test-start test/production/allow-development-build/allow-development-build.test.ts

  • allow-development-build > with NODE_ENV set to development > should warn about a non-standard NODE_ENV
  • allow-development-build > with NODE_ENV set to development > should show React development errors in app-page
  • allow-development-build > with NODE_ENV set to development > should show React development errors in pages-page
Expand output

● allow-development-build › with NODE_ENV set to development › should warn about a non-standard NODE_ENV

next build failed with code/signal 1

   98 |           if (code || signal)
   99 |             reject(
> 100 |               new Error(`next build failed with code/signal ${code || signal}`)
      |               ^
  101 |             )
  102 |           else resolve()
  103 |         })

  at ChildProcess.<anonymous> (lib/next-modes/next-start.ts:100:15)

● allow-development-build › with NODE_ENV set to development › should show React development errors in app-page

next build failed with code/signal 1

   98 |           if (code || signal)
   99 |             reject(
> 100 |               new Error(`next build failed with code/signal ${code || signal}`)
      |               ^
  101 |             )
  102 |           else resolve()
  103 |         })

  at ChildProcess.<anonymous> (lib/next-modes/next-start.ts:100:15)

● allow-development-build › with NODE_ENV set to development › should show React development errors in pages-page

next build failed with code/signal 1

   98 |           if (code || signal)
   99 |             reject(
> 100 |               new Error(`next build failed with code/signal ${code || signal}`)
      |               ^
  101 |             )
  102 |           else resolve()
  103 |         })

  at ChildProcess.<anonymous> (lib/next-modes/next-start.ts:100:15)

Read more about building and testing Next.js in contributing.md.

TURBOPACK=1 pnpm test test/integration/create-next-app/templates/matrix.test.ts (turbopack)

  • CNA options matrix - app > --app --turbo --js --import-alias=@acme/* --eslint --src-dir --tailwind
  • CNA options matrix - app > --app --turbo --js --import-alias=@acme/* --eslint --src-dir --no-tailwind
  • CNA options matrix - app > --app --turbo --js --import-alias=@acme/* --eslint --no-src-dir --tailwind
  • CNA options matrix - app > --app --turbo --js --import-alias=@acme/* --eslint --no-src-dir --no-tailwind
  • CNA options matrix - app > --app --turbo --js --import-alias=@/* --eslint --src-dir --tailwind
  • CNA options matrix - app > --app --turbo --js --import-alias=@/* --eslint --src-dir --no-tailwind
  • CNA options matrix - app > --app --turbo --js --import-alias=@/* --eslint --no-src-dir --tailwind
  • CNA options matrix - app > --app --turbo --js --import-alias=@/* --eslint --no-src-dir --no-tailwind
  • CNA options matrix - app > --app --turbo --js --no-import-alias --eslint --src-dir --tailwind
  • CNA options matrix - app > --app --turbo --js --no-import-alias --eslint --src-dir --no-tailwind
  • CNA options matrix - app > --app --turbo --js --no-import-alias --eslint --no-src-dir --tailwind
  • CNA options matrix - app > --app --turbo --js --no-import-alias --eslint --no-src-dir --no-tailwind
  • CNA options matrix - app > --app --turbo --ts --import-alias=@acme/* --eslint --src-dir --tailwind
  • CNA options matrix - app > --app --turbo --ts --import-alias=@acme/* --eslint --src-dir --no-tailwind
  • CNA options matrix - app > --app --turbo --ts --import-alias=@acme/* --eslint --no-src-dir --tailwind
  • CNA options matrix - app > --app --turbo --ts --import-alias=@acme/* --eslint --no-src-dir --no-tailwind
  • CNA options matrix - app > --app --turbo --ts --import-alias=@/* --eslint --src-dir --tailwind
  • CNA options matrix - app > --app --turbo --ts --import-alias=@/* --eslint --src-dir --no-tailwind
  • CNA options matrix - app > --app --turbo --ts --import-alias=@/* --eslint --no-src-dir --tailwind
  • CNA options matrix - app > --app --turbo --ts --import-alias=@/* --eslint --no-src-dir --no-tailwind
  • CNA options matrix - app > --app --turbo --ts --no-import-alias --eslint --src-dir --tailwind
  • CNA options matrix - app > --app --turbo --ts --no-import-alias --eslint --src-dir --no-tailwind
  • CNA options matrix - app > --app --turbo --ts --no-import-alias --eslint --no-src-dir --tailwind
  • CNA options matrix - app > --app --turbo --ts --no-import-alias --eslint --no-src-dir --no-tailwind
Expand output

● CNA options matrix - app › --app --turbo --js --import-alias=@acme/* --eslint --src-dir --tailwind

expect(received).toBe(expected) // Object.is equality

Expected: 200
Received: 500

  67 |       expect(await res.text()).toContain('Get started by editing')
  68 |     }
> 69 |     expect(res.status).toBe(200)
     |                        ^
  70 |
  71 |     if (!isApp && !isEmpty) {
  72 |       const apiRes = await fetchViaHTTP(port, '/api/hello')

  at toBe (integration/create-next-app/utils.ts:69:24)
  at integration/create-next-app/templates/matrix.test.ts:71:9
  at useTempDir (lib/use-temp-dir.ts:24:5)
  at integration/create-next-app/templates/matrix.test.ts:60:7

● CNA options matrix - app › --app --turbo --js --import-alias=@acme/* --eslint --src-dir --no-tailwind

expect(received).toBe(expected) // Object.is equality

Expected: 200
Received: 500

  67 |       expect(await res.text()).toContain('Get started by editing')
  68 |     }
> 69 |     expect(res.status).toBe(200)
     |                        ^
  70 |
  71 |     if (!isApp && !isEmpty) {
  72 |       const apiRes = await fetchViaHTTP(port, '/api/hello')

  at toBe (integration/create-next-app/utils.ts:69:24)
  at integration/create-next-app/templates/matrix.test.ts:71:9
  at useTempDir (lib/use-temp-dir.ts:24:5)
  at integration/create-next-app/templates/matrix.test.ts:60:7

● CNA options matrix - app › --app --turbo --js --import-alias=@acme/* --eslint --no-src-dir --tailwind

expect(received).toBe(expected) // Object.is equality

Expected: 200
Received: 500

  67 |       expect(await res.text()).toContain('Get started by editing')
  68 |     }
> 69 |     expect(res.status).toBe(200)
     |                        ^
  70 |
  71 |     if (!isApp && !isEmpty) {
  72 |       const apiRes = await fetchViaHTTP(port, '/api/hello')

  at toBe (integration/create-next-app/utils.ts:69:24)
  at integration/create-next-app/templates/matrix.test.ts:71:9
  at useTempDir (lib/use-temp-dir.ts:24:5)
  at integration/create-next-app/templates/matrix.test.ts:60:7

● CNA options matrix - app › --app --turbo --js --import-alias=@acme/* --eslint --no-src-dir --no-tailwind

expect(received).toBe(expected) // Object.is equality

Expected: 200
Received: 500

  67 |       expect(await res.text()).toContain('Get started by editing')
  68 |     }
> 69 |     expect(res.status).toBe(200)
     |                        ^
  70 |
  71 |     if (!isApp && !isEmpty) {
  72 |       const apiRes = await fetchViaHTTP(port, '/api/hello')

  at toBe (integration/create-next-app/utils.ts:69:24)
  at integration/create-next-app/templates/matrix.test.ts:71:9
  at useTempDir (lib/use-temp-dir.ts:24:5)
  at integration/create-next-app/templates/matrix.test.ts:60:7

● CNA options matrix - app › --app --turbo --js --import-alias=@/* --eslint --src-dir --tailwind

expect(received).toBe(expected) // Object.is equality

Expected: 200
Received: 500

  67 |       expect(await res.text()).toContain('Get started by editing')
  68 |     }
> 69 |     expect(res.status).toBe(200)
     |                        ^
  70 |
  71 |     if (!isApp && !isEmpty) {
  72 |       const apiRes = await fetchViaHTTP(port, '/api/hello')

  at toBe (integration/create-next-app/utils.ts:69:24)
  at integration/create-next-app/templates/matrix.test.ts:71:9
  at useTempDir (lib/use-temp-dir.ts:24:5)
  at integration/create-next-app/templates/matrix.test.ts:60:7

● CNA options matrix - app › --app --turbo --js --import-alias=@/* --eslint --src-dir --no-tailwind

expect(received).toBe(expected) // Object.is equality

Expected: 200
Received: 500

  67 |       expect(await res.text()).toContain('Get started by editing')
  68 |     }
> 69 |     expect(res.status).toBe(200)
     |                        ^
  70 |
  71 |     if (!isApp && !isEmpty) {
  72 |       const apiRes = await fetchViaHTTP(port, '/api/hello')

  at toBe (integration/create-next-app/utils.ts:69:24)
  at integration/create-next-app/templates/matrix.test.ts:71:9
  at useTempDir (lib/use-temp-dir.ts:24:5)
  at integration/create-next-app/templates/matrix.test.ts:60:7

● CNA options matrix - app › --app --turbo --js --import-alias=@/* --eslint --no-src-dir --tailwind

expect(received).toBe(expected) // Object.is equality

Expected: 200
Received: 500

  67 |       expect(await res.text()).toContain('Get started by editing')
  68 |     }
> 69 |     expect(res.status).toBe(200)
     |                        ^
  70 |
  71 |     if (!isApp && !isEmpty) {
  72 |       const apiRes = await fetchViaHTTP(port, '/api/hello')

  at toBe (integration/create-next-app/utils.ts:69:24)
  at integration/create-next-app/templates/matrix.test.ts:71:9
  at useTempDir (lib/use-temp-dir.ts:24:5)
  at integration/create-next-app/templates/matrix.test.ts:60:7

● CNA options matrix - app › --app --turbo --js --import-alias=@/* --eslint --no-src-dir --no-tailwind

expect(received).toBe(expected) // Object.is equality

Expected: 200
Received: 500

  67 |       expect(await res.text()).toContain('Get started by editing')
  68 |     }
> 69 |     expect(res.status).toBe(200)
     |                        ^
  70 |
  71 |     if (!isApp && !isEmpty) {
  72 |       const apiRes = await fetchViaHTTP(port, '/api/hello')

  at toBe (integration/create-next-app/utils.ts:69:24)
  at integration/create-next-app/templates/matrix.test.ts:71:9
  at useTempDir (lib/use-temp-dir.ts:24:5)
  at integration/create-next-app/templates/matrix.test.ts:60:7

● CNA options matrix - app › --app --turbo --js --no-import-alias --eslint --src-dir --tailwind

expect(received).toBe(expected) // Object.is equality

Expected: 200
Received: 500

  67 |       expect(await res.text()).toContain('Get started by editing')
  68 |     }
> 69 |     expect(res.status).toBe(200)
     |                        ^
  70 |
  71 |     if (!isApp && !isEmpty) {
  72 |       const apiRes = await fetchViaHTTP(port, '/api/hello')

  at toBe (integration/create-next-app/utils.ts:69:24)
  at integration/create-next-app/templates/matrix.test.ts:71:9
  at useTempDir (lib/use-temp-dir.ts:24:5)
  at integration/create-next-app/templates/matrix.test.ts:60:7

● CNA options matrix - app › --app --turbo --js --no-import-alias --eslint --src-dir --no-tailwind

expect(received).toBe(expected) // Object.is equality

Expected: 200
Received: 500

  67 |       expect(await res.text()).toContain('Get started by editing')
  68 |     }
> 69 |     expect(res.status).toBe(200)
     |                        ^
  70 |
  71 |     if (!isApp && !isEmpty) {
  72 |       const apiRes = await fetchViaHTTP(port, '/api/hello')

  at toBe (integration/create-next-app/utils.ts:69:24)
  at integration/create-next-app/templates/matrix.test.ts:71:9
  at useTempDir (lib/use-temp-dir.ts:24:5)
  at integration/create-next-app/templates/matrix.test.ts:60:7

● CNA options matrix - app › --app --turbo --js --no-import-alias --eslint --no-src-dir --tailwind

expect(received).toBe(expected) // Object.is equality

Expected: 200
Received: 500

  67 |       expect(await res.text()).toContain('Get started by editing')
  68 |     }
> 69 |     expect(res.status).toBe(200)
     |                        ^
  70 |
  71 |     if (!isApp && !isEmpty) {
  72 |       const apiRes = await fetchViaHTTP(port, '/api/hello')

  at toBe (integration/create-next-app/utils.ts:69:24)
  at integration/create-next-app/templates/matrix.test.ts:71:9
  at useTempDir (lib/use-temp-dir.ts:24:5)
  at integration/create-next-app/templates/matrix.test.ts:60:7

● CNA options matrix - app › --app --turbo --js --no-import-alias --eslint --no-src-dir --no-tailwind

expect(received).toBe(expected) // Object.is equality

Expected: 200
Received: 500

  67 |       expect(await res.text()).toContain('Get started by editing')
  68 |     }
> 69 |     expect(res.status).toBe(200)
     |                        ^
  70 |
  71 |     if (!isApp && !isEmpty) {
  72 |       const apiRes = await fetchViaHTTP(port, '/api/hello')

  at toBe (integration/create-next-app/utils.ts:69:24)
  at integration/create-next-app/templates/matrix.test.ts:71:9
  at useTempDir (lib/use-temp-dir.ts:24:5)
  at integration/create-next-app/templates/matrix.test.ts:60:7

● CNA options matrix - app › --app --turbo --ts --import-alias=@acme/* --eslint --src-dir --tailwind

expect(received).toBe(expected) // Object.is equality

Expected: 200
Received: 500

  67 |       expect(await res.text()).toContain('Get started by editing')
  68 |     }
> 69 |     expect(res.status).toBe(200)
     |                        ^
  70 |
  71 |     if (!isApp && !isEmpty) {
  72 |       const apiRes = await fetchViaHTTP(port, '/api/hello')

  at toBe (integration/create-next-app/utils.ts:69:24)
  at integration/create-next-app/templates/matrix.test.ts:71:9
  at useTempDir (lib/use-temp-dir.ts:24:5)
  at integration/create-next-app/templates/matrix.test.ts:60:7

● CNA options matrix - app › --app --turbo --ts --import-alias=@acme/* --eslint --src-dir --no-tailwind

expect(received).toBe(expected) // Object.is equality

Expected: 200
Received: 500

  67 |       expect(await res.text()).toContain('Get started by editing')
  68 |     }
> 69 |     expect(res.status).toBe(200)
     |                        ^
  70 |
  71 |     if (!isApp && !isEmpty) {
  72 |       const apiRes = await fetchViaHTTP(port, '/api/hello')

  at toBe (integration/create-next-app/utils.ts:69:24)
  at integration/create-next-app/templates/matrix.test.ts:71:9
  at useTempDir (lib/use-temp-dir.ts:24:5)
  at integration/create-next-app/templates/matrix.test.ts:60:7

● CNA options matrix - app › --app --turbo --ts --import-alias=@acme/* --eslint --no-src-dir --tailwind

expect(received).toBe(expected) // Object.is equality

Expected: 200
Received: 500

  67 |       expect(await res.text()).toContain('Get started by editing')
  68 |     }
> 69 |     expect(res.status).toBe(200)
     |                        ^
  70 |
  71 |     if (!isApp && !isEmpty) {
  72 |       const apiRes = await fetchViaHTTP(port, '/api/hello')

  at toBe (integration/create-next-app/utils.ts:69:24)
  at integration/create-next-app/templates/matrix.test.ts:71:9
  at useTempDir (lib/use-temp-dir.ts:24:5)
  at integration/create-next-app/templates/matrix.test.ts:60:7

● CNA options matrix - app › --app --turbo --ts --import-alias=@acme/* --eslint --no-src-dir --no-tailwind

expect(received).toBe(expected) // Object.is equality

Expected: 200
Received: 500

  67 |       expect(await res.text()).toContain('Get started by editing')
  68 |     }
> 69 |     expect(res.status).toBe(200)
     |                        ^
  70 |
  71 |     if (!isApp && !isEmpty) {
  72 |       const apiRes = await fetchViaHTTP(port, '/api/hello')

  at toBe (integration/create-next-app/utils.ts:69:24)
  at integration/create-next-app/templates/matrix.test.ts:71:9
  at useTempDir (lib/use-temp-dir.ts:24:5)
  at integration/create-next-app/templates/matrix.test.ts:60:7

● CNA options matrix - app › --app --turbo --ts --import-alias=@/* --eslint --src-dir --tailwind

expect(received).toBe(expected) // Object.is equality

Expected: 200
Received: 500

  67 |       expect(await res.text()).toContain('Get started by editing')
  68 |     }
> 69 |     expect(res.status).toBe(200)
     |                        ^
  70 |
  71 |     if (!isApp && !isEmpty) {
  72 |       const apiRes = await fetchViaHTTP(port, '/api/hello')

  at toBe (integration/create-next-app/utils.ts:69:24)
  at integration/create-next-app/templates/matrix.test.ts:71:9
  at useTempDir (lib/use-temp-dir.ts:24:5)
  at integration/create-next-app/templates/matrix.test.ts:60:7

● CNA options matrix - app › --app --turbo --ts --import-alias=@/* --eslint --src-dir --no-tailwind

expect(received).toBe(expected) // Object.is equality

Expected: 200
Received: 500

  67 |       expect(await res.text()).toContain('Get started by editing')
  68 |     }
> 69 |     expect(res.status).toBe(200)
     |                        ^
  70 |
  71 |     if (!isApp && !isEmpty) {
  72 |       const apiRes = await fetchViaHTTP(port, '/api/hello')

  at toBe (integration/create-next-app/utils.ts:69:24)
  at integration/create-next-app/templates/matrix.test.ts:71:9
  at useTempDir (lib/use-temp-dir.ts:24:5)
  at integration/create-next-app/templates/matrix.test.ts:60:7

● CNA options matrix - app › --app --turbo --ts --import-alias=@/* --eslint --no-src-dir --tailwind

expect(received).toBe(expected) // Object.is equality

Expected: 200
Received: 500

  67 |       expect(await res.text()).toContain('Get started by editing')
  68 |     }
> 69 |     expect(res.status).toBe(200)
     |                        ^
  70 |
  71 |     if (!isApp && !isEmpty) {
  72 |       const apiRes = await fetchViaHTTP(port, '/api/hello')

  at toBe (integration/create-next-app/utils.ts:69:24)
  at integration/create-next-app/templates/matrix.test.ts:71:9
  at useTempDir (lib/use-temp-dir.ts:24:5)
  at integration/create-next-app/templates/matrix.test.ts:60:7

● CNA options matrix - app › --app --turbo --ts --import-alias=@/* --eslint --no-src-dir --no-tailwind

expect(received).toBe(expected) // Object.is equality

Expected: 200
Received: 500

  67 |       expect(await res.text()).toContain('Get started by editing')
  68 |     }
> 69 |     expect(res.status).toBe(200)
     |                        ^
  70 |
  71 |     if (!isApp && !isEmpty) {
  72 |       const apiRes = await fetchViaHTTP(port, '/api/hello')

  at toBe (integration/create-next-app/utils.ts:69:24)
  at integration/create-next-app/templates/matrix.test.ts:71:9
  at useTempDir (lib/use-temp-dir.ts:24:5)
  at integration/create-next-app/templates/matrix.test.ts:60:7

● CNA options matrix - app › --app --turbo --ts --no-import-alias --eslint --src-dir --tailwind

expect(received).toBe(expected) // Object.is equality

Expected: 200
Received: 500

  67 |       expect(await res.text()).toContain('Get started by editing')
  68 |     }
> 69 |     expect(res.status).toBe(200)
     |                        ^
  70 |
  71 |     if (!isApp && !isEmpty) {
  72 |       const apiRes = await fetchViaHTTP(port, '/api/hello')

  at toBe (integration/create-next-app/utils.ts:69:24)
  at integration/create-next-app/templates/matrix.test.ts:71:9
  at useTempDir (lib/use-temp-dir.ts:24:5)
  at integration/create-next-app/templates/matrix.test.ts:60:7

● CNA options matrix - app › --app --turbo --ts --no-import-alias --eslint --src-dir --no-tailwind

expect(received).toBe(expected) // Object.is equality

Expected: 200
Received: 500

  67 |       expect(await res.text()).toContain('Get started by editing')
  68 |     }
> 69 |     expect(res.status).toBe(200)
     |                        ^
  70 |
  71 |     if (!isApp && !isEmpty) {
  72 |       const apiRes = await fetchViaHTTP(port, '/api/hello')

  at toBe (integration/create-next-app/utils.ts:69:24)
  at integration/create-next-app/templates/matrix.test.ts:71:9
  at useTempDir (lib/use-temp-dir.ts:24:5)
  at integration/create-next-app/templates/matrix.test.ts:60:7

● CNA options matrix - app › --app --turbo --ts --no-import-alias --eslint --no-src-dir --tailwind

expect(received).toBe(expected) // Object.is equality

Expected: 200
Received: 500

  67 |       expect(await res.text()).toContain('Get started by editing')
  68 |     }
> 69 |     expect(res.status).toBe(200)
     |                        ^
  70 |
  71 |     if (!isApp && !isEmpty) {
  72 |       const apiRes = await fetchViaHTTP(port, '/api/hello')

  at toBe (integration/create-next-app/utils.ts:69:24)
  at integration/create-next-app/templates/matrix.test.ts:71:9
  at useTempDir (lib/use-temp-dir.ts:24:5)
  at integration/create-next-app/templates/matrix.test.ts:60:7

● CNA options matrix - app › --app --turbo --ts --no-import-alias --eslint --no-src-dir --no-tailwind

expect(received).toBe(expected) // Object.is equality

Expected: 200
Received: 500

  67 |       expect(await res.text()).toContain('Get started by editing')
  68 |     }
> 69 |     expect(res.status).toBe(200)
     |                        ^
  70 |
  71 |     if (!isApp && !isEmpty) {
  72 |       const apiRes = await fetchViaHTTP(port, '/api/hello')

  at toBe (integration/create-next-app/utils.ts:69:24)
  at integration/create-next-app/templates/matrix.test.ts:71:9
  at useTempDir (lib/use-temp-dir.ts:24:5)
  at integration/create-next-app/templates/matrix.test.ts:60:7

Read more about building and testing Next.js in contributing.md.

@ijjk
Copy link
Member

ijjk commented Oct 4, 2024

Stats from current PR

Default Build (Increase detected ⚠️)
General Overall increase ⚠️
vercel/next.js canary vercel/next.js update/react/1460d67c-20241003 Change
buildDuration 18.8s 16s N/A
buildDurationCached 15.5s 13.2s N/A
nodeModulesSize 370 MB 370 MB ⚠️ +186 kB
nextStartRea..uration (ms) 430ms 434ms N/A
Client Bundles (main, webpack) Overall increase ⚠️
vercel/next.js canary vercel/next.js update/react/1460d67c-20241003 Change
6418.HASH.js gzip 168 B 169 B N/A
818-HASH.js gzip 44 kB 44.1 kB ⚠️ +128 B
8c961940-HASH.js gzip 52.8 kB 52.7 kB N/A
929-HASH.js gzip 5.27 kB 5.26 kB N/A
framework-HASH.js gzip 57.5 kB 57.5 kB
main-app-HASH.js gzip 230 B 235 B N/A
main-HASH.js gzip 32.7 kB 32.7 kB N/A
webpack-HASH.js gzip 1.71 kB 1.71 kB N/A
Overall change 101 kB 102 kB ⚠️ +128 B
Legacy Client Bundles (polyfills)
vercel/next.js canary vercel/next.js update/react/1460d67c-20241003 Change
polyfills-HASH.js gzip 39.4 kB 39.4 kB
Overall change 39.4 kB 39.4 kB
Client Pages
vercel/next.js canary vercel/next.js update/react/1460d67c-20241003 Change
_app-HASH.js gzip 193 B 192 B N/A
_error-HASH.js gzip 192 B 192 B
amp-HASH.js gzip 506 B 506 B
css-HASH.js gzip 343 B 343 B
dynamic-HASH.js gzip 1.84 kB 1.83 kB N/A
edge-ssr-HASH.js gzip 266 B 265 B N/A
head-HASH.js gzip 365 B 365 B
hooks-HASH.js gzip 389 B 389 B
image-HASH.js gzip 4.41 kB 4.4 kB N/A
index-HASH.js gzip 268 B 268 B
link-HASH.js gzip 2.77 kB 2.78 kB N/A
routerDirect..HASH.js gzip 328 B 327 B N/A
script-HASH.js gzip 395 B 397 B N/A
withRouter-HASH.js gzip 323 B 324 B N/A
1afbb74e6ecf..834.css gzip 106 B 106 B
Overall change 2.17 kB 2.17 kB
Client Build Manifests
vercel/next.js canary vercel/next.js update/react/1460d67c-20241003 Change
_buildManifest.js gzip 751 B 748 B N/A
Overall change 0 B 0 B
Rendered Page Sizes
vercel/next.js canary vercel/next.js update/react/1460d67c-20241003 Change
index.html gzip 522 B 524 B N/A
link.html gzip 537 B 538 B N/A
withRouter.html gzip 516 B 520 B N/A
Overall change 0 B 0 B
Edge SSR bundle Size Overall increase ⚠️
vercel/next.js canary vercel/next.js update/react/1460d67c-20241003 Change
edge-ssr.js gzip 129 kB 129 kB
page.js gzip 187 kB 187 kB ⚠️ +154 B
Overall change 315 kB 316 kB ⚠️ +154 B
Middleware size
vercel/next.js canary vercel/next.js update/react/1460d67c-20241003 Change
middleware-b..fest.js gzip 668 B 668 B
middleware-r..fest.js gzip 155 B 156 B N/A
middleware.js gzip 30.1 kB 30.1 kB N/A
edge-runtime..pack.js gzip 844 B 844 B
Overall change 1.51 kB 1.51 kB
Next Runtimes Overall increase ⚠️
vercel/next.js canary vercel/next.js update/react/1460d67c-20241003 Change
973-experime...dev.js gzip 322 B 322 B
973.runtime.dev.js gzip 314 B 314 B
app-page-exp...dev.js gzip 310 kB 311 kB ⚠️ +1.47 kB
app-page-exp..prod.js gzip 119 kB 119 kB ⚠️ +111 B
app-page-tur..prod.js gzip 133 kB 133 kB ⚠️ +118 B
app-page-tur..prod.js gzip 128 kB 128 kB N/A
app-page.run...dev.js gzip 300 kB 302 kB ⚠️ +1.53 kB
app-page.run..prod.js gzip 115 kB 115 kB N/A
app-route-ex...dev.js gzip 34.3 kB 34.3 kB N/A
app-route-ex..prod.js gzip 23.2 kB 23.2 kB
app-route-tu..prod.js gzip 23.2 kB 23.2 kB N/A
app-route-tu..prod.js gzip 23 kB 23 kB N/A
app-route.ru...dev.js gzip 35.9 kB 35.9 kB
app-route.ru..prod.js gzip 23 kB 23 kB
pages-api-tu..prod.js gzip 9.62 kB 9.62 kB
pages-api.ru...dev.js gzip 11.5 kB 11.5 kB
pages-api.ru..prod.js gzip 9.61 kB 9.61 kB
pages-turbo...prod.js gzip 20.9 kB 20.9 kB
pages.runtim...dev.js gzip 26.5 kB 26.5 kB
pages.runtim..prod.js gzip 20.9 kB 20.9 kB
server.runti..prod.js gzip 57.5 kB 57.5 kB
Overall change 1.1 MB 1.1 MB ⚠️ +3.23 kB
build cache Overall increase ⚠️
vercel/next.js canary vercel/next.js update/react/1460d67c-20241003 Change
0.pack gzip 1.84 MB 1.84 MB ⚠️ +1.96 kB
index.pack gzip 142 kB 142 kB N/A
Overall change 1.84 MB 1.84 MB ⚠️ +1.96 kB
Diff details
Diff for page.js
@@ -15,7 +15,7 @@
       /***/
     },
 
-    /***/ 9261: /***/ (
+    /***/ 7544: /***/ (
       __unused_webpack_module,
       __webpack_exports__,
       __webpack_require__
@@ -30,7 +30,7 @@
         default: () => /* binding */ nHandler,
       });
 
-      // NAMESPACE OBJECT: ./node_modules/.pnpm/next@file+..+main-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-1460d67c-20241003_re_wwvutoix5dph4lb7oeg7lue6vi/node_modules/next/dist/build/webpack/loaders/next-app-loader/index.js?name=app%2Fapp-edge-ssr%2Fpage&page=%2Fapp-edge-ssr%2Fpage&pagePath=private-next-app-dir%2Fapp-edge-ssr%2Fpage.js&appDir=%2Ftmp%2Fnext-statswVULoJ%2Fstats-app%2Fapp&appPaths=%2Fapp-edge-ssr%2Fpage&pageExtensions=tsx&pageExtensions=ts&pageExtensions=jsx&pageExtensions=js&basePath=&assetPrefix=&nextConfigOutput=&flyingShuttle=false&preferredRegion=&middlewareConfig=e30%3D!./app/app-edge-ssr/page.js?__next_edge_ssr_entry__
+      // NAMESPACE OBJECT: ./node_modules/.pnpm/next@file+..+diff-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-1460d67c-20241003_re_xhiccmn4ilb7rw6c7k3st4s3bi/node_modules/next/dist/build/webpack/loaders/next-app-loader/index.js?name=app%2Fapp-edge-ssr%2Fpage&page=%2Fapp-edge-ssr%2Fpage&pagePath=private-next-app-dir%2Fapp-edge-ssr%2Fpage.js&appDir=%2Ftmp%2Fnext-statswVULoJ%2Fstats-app%2Fapp&appPaths=%2Fapp-edge-ssr%2Fpage&pageExtensions=tsx&pageExtensions=ts&pageExtensions=jsx&pageExtensions=js&basePath=&assetPrefix=&nextConfigOutput=&flyingShuttle=false&preferredRegion=&middlewareConfig=e30%3D!./app/app-edge-ssr/page.js?__next_edge_ssr_entry__
       var page_next_edge_ssr_entry_namespaceObject = {};
       __webpack_require__.r(page_next_edge_ssr_entry_namespaceObject);
       __webpack_require__.d(page_next_edge_ssr_entry_namespaceObject, {
@@ -80,35 +80,35 @@
         workAsyncStorage: () => entry_base /* workAsyncStorage */.eP,
       });
 
-      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+main-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-1460d67c-20241003_re_wwvutoix5dph4lb7oeg7lue6vi/node_modules/next/dist/esm/server/web/globals.js
-      var globals = __webpack_require__(5629);
-      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+main-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-1460d67c-20241003_re_wwvutoix5dph4lb7oeg7lue6vi/node_modules/next/dist/esm/server/web/adapter.js + 3 modules
-      var adapter = __webpack_require__(8187);
-      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+main-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-1460d67c-20241003_re_wwvutoix5dph4lb7oeg7lue6vi/node_modules/next/dist/esm/build/webpack/loaders/next-edge-ssr-loader/render.js + 89 modules
-      var render = __webpack_require__(883);
-      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+main-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-1460d67c-20241003_re_wwvutoix5dph4lb7oeg7lue6vi/node_modules/next/dist/esm/server/lib/incremental-cache/index.js + 3 modules
-      var incremental_cache = __webpack_require__(3950);
-      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+main-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-1460d67c-20241003_re_wwvutoix5dph4lb7oeg7lue6vi/node_modules/next/dist/esm/server/app-render/app-render.js + 61 modules
-      var app_render = __webpack_require__(6702);
-      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+main-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-1460d67c-20241003_re_wwvutoix5dph4lb7oeg7lue6vi/node_modules/next/dist/esm/server/route-modules/app-page/module.compiled.js
-      var module_compiled = __webpack_require__(2677);
-      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+main-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-1460d67c-20241003_re_wwvutoix5dph4lb7oeg7lue6vi/node_modules/next/dist/esm/server/route-kind.js
-      var route_kind = __webpack_require__(9455);
-      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+main-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-1460d67c-20241003_re_wwvutoix5dph4lb7oeg7lue6vi/node_modules/next/dist/esm/client/components/error-boundary.js
-      var error_boundary = __webpack_require__(1958);
-      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+main-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-1460d67c-20241003_re_wwvutoix5dph4lb7oeg7lue6vi/node_modules/next/dist/esm/server/app-render/entry-base.js + 29 modules
-      var entry_base = __webpack_require__(8175); // CONCATENATED MODULE: ./node_modules/.pnpm/next@file+..+main-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-1460d67c-20241003_re_wwvutoix5dph4lb7oeg7lue6vi/node_modules/next/dist/build/webpack/loaders/next-app-loader/index.js?name=app%2Fapp-edge-ssr%2Fpage&page=%2Fapp-edge-ssr%2Fpage&pagePath=private-next-app-dir%2Fapp-edge-ssr%2Fpage.js&appDir=%2Ftmp%2Fnext-statswVULoJ%2Fstats-app%2Fapp&appPaths=%2Fapp-edge-ssr%2Fpage&pageExtensions=tsx&pageExtensions=ts&pageExtensions=jsx&pageExtensions=js&basePath=&assetPrefix=&nextConfigOutput=&flyingShuttle=false&preferredRegion=&middlewareConfig=e30%3D!./app/app-edge-ssr/page.js?__next_edge_ssr_entry__
+      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+diff-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-1460d67c-20241003_re_xhiccmn4ilb7rw6c7k3st4s3bi/node_modules/next/dist/esm/server/web/globals.js
+      var globals = __webpack_require__(4864);
+      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+diff-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-1460d67c-20241003_re_xhiccmn4ilb7rw6c7k3st4s3bi/node_modules/next/dist/esm/server/web/adapter.js + 3 modules
+      var adapter = __webpack_require__(267);
+      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+diff-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-1460d67c-20241003_re_xhiccmn4ilb7rw6c7k3st4s3bi/node_modules/next/dist/esm/build/webpack/loaders/next-edge-ssr-loader/render.js + 89 modules
+      var render = __webpack_require__(8234);
+      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+diff-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-1460d67c-20241003_re_xhiccmn4ilb7rw6c7k3st4s3bi/node_modules/next/dist/esm/server/lib/incremental-cache/index.js + 3 modules
+      var incremental_cache = __webpack_require__(6386);
+      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+diff-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-1460d67c-20241003_re_xhiccmn4ilb7rw6c7k3st4s3bi/node_modules/next/dist/esm/server/app-render/app-render.js + 61 modules
+      var app_render = __webpack_require__(3538);
+      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+diff-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-1460d67c-20241003_re_xhiccmn4ilb7rw6c7k3st4s3bi/node_modules/next/dist/esm/server/route-modules/app-page/module.compiled.js
+      var module_compiled = __webpack_require__(6218);
+      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+diff-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-1460d67c-20241003_re_xhiccmn4ilb7rw6c7k3st4s3bi/node_modules/next/dist/esm/server/route-kind.js
+      var route_kind = __webpack_require__(2953);
+      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+diff-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-1460d67c-20241003_re_xhiccmn4ilb7rw6c7k3st4s3bi/node_modules/next/dist/esm/client/components/error-boundary.js
+      var error_boundary = __webpack_require__(7158);
+      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+diff-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-1460d67c-20241003_re_xhiccmn4ilb7rw6c7k3st4s3bi/node_modules/next/dist/esm/server/app-render/entry-base.js + 29 modules
+      var entry_base = __webpack_require__(6138); // CONCATENATED MODULE: ./node_modules/.pnpm/next@file+..+diff-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-1460d67c-20241003_re_xhiccmn4ilb7rw6c7k3st4s3bi/node_modules/next/dist/build/webpack/loaders/next-app-loader/index.js?name=app%2Fapp-edge-ssr%2Fpage&page=%2Fapp-edge-ssr%2Fpage&pagePath=private-next-app-dir%2Fapp-edge-ssr%2Fpage.js&appDir=%2Ftmp%2Fnext-statswVULoJ%2Fstats-app%2Fapp&appPaths=%2Fapp-edge-ssr%2Fpage&pageExtensions=tsx&pageExtensions=ts&pageExtensions=jsx&pageExtensions=js&basePath=&assetPrefix=&nextConfigOutput=&flyingShuttle=false&preferredRegion=&middlewareConfig=e30%3D!./app/app-edge-ssr/page.js?__next_edge_ssr_entry__
       const module0 = () =>
         Promise.resolve(/* import() eager */).then(
-          __webpack_require__.bind(__webpack_require__, 7355)
+          __webpack_require__.bind(__webpack_require__, 1458)
         );
       const module1 = () =>
         Promise.resolve(/* import() eager */).then(
-          __webpack_require__.bind(__webpack_require__, 1888)
+          __webpack_require__.bind(__webpack_require__, 1007)
         );
       const page2 = () =>
         Promise.resolve(/* import() eager */).then(
-          __webpack_require__.bind(__webpack_require__, 7780)
+          __webpack_require__.bind(__webpack_require__, 2424)
         );
 
       // We inject the tree and pages here so that we can use them in the route
@@ -171,12 +171,12 @@
       });
 
       //# sourceMappingURL=app-page.js.map
-      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+main-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-1460d67c-20241003_re_wwvutoix5dph4lb7oeg7lue6vi/node_modules/next/dist/esm/lib/page-types.js
-      var page_types = __webpack_require__(8586);
-      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+main-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-1460d67c-20241003_re_wwvutoix5dph4lb7oeg7lue6vi/node_modules/next/dist/esm/server/app-render/encryption-utils.js
-      var encryption_utils = __webpack_require__(551);
-      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+main-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-1460d67c-20241003_re_wwvutoix5dph4lb7oeg7lue6vi/node_modules/next/dist/esm/server/app-render/action-utils.js
-      var action_utils = __webpack_require__(7541); // CONCATENATED MODULE: ./node_modules/.pnpm/next@file+..+main-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-1460d67c-20241003_re_wwvutoix5dph4lb7oeg7lue6vi/node_modules/next/dist/build/webpack/loaders/next-edge-ssr-loader/index.js?{"absolute500Path":"","absoluteAppPath":"next/dist/pages/_app","absoluteDocumentPath":"next/dist/pages/_document","absoluteErrorPath":"next/dist/pages/_error","absolutePagePath":"private-next-app-dir/app-edge-ssr/page.js","dev":false,"isServerComponent":true,"page":"/app-edge-ssr/page","stringifiedConfig":"eyJlbnYiOnt9LCJlc2xpbnQiOnsiaWdub3JlRHVyaW5nQnVpbGRzIjpmYWxzZX0sInR5cGVzY3JpcHQiOnsiaWdub3JlQnVpbGRFcnJvcnMiOmZhbHNlLCJ0c2NvbmZpZ1BhdGgiOiJ0c2NvbmZpZy5qc29uIn0sImRpc3REaXIiOiIubmV4dCIsImNsZWFuRGlzdERpciI6dHJ1ZSwiYXNzZXRQcmVmaXgiOiIiLCJjYWNoZU1heE1lbW9yeVNpemUiOjUyNDI4ODAwLCJjb25maWdPcmlnaW4iOiJuZXh0LmNvbmZpZy5qcyIsInVzZUZpbGVTeXN0ZW1QdWJsaWNSb3V0ZXMiOnRydWUsImdlbmVyYXRlRXRhZ3MiOnRydWUsInBhZ2VFeHRlbnNpb25zIjpbInRzeCIsInRzIiwianN4IiwianMiXSwicG93ZXJlZEJ5SGVhZGVyIjp0cnVlLCJjb21wcmVzcyI6dHJ1ZSwiaW1hZ2VzIjp7ImRldmljZVNpemVzIjpbNjQwLDc1MCw4MjgsMTA4MCwxMjAwLDE5MjAsMjA0OCwzODQwXSwiaW1hZ2VTaXplcyI6WzE2LDMyLDQ4LDY0LDk2LDEyOCwyNTYsMzg0XSwicGF0aCI6Ii9fbmV4dC9pbWFnZSIsImxvYWRlciI6ImRlZmF1bHQiLCJsb2FkZXJGaWxlIjoiIiwiZG9tYWlucyI6W10sImRpc2FibGVTdGF0aWNJbWFnZXMiOmZhbHNlLCJtaW5pbXVtQ2FjaGVUVEwiOjYwLCJmb3JtYXRzIjpbImltYWdlL3dlYnAiXSwiZGFuZ2Vyb3VzbHlBbGxvd1NWRyI6ZmFsc2UsImNvbnRlbnRTZWN1cml0eVBvbGljeSI6InNjcmlwdC1zcmMgJ25vbmUnOyBmcmFtZS1zcmMgJ25vbmUnOyBzYW5kYm94OyIsImNvbnRlbnREaXNwb3NpdGlvblR5cGUiOiJhdHRhY2htZW50IiwicmVtb3RlUGF0dGVybnMiOltdLCJ1bm9wdGltaXplZCI6ZmFsc2V9LCJkZXZJbmRpY2F0b3JzIjp7ImFwcElzclN0YXR1cyI6dHJ1ZSwiYnVpbGRBY3Rpdml0eSI6dHJ1ZSwiYnVpbGRBY3Rpdml0eVBvc2l0aW9uIjoiYm90dG9tLXJpZ2h0In0sIm9uRGVtYW5kRW50cmllcyI6eyJtYXhJbmFjdGl2ZUFnZSI6NjAwMDAsInBhZ2VzQnVmZmVyTGVuZ3RoIjo1fSwiYW1wIjp7ImNhbm9uaWNhbEJhc2UiOiIifSwiYmFzZVBhdGgiOiIiLCJzYXNzT3B0aW9ucyI6e30sInRyYWlsaW5nU2xhc2giOmZhbHNlLCJpMThuIjpudWxsLCJwcm9kdWN0aW9uQnJvd3NlclNvdXJjZU1hcHMiOmZhbHNlLCJleGNsdWRlRGVmYXVsdE1vbWVudExvY2FsZXMiOnRydWUsInNlcnZlclJ1bnRpbWVDb25maWciOnt9LCJwdWJsaWNSdW50aW1lQ29uZmlnIjp7fSwicmVhY3RQcm9kdWN0aW9uUHJvZmlsaW5nIjpmYWxzZSwicmVhY3RTdHJpY3RNb2RlIjpudWxsLCJyZWFjdE1heEhlYWRlcnNMZW5ndGgiOjYwMDAsImh0dHBBZ2VudE9wdGlvbnMiOnsia2VlcEFsaXZlIjp0cnVlfSwibG9nZ2luZyI6e30sInN3ckRlbHRhIjozMTUzNjAwMCwic3RhdGljUGFnZUdlbmVyYXRpb25UaW1lb3V0Ijo2MCwibW9kdWxhcml6ZUltcG9ydHMiOnsiQG11aS9pY29ucy1tYXRlcmlhbCI6eyJ0cmFuc2Zvcm0iOiJAbXVpL2ljb25zLW1hdGVyaWFsL3t7bWVtYmVyfX0ifSwibG9kYXNoIjp7InRyYW5zZm9ybSI6ImxvZGFzaC97e21lbWJlcn19In19LCJvdXRwdXRGaWxlVHJhY2luZ1Jvb3QiOiIvdG1wL25leHQtc3RhdHN3VlVMb0ovc3RhdHMtYXBwIiwiZXhwZXJpbWVudGFsIjp7Im11bHRpWm9uZURyYWZ0TW9kZSI6ZmFsc2UsImFwcE5hdkZhaWxIYW5kbGluZyI6ZmFsc2UsInByZXJlbmRlckVhcmx5RXhpdCI6dHJ1ZSwic2VydmVyTWluaWZpY2F0aW9uIjp0cnVlLCJzZXJ2ZXJTb3VyY2VNYXBzIjpmYWxzZSwibGlua05vVG91Y2hTdGFydCI6ZmFsc2UsImNhc2VTZW5zaXRpdmVSb3V0ZXMiOmZhbHNlLCJwcmVsb2FkRW50cmllc09uU3RhcnQiOnRydWUsImNsaWVudFJvdXRlckZpbHRlciI6dHJ1ZSwiY2xpZW50Um91dGVyRmlsdGVyUmVkaXJlY3RzIjpmYWxzZSwiZmV0Y2hDYWNoZUtleVByZWZpeCI6IiIsIm1pZGRsZXdhcmVQcmVmZXRjaCI6ImZsZXhpYmxlIiwib3B0aW1pc3RpY0NsaWVudENhY2hlIjp0cnVlLCJtYW51YWxDbGllbnRCYXNlUGF0aCI6ZmFsc2UsImNwdXMiOjE5LCJtZW1vcnlCYXNlZFdvcmtlcnNDb3VudCI6ZmFsc2UsImlzckZsdXNoVG9EaXNrIjp0cnVlLCJ3b3JrZXJUaHJlYWRzIjpmYWxzZSwib3B0aW1pemVDc3MiOmZhbHNlLCJuZXh0U2NyaXB0V29ya2VycyI6ZmFsc2UsInNjcm9sbFJlc3RvcmF0aW9uIjpmYWxzZSwiZXh0ZXJuYWxEaXIiOmZhbHNlLCJkaXNhYmxlT3B0aW1pemVkTG9hZGluZyI6ZmFsc2UsImd6aXBTaXplIjp0cnVlLCJjcmFDb21wYXQiOmZhbHNlLCJlc21FeHRlcm5hbHMiOnRydWUsImZ1bGx5U3BlY2lmaWVkIjpmYWxzZSwic3djVHJhY2VQcm9maWxpbmciOmZhbHNlLCJmb3JjZVN3Y1RyYW5zZm9ybXMiOmZhbHNlLCJsYXJnZVBhZ2VEYXRhQnl0ZXMiOjEyODAwMCwidHVyYm8iOnsicm9vdCI6Ii90bXAvbmV4dC1zdGF0c3dWVUxvSi9zdGF0cy1hcHAifSwidHlwZWRSb3V0ZXMiOmZhbHNlLCJ0eXBlZEVudiI6ZmFsc2UsInBhcmFsbGVsU2VydmVyQ29tcGlsZXMiOmZhbHNlLCJwYXJhbGxlbFNlcnZlckJ1aWxkVHJhY2VzIjpmYWxzZSwicHByIjpmYWxzZSwicHByRmFsbGJhY2tzIjpmYWxzZSwid2VicGFja01lbW9yeU9wdGltaXphdGlvbnMiOmZhbHNlLCJvcHRpbWl6ZVNlcnZlclJlYWN0Ijp0cnVlLCJ1c2VFYXJseUltcG9ydCI6ZmFsc2UsInN0YWxlVGltZXMiOnsiZHluYW1pYyI6MCwic3RhdGljIjozMDB9LCJhZnRlciI6ZmFsc2UsInNlcnZlckNvbXBvbmVudHNIbXJDYWNoZSI6dHJ1ZSwic3RhdGljR2VuZXJhdGlvbk1heENvbmN1cnJlbmN5Ijo4LCJzdGF0aWNHZW5lcmF0aW9uTWluUGFnZXNQZXJXb3JrZXIiOjI1LCJkeW5hbWljSU8iOmZhbHNlLCJvcHRpbWl6ZVBhY2thZ2VJbXBvcnRzIjpbImx1Y2lkZS1yZWFjdCIsImRhdGUtZm5zIiwibG9kYXNoLWVzIiwicmFtZGEiLCJhbnRkIiwicmVhY3QtYm9vdHN0cmFwIiwiYWhvb2tzIiwiQGFudC1kZXNpZ24vaWNvbnMiLCJAaGVhZGxlc3N1aS9yZWFjdCIsIkBoZWFkbGVzc3VpLWZsb2F0L3JlYWN0IiwiQGhlcm9pY29ucy9yZWFjdC8yMC9zb2xpZCIsIkBoZXJvaWNvbnMvcmVhY3QvMjQvc29saWQiLCJAaGVyb2ljb25zL3JlYWN0LzI0L291dGxpbmUiLCJAdmlzeC92aXN4IiwiQHRyZW1vci9yZWFjdCIsInJ4anMiLCJAbXVpL21hdGVyaWFsIiwiQG11aS9pY29ucy1tYXRlcmlhbCIsInJlY2hhcnRzIiwicmVhY3QtdXNlIiwiZWZmZWN0IiwiQGVmZmVjdC9zY2hlbWEiLCJAZWZmZWN0L3BsYXRmb3JtIiwiQGVmZmVjdC9wbGF0Zm9ybS1ub2RlIiwiQGVmZmVjdC9wbGF0Zm9ybS1icm93c2VyIiwiQGVmZmVjdC9wbGF0Zm9ybS1idW4iLCJAZWZmZWN0L3NxbCIsIkBlZmZlY3Qvc3FsLW1zc3FsIiwiQGVmZmVjdC9zcWwtbXlzcWwyIiwiQGVmZmVjdC9zcWwtcGciLCJAZWZmZWN0L3NxbC1zcXVsaXRlLW5vZGUiLCJAZWZmZWN0L3NxbC1zcXVsaXRlLWJ1biIsIkBlZmZlY3Qvc3FsLXNxdWxpdGUtd2FzbSIsIkBlZmZlY3Qvc3FsLXNxdWxpdGUtcmVhY3QtbmF0aXZlIiwiQGVmZmVjdC9ycGMiLCJAZWZmZWN0L3JwYy1odHRwIiwiQGVmZmVjdC90eXBlY2xhc3MiLCJAZWZmZWN0L2V4cGVyaW1lbnRhbCIsIkBlZmZlY3Qvb3BlbnRlbGVtZXRyeSIsIkBtYXRlcmlhbC11aS9jb3JlIiwiQG1hdGVyaWFsLXVpL2ljb25zIiwiQHRhYmxlci9pY29ucy1yZWFjdCIsIm11aS1jb3JlIiwicmVhY3QtaWNvbnMvYWkiLCJyZWFjdC1pY29ucy9iaSIsInJlYWN0LWljb25zL2JzIiwicmVhY3QtaWNvbnMvY2ciLCJyZWFjdC1pY29ucy9jaSIsInJlYWN0LWljb25zL2RpIiwicmVhY3QtaWNvbnMvZmEiLCJyZWFjdC1pY29ucy9mYTYiLCJyZWFjdC1pY29ucy9mYyIsInJlYWN0LWljb25zL2ZpIiwicmVhY3QtaWNvbnMvZ2kiLCJyZWFjdC1pY29ucy9nbyIsInJlYWN0LWljb25zL2dyIiwicmVhY3QtaWNvbnMvaGkiLCJyZWFjdC1pY29ucy9oaTIiLCJyZWFjdC1pY29ucy9pbSIsInJlYWN0LWljb25zL2lvIiwicmVhY3QtaWNvbnMvaW81IiwicmVhY3QtaWNvbnMvbGlhIiwicmVhY3QtaWNvbnMvbGliIiwicmVhY3QtaWNvbnMvbHUiLCJyZWFjdC1pY29ucy9tZCIsInJlYWN0LWljb25zL3BpIiwicmVhY3QtaWNvbnMvcmkiLCJyZWFjdC1pY29ucy9yeCIsInJlYWN0LWljb25zL3NpIiwicmVhY3QtaWNvbnMvc2wiLCJyZWFjdC1pY29ucy90YiIsInJlYWN0LWljb25zL3RmaSIsInJlYWN0LWljb25zL3RpIiwicmVhY3QtaWNvbnMvdnNjIiwicmVhY3QtaWNvbnMvd2kiXX0sImJ1bmRsZVBhZ2VzUm91dGVyRGVwZW5kZW5jaWVzIjpmYWxzZSwiY29uZmlnRmlsZSI6Ii90bXAvbmV4dC1zdGF0c3dWVUxvSi9zdGF0cy1hcHAvbmV4dC5jb25maWcuanMiLCJjb25maWdGaWxlTmFtZSI6Im5leHQuY29uZmlnLmpzIn0=","pagesType":"app","appDirLoader":"bmV4dC1hcHAtbG9hZGVyP25hbWU9YXBwJTJGYXBwLWVkZ2Utc3NyJTJGcGFnZSZwYWdlPSUyRmFwcC1lZGdlLXNzciUyRnBhZ2UmcGFnZVBhdGg9cHJpdmF0ZS1uZXh0LWFwcC1kaXIlMkZhcHAtZWRnZS1zc3IlMkZwYWdlLmpzJmFwcERpcj0lMkZ0bXAlMkZuZXh0LXN0YXRzd1ZVTG9KJTJGc3RhdHMtYXBwJTJGYXBwJmFwcFBhdGhzPSUyRmFwcC1lZGdlLXNzciUyRnBhZ2UmcGFnZUV4dGVuc2lvbnM9dHN4JnBhZ2VFeHRlbnNpb25zPXRzJnBhZ2VFeHRlbnNpb25zPWpzeCZwYWdlRXh0ZW5zaW9ucz1qcyZiYXNlUGF0aD0mYXNzZXRQcmVmaXg9Jm5leHRDb25maWdPdXRwdXQ9JmZseWluZ1NodXR0bGU9ZmFsc2UmcHJlZmVycmVkUmVnaW9uPSZtaWRkbGV3YXJlQ29uZmlnPWUzMCUzRCE=","sriEnabled":false,"middlewareConfig":"e30="}!
+      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+diff-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-1460d67c-20241003_re_xhiccmn4ilb7rw6c7k3st4s3bi/node_modules/next/dist/esm/lib/page-types.js
+      var page_types = __webpack_require__(6911);
+      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+diff-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-1460d67c-20241003_re_xhiccmn4ilb7rw6c7k3st4s3bi/node_modules/next/dist/esm/server/app-render/encryption-utils.js
+      var encryption_utils = __webpack_require__(5970);
+      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+diff-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-1460d67c-20241003_re_xhiccmn4ilb7rw6c7k3st4s3bi/node_modules/next/dist/esm/server/app-render/action-utils.js
+      var action_utils = __webpack_require__(6672); // CONCATENATED MODULE: ./node_modules/.pnpm/next@file+..+diff-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-1460d67c-20241003_re_xhiccmn4ilb7rw6c7k3st4s3bi/node_modules/next/dist/build/webpack/loaders/next-edge-ssr-loader/index.js?{"absolute500Path":"","absoluteAppPath":"next/dist/pages/_app","absoluteDocumentPath":"next/dist/pages/_document","absoluteErrorPath":"next/dist/pages/_error","absolutePagePath":"private-next-app-dir/app-edge-ssr/page.js","dev":false,"isServerComponent":true,"page":"/app-edge-ssr/page","stringifiedConfig":"eyJlbnYiOnt9LCJlc2xpbnQiOnsiaWdub3JlRHVyaW5nQnVpbGRzIjpmYWxzZX0sInR5cGVzY3JpcHQiOnsiaWdub3JlQnVpbGRFcnJvcnMiOmZhbHNlLCJ0c2NvbmZpZ1BhdGgiOiJ0c2NvbmZpZy5qc29uIn0sImRpc3REaXIiOiIubmV4dCIsImNsZWFuRGlzdERpciI6dHJ1ZSwiYXNzZXRQcmVmaXgiOiIiLCJjYWNoZU1heE1lbW9yeVNpemUiOjUyNDI4ODAwLCJjb25maWdPcmlnaW4iOiJuZXh0LmNvbmZpZy5qcyIsInVzZUZpbGVTeXN0ZW1QdWJsaWNSb3V0ZXMiOnRydWUsImdlbmVyYXRlRXRhZ3MiOnRydWUsInBhZ2VFeHRlbnNpb25zIjpbInRzeCIsInRzIiwianN4IiwianMiXSwicG93ZXJlZEJ5SGVhZGVyIjp0cnVlLCJjb21wcmVzcyI6dHJ1ZSwiaW1hZ2VzIjp7ImRldmljZVNpemVzIjpbNjQwLDc1MCw4MjgsMTA4MCwxMjAwLDE5MjAsMjA0OCwzODQwXSwiaW1hZ2VTaXplcyI6WzE2LDMyLDQ4LDY0LDk2LDEyOCwyNTYsMzg0XSwicGF0aCI6Ii9fbmV4dC9pbWFnZSIsImxvYWRlciI6ImRlZmF1bHQiLCJsb2FkZXJGaWxlIjoiIiwiZG9tYWlucyI6W10sImRpc2FibGVTdGF0aWNJbWFnZXMiOmZhbHNlLCJtaW5pbXVtQ2FjaGVUVEwiOjYwLCJmb3JtYXRzIjpbImltYWdlL3dlYnAiXSwiZGFuZ2Vyb3VzbHlBbGxvd1NWRyI6ZmFsc2UsImNvbnRlbnRTZWN1cml0eVBvbGljeSI6InNjcmlwdC1zcmMgJ25vbmUnOyBmcmFtZS1zcmMgJ25vbmUnOyBzYW5kYm94OyIsImNvbnRlbnREaXNwb3NpdGlvblR5cGUiOiJhdHRhY2htZW50IiwicmVtb3RlUGF0dGVybnMiOltdLCJ1bm9wdGltaXplZCI6ZmFsc2V9LCJkZXZJbmRpY2F0b3JzIjp7ImFwcElzclN0YXR1cyI6dHJ1ZSwiYnVpbGRBY3Rpdml0eSI6dHJ1ZSwiYnVpbGRBY3Rpdml0eVBvc2l0aW9uIjoiYm90dG9tLXJpZ2h0In0sIm9uRGVtYW5kRW50cmllcyI6eyJtYXhJbmFjdGl2ZUFnZSI6NjAwMDAsInBhZ2VzQnVmZmVyTGVuZ3RoIjo1fSwiYW1wIjp7ImNhbm9uaWNhbEJhc2UiOiIifSwiYmFzZVBhdGgiOiIiLCJzYXNzT3B0aW9ucyI6e30sInRyYWlsaW5nU2xhc2giOmZhbHNlLCJpMThuIjpudWxsLCJwcm9kdWN0aW9uQnJvd3NlclNvdXJjZU1hcHMiOmZhbHNlLCJleGNsdWRlRGVmYXVsdE1vbWVudExvY2FsZXMiOnRydWUsInNlcnZlclJ1bnRpbWVDb25maWciOnt9LCJwdWJsaWNSdW50aW1lQ29uZmlnIjp7fSwicmVhY3RQcm9kdWN0aW9uUHJvZmlsaW5nIjpmYWxzZSwicmVhY3RTdHJpY3RNb2RlIjpudWxsLCJyZWFjdE1heEhlYWRlcnNMZW5ndGgiOjYwMDAsImh0dHBBZ2VudE9wdGlvbnMiOnsia2VlcEFsaXZlIjp0cnVlfSwibG9nZ2luZyI6e30sInN3ckRlbHRhIjozMTUzNjAwMCwic3RhdGljUGFnZUdlbmVyYXRpb25UaW1lb3V0Ijo2MCwibW9kdWxhcml6ZUltcG9ydHMiOnsiQG11aS9pY29ucy1tYXRlcmlhbCI6eyJ0cmFuc2Zvcm0iOiJAbXVpL2ljb25zLW1hdGVyaWFsL3t7bWVtYmVyfX0ifSwibG9kYXNoIjp7InRyYW5zZm9ybSI6ImxvZGFzaC97e21lbWJlcn19In19LCJvdXRwdXRGaWxlVHJhY2luZ1Jvb3QiOiIvdG1wL25leHQtc3RhdHN3VlVMb0ovc3RhdHMtYXBwIiwiZXhwZXJpbWVudGFsIjp7Im11bHRpWm9uZURyYWZ0TW9kZSI6ZmFsc2UsImFwcE5hdkZhaWxIYW5kbGluZyI6ZmFsc2UsInByZXJlbmRlckVhcmx5RXhpdCI6dHJ1ZSwic2VydmVyTWluaWZpY2F0aW9uIjp0cnVlLCJzZXJ2ZXJTb3VyY2VNYXBzIjpmYWxzZSwibGlua05vVG91Y2hTdGFydCI6ZmFsc2UsImNhc2VTZW5zaXRpdmVSb3V0ZXMiOmZhbHNlLCJwcmVsb2FkRW50cmllc09uU3RhcnQiOnRydWUsImNsaWVudFJvdXRlckZpbHRlciI6dHJ1ZSwiY2xpZW50Um91dGVyRmlsdGVyUmVkaXJlY3RzIjpmYWxzZSwiZmV0Y2hDYWNoZUtleVByZWZpeCI6IiIsIm1pZGRsZXdhcmVQcmVmZXRjaCI6ImZsZXhpYmxlIiwib3B0aW1pc3RpY0NsaWVudENhY2hlIjp0cnVlLCJtYW51YWxDbGllbnRCYXNlUGF0aCI6ZmFsc2UsImNwdXMiOjE5LCJtZW1vcnlCYXNlZFdvcmtlcnNDb3VudCI6ZmFsc2UsImlzckZsdXNoVG9EaXNrIjp0cnVlLCJ3b3JrZXJUaHJlYWRzIjpmYWxzZSwib3B0aW1pemVDc3MiOmZhbHNlLCJuZXh0U2NyaXB0V29ya2VycyI6ZmFsc2UsInNjcm9sbFJlc3RvcmF0aW9uIjpmYWxzZSwiZXh0ZXJuYWxEaXIiOmZhbHNlLCJkaXNhYmxlT3B0aW1pemVkTG9hZGluZyI6ZmFsc2UsImd6aXBTaXplIjp0cnVlLCJjcmFDb21wYXQiOmZhbHNlLCJlc21FeHRlcm5hbHMiOnRydWUsImZ1bGx5U3BlY2lmaWVkIjpmYWxzZSwic3djVHJhY2VQcm9maWxpbmciOmZhbHNlLCJmb3JjZVN3Y1RyYW5zZm9ybXMiOmZhbHNlLCJsYXJnZVBhZ2VEYXRhQnl0ZXMiOjEyODAwMCwidHVyYm8iOnsicm9vdCI6Ii90bXAvbmV4dC1zdGF0c3dWVUxvSi9zdGF0cy1hcHAifSwidHlwZWRSb3V0ZXMiOmZhbHNlLCJ0eXBlZEVudiI6ZmFsc2UsInBhcmFsbGVsU2VydmVyQ29tcGlsZXMiOmZhbHNlLCJwYXJhbGxlbFNlcnZlckJ1aWxkVHJhY2VzIjpmYWxzZSwicHByIjpmYWxzZSwicHByRmFsbGJhY2tzIjpmYWxzZSwid2VicGFja01lbW9yeU9wdGltaXphdGlvbnMiOmZhbHNlLCJvcHRpbWl6ZVNlcnZlclJlYWN0Ijp0cnVlLCJ1c2VFYXJseUltcG9ydCI6ZmFsc2UsInN0YWxlVGltZXMiOnsiZHluYW1pYyI6MCwic3RhdGljIjozMDB9LCJhZnRlciI6ZmFsc2UsInNlcnZlckNvbXBvbmVudHNIbXJDYWNoZSI6dHJ1ZSwic3RhdGljR2VuZXJhdGlvbk1heENvbmN1cnJlbmN5Ijo4LCJzdGF0aWNHZW5lcmF0aW9uTWluUGFnZXNQZXJXb3JrZXIiOjI1LCJkeW5hbWljSU8iOmZhbHNlLCJvcHRpbWl6ZVBhY2thZ2VJbXBvcnRzIjpbImx1Y2lkZS1yZWFjdCIsImRhdGUtZm5zIiwibG9kYXNoLWVzIiwicmFtZGEiLCJhbnRkIiwicmVhY3QtYm9vdHN0cmFwIiwiYWhvb2tzIiwiQGFudC1kZXNpZ24vaWNvbnMiLCJAaGVhZGxlc3N1aS9yZWFjdCIsIkBoZWFkbGVzc3VpLWZsb2F0L3JlYWN0IiwiQGhlcm9pY29ucy9yZWFjdC8yMC9zb2xpZCIsIkBoZXJvaWNvbnMvcmVhY3QvMjQvc29saWQiLCJAaGVyb2ljb25zL3JlYWN0LzI0L291dGxpbmUiLCJAdmlzeC92aXN4IiwiQHRyZW1vci9yZWFjdCIsInJ4anMiLCJAbXVpL21hdGVyaWFsIiwiQG11aS9pY29ucy1tYXRlcmlhbCIsInJlY2hhcnRzIiwicmVhY3QtdXNlIiwiZWZmZWN0IiwiQGVmZmVjdC9zY2hlbWEiLCJAZWZmZWN0L3BsYXRmb3JtIiwiQGVmZmVjdC9wbGF0Zm9ybS1ub2RlIiwiQGVmZmVjdC9wbGF0Zm9ybS1icm93c2VyIiwiQGVmZmVjdC9wbGF0Zm9ybS1idW4iLCJAZWZmZWN0L3NxbCIsIkBlZmZlY3Qvc3FsLW1zc3FsIiwiQGVmZmVjdC9zcWwtbXlzcWwyIiwiQGVmZmVjdC9zcWwtcGciLCJAZWZmZWN0L3NxbC1zcXVsaXRlLW5vZGUiLCJAZWZmZWN0L3NxbC1zcXVsaXRlLWJ1biIsIkBlZmZlY3Qvc3FsLXNxdWxpdGUtd2FzbSIsIkBlZmZlY3Qvc3FsLXNxdWxpdGUtcmVhY3QtbmF0aXZlIiwiQGVmZmVjdC9ycGMiLCJAZWZmZWN0L3JwYy1odHRwIiwiQGVmZmVjdC90eXBlY2xhc3MiLCJAZWZmZWN0L2V4cGVyaW1lbnRhbCIsIkBlZmZlY3Qvb3BlbnRlbGVtZXRyeSIsIkBtYXRlcmlhbC11aS9jb3JlIiwiQG1hdGVyaWFsLXVpL2ljb25zIiwiQHRhYmxlci9pY29ucy1yZWFjdCIsIm11aS1jb3JlIiwicmVhY3QtaWNvbnMvYWkiLCJyZWFjdC1pY29ucy9iaSIsInJlYWN0LWljb25zL2JzIiwicmVhY3QtaWNvbnMvY2ciLCJyZWFjdC1pY29ucy9jaSIsInJlYWN0LWljb25zL2RpIiwicmVhY3QtaWNvbnMvZmEiLCJyZWFjdC1pY29ucy9mYTYiLCJyZWFjdC1pY29ucy9mYyIsInJlYWN0LWljb25zL2ZpIiwicmVhY3QtaWNvbnMvZ2kiLCJyZWFjdC1pY29ucy9nbyIsInJlYWN0LWljb25zL2dyIiwicmVhY3QtaWNvbnMvaGkiLCJyZWFjdC1pY29ucy9oaTIiLCJyZWFjdC1pY29ucy9pbSIsInJlYWN0LWljb25zL2lvIiwicmVhY3QtaWNvbnMvaW81IiwicmVhY3QtaWNvbnMvbGlhIiwicmVhY3QtaWNvbnMvbGliIiwicmVhY3QtaWNvbnMvbHUiLCJyZWFjdC1pY29ucy9tZCIsInJlYWN0LWljb25zL3BpIiwicmVhY3QtaWNvbnMvcmkiLCJyZWFjdC1pY29ucy9yeCIsInJlYWN0LWljb25zL3NpIiwicmVhY3QtaWNvbnMvc2wiLCJyZWFjdC1pY29ucy90YiIsInJlYWN0LWljb25zL3RmaSIsInJlYWN0LWljb25zL3RpIiwicmVhY3QtaWNvbnMvdnNjIiwicmVhY3QtaWNvbnMvd2kiXX0sImJ1bmRsZVBhZ2VzUm91dGVyRGVwZW5kZW5jaWVzIjpmYWxzZSwiY29uZmlnRmlsZSI6Ii90bXAvbmV4dC1zdGF0c3dWVUxvSi9zdGF0cy1hcHAvbmV4dC5jb25maWcuanMiLCJjb25maWdGaWxlTmFtZSI6Im5leHQuY29uZmlnLmpzIn0=","pagesType":"app","appDirLoader":"bmV4dC1hcHAtbG9hZGVyP25hbWU9YXBwJTJGYXBwLWVkZ2Utc3NyJTJGcGFnZSZwYWdlPSUyRmFwcC1lZGdlLXNzciUyRnBhZ2UmcGFnZVBhdGg9cHJpdmF0ZS1uZXh0LWFwcC1kaXIlMkZhcHAtZWRnZS1zc3IlMkZwYWdlLmpzJmFwcERpcj0lMkZ0bXAlMkZuZXh0LXN0YXRzd1ZVTG9KJTJGc3RhdHMtYXBwJTJGYXBwJmFwcFBhdGhzPSUyRmFwcC1lZGdlLXNzciUyRnBhZ2UmcGFnZUV4dGVuc2lvbnM9dHN4JnBhZ2VFeHRlbnNpb25zPXRzJnBhZ2VFeHRlbnNpb25zPWpzeCZwYWdlRXh0ZW5zaW9ucz1qcyZiYXNlUGF0aD0mYXNzZXRQcmVmaXg9Jm5leHRDb25maWdPdXRwdXQ9JmZseWluZ1NodXR0bGU9ZmFsc2UmcHJlZmVycmVkUmVnaW9uPSZtaWRkbGV3YXJlQ29uZmlnPWUzMCUzRCE=","sriEnabled":false,"middlewareConfig":"e30="}!
       var _self___RSC_MANIFEST;
 
       const incrementalCacheHandler = null;
@@ -441,56 +441,56 @@
       /***/
     },
 
-    /***/ 2997: /***/ (
+    /***/ 2558: /***/ (
       __unused_webpack_module,
       __unused_webpack_exports,
       __webpack_require__
     ) => {
       Promise.resolve(/* import() eager */).then(
-        __webpack_require__.bind(__webpack_require__, 3682)
+        __webpack_require__.bind(__webpack_require__, 6325)
       );
       Promise.resolve(/* import() eager */).then(
-        __webpack_require__.bind(__webpack_require__, 9439)
+        __webpack_require__.bind(__webpack_require__, 7791)
       );
       Promise.resolve(/* import() eager */).then(
-        __webpack_require__.bind(__webpack_require__, 7008)
+        __webpack_require__.bind(__webpack_require__, 8779)
       );
       Promise.resolve(/* import() eager */).then(
-        __webpack_require__.bind(__webpack_require__, 7806)
+        __webpack_require__.bind(__webpack_require__, 2874)
       );
       Promise.resolve(/* import() eager */).then(
-        __webpack_require__.bind(__webpack_require__, 6770)
+        __webpack_require__.bind(__webpack_require__, 6616)
       );
       Promise.resolve(/* import() eager */).then(
-        __webpack_require__.bind(__webpack_require__, 3925)
+        __webpack_require__.bind(__webpack_require__, 9941)
       );
       Promise.resolve(/* import() eager */).then(
-        __webpack_require__.bind(__webpack_require__, 7353)
+        __webpack_require__.bind(__webpack_require__, 5206)
       );
       Promise.resolve(/* import() eager */).then(
-        __webpack_require__.bind(__webpack_require__, 1668)
+        __webpack_require__.bind(__webpack_require__, 1549)
       );
       Promise.resolve(/* import() eager */).then(
-        __webpack_require__.bind(__webpack_require__, 736)
+        __webpack_require__.bind(__webpack_require__, 9447)
       );
       Promise.resolve(/* import() eager */).then(
-        __webpack_require__.bind(__webpack_require__, 2705)
+        __webpack_require__.bind(__webpack_require__, 8047)
       );
       Promise.resolve(/* import() eager */).then(
-        __webpack_require__.bind(__webpack_require__, 9258)
+        __webpack_require__.bind(__webpack_require__, 4214)
       );
       Promise.resolve(/* import() eager */).then(
-        __webpack_require__.bind(__webpack_require__, 3020)
+        __webpack_require__.bind(__webpack_require__, 8204)
       );
 
       /***/
     },
 
-    /***/ 4900: /***/ () => {
+    /***/ 140: /***/ () => {
       /***/
     },
 
-    /***/ 7780: /***/ (
+    /***/ 2424: /***/ (
       __unused_webpack_module,
       __webpack_exports__,
       __webpack_require__
@@ -510,7 +510,7 @@
       /***/
     },
 
-    /***/ 7355: /***/ (
+    /***/ 1458: /***/ (
       __unused_webpack_module,
       __webpack_exports__,
       __webpack_require__
@@ -522,7 +522,7 @@
         /* harmony export */
       });
       /* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__ =
-        __webpack_require__(6547);
+        __webpack_require__(5809);
 
       function RootLayout({ children }) {
         return /*#__PURE__*/ (0,
@@ -541,7 +541,7 @@
     // webpackRuntimeModules
     /******/ var __webpack_exec__ = (moduleId) =>
       __webpack_require__((__webpack_require__.s = moduleId));
-    /******/ __webpack_require__.O(0, [226, 302], () => __webpack_exec__(9261));
+    /******/ __webpack_require__.O(0, [309, 995], () => __webpack_exec__(7544));
     /******/ var __webpack_exports__ = __webpack_require__.O();
     /******/ (_ENTRIES = typeof _ENTRIES === "undefined" ? {} : _ENTRIES)[
       "middleware_app/app-edge-ssr/page"
Diff for middleware.js

Diff too large to display

Diff for edge-ssr.js

Diff too large to display

Diff for dynamic-HASH.js
@@ -1,7 +1,7 @@
 (self["webpackChunk_N_E"] = self["webpackChunk_N_E"] || []).push([
   [2739],
   {
-    /***/ 8286: /***/ (
+    /***/ 7342: /***/ (
       __unused_webpack_module,
       __unused_webpack_exports,
       __webpack_require__
@@ -9,7 +9,7 @@
       (window.__NEXT_P = window.__NEXT_P || []).push([
         "/dynamic",
         function () {
-          return __webpack_require__(848);
+          return __webpack_require__(4662);
         },
       ]);
       if (false) {
@@ -18,7 +18,7 @@
       /***/
     },
 
-    /***/ 9343: /***/ (module, exports, __webpack_require__) => {
+    /***/ 754: /***/ (module, exports, __webpack_require__) => {
       "use strict";
 
       Object.defineProperty(exports, "__esModule", {
@@ -51,7 +51,7 @@
         __webpack_require__(90)
       );
       const _loadablesharedruntime = /*#__PURE__*/ _interop_require_default._(
-        __webpack_require__(7852)
+        __webpack_require__(8025)
       );
       const isServerSide = "object" === "undefined";
       // Normalize loader to return the module as form { default: Component } for `React.lazy`.
@@ -152,11 +152,7 @@
       /***/
     },
 
-    /***/ 9838: /***/ (
-      __unused_webpack_module,
-      exports,
-      __webpack_require__
-    ) => {
+    /***/ 28: /***/ (__unused_webpack_module, exports, __webpack_require__) => {
       "use strict";
       /* __next_internal_client_entry_do_not_use__  cjs */
       Object.defineProperty(exports, "__esModule", {
@@ -179,7 +175,7 @@
       /***/
     },
 
-    /***/ 7852: /***/ (
+    /***/ 8025: /***/ (
       __unused_webpack_module,
       exports,
       __webpack_require__
@@ -221,7 +217,7 @@ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE
       const _react = /*#__PURE__*/ _interop_require_default._(
         __webpack_require__(90)
       );
-      const _loadablecontextsharedruntime = __webpack_require__(9838);
+      const _loadablecontextsharedruntime = __webpack_require__(28);
       function resolve(obj) {
         return obj && obj.default ? obj.default : obj;
       }
@@ -456,7 +452,7 @@ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE
       /***/
     },
 
-    /***/ 848: /***/ (
+    /***/ 4662: /***/ (
       __unused_webpack_module,
       __webpack_exports__,
       __webpack_require__
@@ -471,7 +467,7 @@ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE
       /* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_0__ =
         __webpack_require__(4880);
       /* harmony import */ var next_dynamic__WEBPACK_IMPORTED_MODULE_1__ =
-        __webpack_require__(2829);
+        __webpack_require__(5300);
       /* harmony import */ var next_dynamic__WEBPACK_IMPORTED_MODULE_1___default =
         /*#__PURE__*/ __webpack_require__.n(
           next_dynamic__WEBPACK_IMPORTED_MODULE_1__
@@ -480,12 +476,12 @@ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE
       const DynamicHello = next_dynamic__WEBPACK_IMPORTED_MODULE_1___default()(
         () =>
           __webpack_require__
-            .e(/* import() */ 6418)
-            .then(__webpack_require__.bind(__webpack_require__, 6418))
+            .e(/* import() */ 5060)
+            .then(__webpack_require__.bind(__webpack_require__, 5060))
             .then((mod) => mod.Hello),
         {
           loadableGenerated: {
-            webpack: () => [/*require.resolve*/ 6418],
+            webpack: () => [/*require.resolve*/ 5060],
           },
         }
       );
@@ -512,12 +508,12 @@ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE
       /***/
     },
 
-    /***/ 2829: /***/ (
+    /***/ 5300: /***/ (
       module,
       __unused_webpack_exports,
       __webpack_require__
     ) => {
-      module.exports = __webpack_require__(9343);
+      module.exports = __webpack_require__(754);
 
       /***/
     },
@@ -527,7 +523,7 @@ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE
     /******/ var __webpack_exec__ = (moduleId) =>
       __webpack_require__((__webpack_require__.s = moduleId));
     /******/ __webpack_require__.O(0, [2888, 9774, 179], () =>
-      __webpack_exec__(8286)
+      __webpack_exec__(7342)
     );
     /******/ var __webpack_exports__ = __webpack_require__.O();
     /******/ _N_E = __webpack_exports__;
Diff for image-HASH.js
@@ -1,7 +1,7 @@
 (self["webpackChunk_N_E"] = self["webpackChunk_N_E"] || []).push([
   [8358],
   {
-    /***/ 3441: /***/ (
+    /***/ 9836: /***/ (
       __unused_webpack_module,
       __unused_webpack_exports,
       __webpack_require__
@@ -9,7 +9,7 @@
       (window.__NEXT_P = window.__NEXT_P || []).push([
         "/image",
         function () {
-          return __webpack_require__(8252);
+          return __webpack_require__(129);
         },
       ]);
       if (false) {
@@ -18,7 +18,7 @@
       /***/
     },
 
-    /***/ 5320: /***/ (module, exports, __webpack_require__) => {
+    /***/ 788: /***/ (module, exports, __webpack_require__) => {
       "use strict";
       /* __next_internal_client_entry_do_not_use__  cjs */
       Object.defineProperty(exports, "__esModule", {
@@ -40,17 +40,17 @@
         __webpack_require__(3853)
       );
       const _head = /*#__PURE__*/ _interop_require_default._(
-        __webpack_require__(7149)
+        __webpack_require__(7577)
       );
-      const _getimgprops = __webpack_require__(3358);
-      const _imageconfig = __webpack_require__(2179);
-      const _imageconfigcontextsharedruntime = __webpack_require__(4279);
-      const _warnonce = __webpack_require__(4541);
-      const _routercontextsharedruntime = __webpack_require__(7743);
+      const _getimgprops = __webpack_require__(5772);
+      const _imageconfig = __webpack_require__(1152);
+      const _imageconfigcontextsharedruntime = __webpack_require__(4545);
+      const _warnonce = __webpack_require__(2609);
+      const _routercontextsharedruntime = __webpack_require__(1678);
       const _imageloader = /*#__PURE__*/ _interop_require_default._(
-        __webpack_require__(4582)
+        __webpack_require__(3389)
       );
-      const _usemergedref = __webpack_require__(5465);
+      const _usemergedref = __webpack_require__(6028);
       // This is replaced by webpack define plugin
       const configEnv = {
         deviceSizes: [640, 750, 828, 1080, 1200, 1920, 2048, 3840],
@@ -371,7 +371,7 @@
       /***/
     },
 
-    /***/ 5465: /***/ (module, exports, __webpack_require__) => {
+    /***/ 6028: /***/ (module, exports, __webpack_require__) => {
       "use strict";
 
       Object.defineProperty(exports, "__esModule", {
@@ -432,7 +432,7 @@
       /***/
     },
 
-    /***/ 3358: /***/ (
+    /***/ 5772: /***/ (
       __unused_webpack_module,
       exports,
       __webpack_require__
@@ -448,9 +448,9 @@
           return getImgProps;
         },
       });
-      const _warnonce = __webpack_require__(4541);
-      const _imageblursvg = __webpack_require__(2630);
-      const _imageconfig = __webpack_require__(2179);
+      const _warnonce = __webpack_require__(2609);
+      const _imageblursvg = __webpack_require__(2015);
+      const _imageconfig = __webpack_require__(1152);
       const VALID_LOADING_VALUES =
         /* unused pure expression or super */ null && [
           "lazy",
@@ -823,7 +823,7 @@
       /***/
     },
 
-    /***/ 2630: /***/ (__unused_webpack_module, exports) => {
+    /***/ 2015: /***/ (__unused_webpack_module, exports) => {
       "use strict";
       /**
        * A shared function, used on both client and server, to generate a SVG blur placeholder.
@@ -878,7 +878,7 @@
       /***/
     },
 
-    /***/ 3286: /***/ (
+    /***/ 4934: /***/ (
       __unused_webpack_module,
       exports,
       __webpack_require__
@@ -905,10 +905,10 @@
         },
       });
       const _interop_require_default = __webpack_require__(9608);
-      const _getimgprops = __webpack_require__(3358);
-      const _imagecomponent = __webpack_require__(5320);
+      const _getimgprops = __webpack_require__(5772);
+      const _imagecomponent = __webpack_require__(788);
       const _imageloader = /*#__PURE__*/ _interop_require_default._(
-        __webpack_require__(4582)
+        __webpack_require__(3389)
       );
       function getImageProps(imgProps) {
         const { props } = (0, _getimgprops.getImgProps)(imgProps, {
@@ -940,7 +940,7 @@
       /***/
     },
 
-    /***/ 4582: /***/ (__unused_webpack_module, exports) => {
+    /***/ 3389: /***/ (__unused_webpack_module, exports) => {
       "use strict";
 
       Object.defineProperty(exports, "__esModule", {
@@ -975,7 +975,7 @@
       /***/
     },
 
-    /***/ 8252: /***/ (
+    /***/ 129: /***/ (
       __unused_webpack_module,
       __webpack_exports__,
       __webpack_require__
@@ -992,8 +992,8 @@
 
       // EXTERNAL MODULE: ./node_modules/.pnpm/react@19.0.0-rc-1460d67c-20241003/node_modules/react/jsx-runtime.js
       var jsx_runtime = __webpack_require__(4880);
-      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+main-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-1460d67c-20241003_re_wwvutoix5dph4lb7oeg7lue6vi/node_modules/next/image.js
-      var next_image = __webpack_require__(1841);
+      // EXTERNAL MODULE: ./node_modules/.pnpm/next@file+..+diff-repo+packages+next+next-packed.tgz_react-dom@19.0.0-rc-1460d67c-20241003_re_xhiccmn4ilb7rw6c7k3st4s3bi/node_modules/next/image.js
+      var next_image = __webpack_require__(5651);
       var image_default = /*#__PURE__*/ __webpack_require__.n(next_image); // CONCATENATED MODULE: ./pages/nextjs.png
       /* harmony default export */ const nextjs = {
         src: "/_next/static/media/nextjs.cae0b805.png",
@@ -1023,12 +1023,12 @@
       /***/
     },
 
-    /***/ 1841: /***/ (
+    /***/ 5651: /***/ (
       module,
       __unused_webpack_exports,
       __webpack_require__
     ) => {
-      module.exports = __webpack_require__(3286);
+      module.exports = __webpack_require__(4934);
 
       /***/
     },
@@ -1038,7 +1038,7 @@
     /******/ var __webpack_exec__ = (moduleId) =>
       __webpack_require__((__webpack_require__.s = moduleId));
     /******/ __webpack_require__.O(0, [2888, 9774, 179], () =>
-      __webpack_exec__(3441)
+      __webpack_exec__(9836)
     );
     /******/ var __webpack_exports__ = __webpack_require__.O();
     /******/ _N_E = __webpack_exports__;
Diff for 818-HASH.js

Diff too large to display

Diff for 8c961940-HASH.js
@@ -1,13 +1,13 @@
 "use strict";
 (self["webpackChunk_N_E"] = self["webpackChunk_N_E"] || []).push([
-  [5046],
+  [3071],
   {
-    /***/ 3676: /***/ (
+    /***/ 611: /***/ (
       __unused_webpack_module,
       exports,
       __webpack_require__
     ) => {
-      /* provided dependency */ var process = __webpack_require__(7838);
+      /* provided dependency */ var process = __webpack_require__(4966);
       /**
        * @license React
        * react-dom-client.production.js
@@ -22,9 +22,9 @@
  Modernizr 3.0.0pre (Custom Build) | MIT
 */
 
-      var Scheduler = __webpack_require__(8084),
-        React = __webpack_require__(3921),
-        ReactDOM = __webpack_require__(7147);
+      var Scheduler = __webpack_require__(7373),
+        React = __webpack_require__(2951),
+        ReactDOM = __webpack_require__(2292);
       function formatProdErrorMessage(code) {
         var url = "https://react.dev/errors/" + code;
         if (1 < arguments.length) {
@@ -731,6 +731,13 @@
         for (var laneMap = [], i = 0; 31 > i; i++) laneMap.push(initial);
         return laneMap;
       }
+      function markRootUpdated$1(root, updateLane) {
+        root.pendingLanes |= updateLane;
+        268435456 !== updateLane &&
+          ((root.suspendedLanes = 0),
+          (root.pingedLanes = 0),
+          (root.warmLanes = 0));
+      }
       function markRootFinished(
         root,
         finishedLanes,
@@ -2501,7 +2508,12 @@
           (update.lane = lane | 536870912));
       }
       function getRootForUpdatedFiber(sourceFiber) {
-        throwIfInfiniteUpdateLoopDetected();
+        if (50 < nestedUpdateCount)
+          throw (
+            ((nestedUpdateCount = 0),
+            (rootWithNestedUpdates = null),
+            Error(formatProdErrorMessage(185)))
+          );
         for (var parent = sourceFiber.return; null !== parent; )
           (sourceFiber = parent), (parent = sourceFiber.return);
         return 3 === sourceFiber.tag ? sourceFiber.stateNode : null;
@@ -10849,7 +10861,6 @@
         workInProgressRootConcurrentErrors = null,
         workInProgressRootRecoverableErrors = null,
         workInProgressRootDidIncludeRecursiveRenderUpdate = !1,
-        didIncludeCommitPhaseUpdate = !1,
         globalMostRecentFallbackTime = 0,
         workInProgressRootRenderTargetTime = Infinity,
         workInProgressTransitions = null,
@@ -10895,7 +10906,7 @@
               workInProgressDeferredLane,
               workInProgressRootDidSkipSuspendedSiblings
             );
-        markRootUpdated(root, lane);
+        markRootUpdated$1(root, lane);
         if (0 === (executionContext & 2) || root !== workInProgressRoot)
           root === workInProgressRoot &&
             (0 === (executionContext & 2) &&
@@ -11190,17 +11201,6 @@
         }
         return !0;
       }
-      function markRootUpdated(root, updatedLanes) {
-        root.pendingLanes |= updatedLanes;
-        268435456 !== updatedLanes &&
-          ((root.suspendedLanes = 0),
-          (root.pingedLanes = 0),
-          (root.warmLanes = 0));
-        executionContext & 2
-          ? (workInProgressRootDidIncludeRecursiveRenderUpdate = !0)
-          : executionContext & 4 && (didIncludeCommitPhaseUpdate = !0);
-        throwIfInfiniteUpdateLoopDetected();
-      }
       function markRootSuspended(
         root,
         suspendedLanes,
@@ -11722,8 +11722,8 @@
         while (null !== rootWithPendingPassiveEffects);
         if (0 !== (executionContext & 6))
           throw Error(formatProdErrorMessage(327));
-        var finishedWork = root.finishedWork,
-          lanes = root.finishedLanes;
+        var finishedWork = root.finishedWork;
+        didIncludeRenderPhaseUpdate = root.finishedLanes;
         if (null === finishedWork) return null;
         root.finishedWork = null;
         root.finishedLanes = 0;
@@ -11736,13 +11736,12 @@
         remainingLanes |= concurrentlyUpdatedLanes;
         markRootFinished(
           root,
-          lanes,
+          didIncludeRenderPhaseUpdate,
           remainingLanes,
           spawnedLane,
           updatedLanes,
           suspendedRetryLanes
         );
-        didIncludeCommitPhaseUpdate = !1;
         root === workInProgressRoot &&
           ((workInProgress = workInProgressRoot = null),
           (workInProgressRootRenderLanes = 0));
@@ -11783,7 +11782,7 @@
         rootDoesHavePassiveEffects
           ? ((rootDoesHavePassiveEffects = !1),
             (rootWithPendingPassiveEffects = root),
-            (pendingPassiveEffectsLanes = lanes))
+            (pendingPassiveEffectsLanes = didIncludeRenderPhaseUpdate))
           : releaseRootPooledCache(root, remainingLanes);
         remainingLanes = root.pendingLanes;
         0 === remainingLanes && (legacyErrorBoundariesThatAlreadyFailed = null);
@@ -11801,9 +11800,8 @@
               });
         0 !== (pendingPassiveEffectsLanes & 3) && flushPassiveEffects();
         remainingLanes = root.pendingLanes;
-        didIncludeRenderPhaseUpdate ||
-        didIncludeCommitPhaseUpdate ||
-        (0 !== (lanes & 4194218) && 0 !== (remainingLanes & 42))
+        0 !== (didIncludeRenderPhaseUpdate & 4194218) &&
+        0 !== (remainingLanes & 42)
           ? root === rootWithNestedUpdates
             ? nestedUpdateCount++
             : ((nestedUpdateCount = 0), (rootWithNestedUpdates = root))
@@ -11878,7 +11876,7 @@
         );
         rootFiber = enqueueUpdate(rootFiber, sourceFiber, 2);
         null !== rootFiber &&
-          (markRootUpdated(rootFiber, 2), ensureRootIsScheduled(rootFiber));
+          (markRootUpdated$1(rootFiber, 2), ensureRootIsScheduled(rootFiber));
       }
       function captureCommitPhaseError(
         sourceFiber,
@@ -11915,7 +11913,7 @@
                     nearestMountedAncestor,
                     sourceFiber
                   ),
-                  markRootUpdated(instance, 2),
+                  markRootUpdated$1(instance, 2),
                   ensureRootIsScheduled(instance));
                 break;
               }
@@ -11944,10 +11942,6 @@
         null !== pingCache && pingCache.delete(wakeable);
         root.pingedLanes |= root.suspendedLanes & pingedLanes;
         root.warmLanes &= ~pingedLanes;
-        executionContext & 2
-          ? (workInProgressRootDidIncludeRecursiveRenderUpdate = !0)
-          : executionContext & 4 && (didIncludeCommitPhaseUpdate = !0);
-        throwIfInfiniteUpdateLoopDetected();
         workInProgressRoot === root &&
           (workInProgressRootRenderLanes & pingedLanes) === pingedLanes &&
           (4 === workInProgressRootExitStatus ||
@@ -11968,7 +11962,7 @@
           retryLane
         );
         null !== boundaryFiber &&
-          (markRootUpdated(boundaryFiber, retryLane),
+          (markRootUpdated$1(boundaryFiber, retryLane),
           ensureRootIsScheduled(boundaryFiber));
       }
       function retryDehydratedSuspenseBoundary(boundaryFiber) {
@@ -11997,18 +11991,6 @@
         null !== retryCache && retryCache.delete(wakeable);
         retryTimedOutBoundary(boundaryFiber, retryLane);
       }
-      function throwIfInfiniteUpdateLoopDetected() {
-        if (100 < nestedUpdateCount)
-          throw (
-            ((nestedUpdateCount = 0),
-            (rootWithNestedUpdates = null),
-            executionContext & 2 &&
-              null !== workInProgressRoot &&
-              (workInProgressRoot.errorRecoveryDisabledLanes |=
-                workInProgressRootRenderLanes),
-            Error(formatProdErrorMessage(185)))
-          );
-      }
       function scheduleCallback$1(priorityLevel, callback) {
         return scheduleCallback$3(priorityLevel, callback);
       }
@@ -12318,20 +12300,20 @@
         }
       }
       for (
-        var i$jscomp$inline_1419 = 0;
-        i$jscomp$inline_1419 < simpleEventPluginEvents.length;
-        i$jscomp$inline_1419++
+        var i$jscomp$inline_1432 = 0;
+        i$jscomp$inline_1432 < simpleEventPluginEvents.length;
+        i$jscomp$inline_1432++
       ) {
-        var eventName$jscomp$inline_1420 =
-            simpleEventPluginEvents[i$jscomp$inline_1419],
-          domEventName$jscomp$inline_1421 =
-            eventName$jscomp$inline_1420.toLowerCase(),
-          capitalizedEvent$jscomp$inline_1422 =
-            eventName$jscomp$inline_1420[0].toUpperCase() +
-            eventName$jscomp$inline_1420.slice(1);
+        var eventName$jscomp$inline_1433 =
+            simpleEventPluginEvents[i$jscomp$inline_1432],
+          domEventName$jscomp$inline_1434 =
+            eventName$jscomp$inline_1433.toLowerCase(),
+          capitalizedEvent$jscomp$inline_1435 =
+            eventName$jscomp$inline_1433[0].toUpperCase() +
+            eventName$jscomp$inline_1433.slice(1);
         registerSimpleEvent(
-          domEventName$jscomp$inline_1421,
-          "on" + capitalizedEvent$jscomp$inline_1422
+          domEventName$jscomp$inline_1434,
+          "on" + capitalizedEvent$jscomp$inline_1435
         );
       }
       registerSimpleEvent(ANIMATION_END, "onAnimationEnd");
@@ -16000,16 +15982,16 @@
           0 === i && attemptExplicitHydrationTarget(target);
         }
       };
-      var isomorphicReactPackageVersion$jscomp$inline_1666 = React.version;
+      var isomorphicReactPackageVersion$jscomp$inline_1679 = React.version;
       if (
-        "19.0.0-rc-2d16326d-20240930" !==
-        isomorphicReactPackageVersion$jscomp$inline_1666
+        "19.0.0-rc-1460d67c-20241003" !==
+        isomorphicReactPackageVersion$jscomp$inline_1679
       )
         throw Error(
           formatProdErrorMessage(
             527,
-            isomorphicReactPackageVersion$jscomp$inline_1666,
-            "19.0.0-rc-2d16326d-20240930"
+            isomorphicReactPackageVersion$jscomp$inline_1679,
+            "19.0.0-rc-1460d67c-20241003"
           )
         );
       ReactDOMSharedInternals.findDOMNode = function (componentOrElement) {
@@ -16029,25 +16011,25 @@
           null === componentOrElement ? null : componentOrElement.stateNode;
         return componentOrElement;
       };
-      var internals$jscomp$inline_2137 = {
+      var internals$jscomp$inline_2150 = {
         bundleType: 0,
-        version: "19.0.0-rc-2d16326d-20240930",
+        version: "19.0.0-rc-1460d67c-20241003",
         rendererPackageName: "react-dom",
         currentDispatcherRef: ReactSharedInternals,
         findFiberByHostInstance: getClosestInstanceFromNode,
-        reconcilerVersion: "19.0.0-rc-2d16326d-20240930",
+        reconcilerVersion: "19.0.0-rc-1460d67c-20241003",
       };
       if ("undefined" !== typeof __REACT_DEVTOOLS_GLOBAL_HOOK__) {
-        var hook$jscomp$inline_2138 = __REACT_DEVTOOLS_GLOBAL_HOOK__;
+        var hook$jscomp$inline_2151 = __REACT_DEVTOOLS_GLOBAL_HOOK__;
         if (
-          !hook$jscomp$inline_2138.isDisabled &&
-          hook$jscomp$inline_2138.supportsFiber
+          !hook$jscomp$inline_2151.isDisabled &&
+          hook$jscomp$inline_2151.supportsFiber
         )
           try {
-            (rendererID = hook$jscomp$inline_2138.inject(
-              internals$jscomp$inline_2137
+            (rendererID = hook$jscomp$inline_2151.inject(
+              internals$jscomp$inline_2150
             )),
-              (injectedHook = hook$jscomp$inline_2138);
+              (injectedHook = hook$jscomp$inline_2151);
           } catch (err) {}
       }
       exports.createRoot = function (container, options) {
@@ -16137,13 +16119,13 @@
         identifierPrefix.callback = null;
         enqueueUpdate(options, identifierPrefix, isStrictMode);
         initialChildren.current.lanes = isStrictMode;
-        markRootUpdated(initialChildren, isStrictMode);
+        markRootUpdated$1(initialChildren, isStrictMode);
         ensureRootIsScheduled(initialChildren);
         container[internalContainerInstanceKey] = initialChildren.current;
         listenToAllSupportedEvents(container);
         return new ReactDOMHydrationRoot(initialChildren);
       };
-      exports.version = "19.0.0-rc-2d16326d-20240930";
+      exports.version = "19.0.0-rc-1460d67c-20241003";
 
       /***/
     },
Diff for 929-HASH.js
@@ -1,8 +1,8 @@
 "use strict";
 (self["webpackChunk_N_E"] = self["webpackChunk_N_E"] || []).push([
-  [929],
+  [5572],
   {
-    /***/ 929: /***/ (module, exports, __webpack_require__) => {
+    /***/ 5572: /***/ (module, exports, __webpack_require__) => {
       /* __next_internal_client_entry_do_not_use__  cjs */
       Object.defineProperty(exports, "__esModule", {
         value: true,
@@ -13,27 +13,27 @@
           return Image;
         },
       });
-      const _interop_require_default = __webpack_require__(1870);
-      const _interop_require_wildcard = __webpack_require__(969);
-      const _jsxruntime = __webpack_require__(5180);
+      const _interop_require_default = __webpack_require__(648);
+      const _interop_require_wildcard = __webpack_require__(9474);
+      const _jsxruntime = __webpack_require__(6110);
       const _react = /*#__PURE__*/ _interop_require_wildcard._(
-        __webpack_require__(3921)
+        __webpack_require__(2951)
       );
       const _reactdom = /*#__PURE__*/ _interop_require_default._(
-        __webpack_require__(7147)
+        __webpack_require__(2292)
       );
       const _head = /*#__PURE__*/ _interop_require_default._(
-        __webpack_require__(6911)
+        __webpack_require__(8883)
       );
-      const _getimgprops = __webpack_require__(1406);
-      const _imageconfig = __webpack_require__(8957);
-      const _imageconfigcontextsharedruntime = __webpack_require__(746);
-      const _warnonce = __webpack_require__(8307);
-      const _routercontextsharedruntime = __webpack_require__(6922);
+      const _getimgprops = __webpack_require__(8474);
+      const _imageconfig = __webpack_require__(8148);
+      const _imageconfigcontextsharedruntime = __webpack_require__(903);
+      const _warnonce = __webpack_require__(8063);
+      const _routercontextsharedruntime = __webpack_require__(5586);
       const _imageloader = /*#__PURE__*/ _interop_require_default._(
-        __webpack_require__(9194)
+        __webpack_require__(4343)
       );
-      const _usemergedref = __webpack_require__(2038);
+      const _usemergedref = __webpack_require__(3733);
       // This is replaced by webpack define plugin
       const configEnv = {
         deviceSizes: [640, 750, 828, 1080, 1200, 1920, 2048, 3840],
@@ -355,7 +355,7 @@
       /***/
     },
 
-    /***/ 2038: /***/ (module, exports, __webpack_require__) => {
+    /***/ 3733: /***/ (module, exports, __webpack_require__) => {
       Object.defineProperty(exports, "__esModule", {
         value: true,
       });
@@ -365,7 +365,7 @@
           return useMergedRef;
         },
       });
-      const _react = __webpack_require__(3921);
+      const _react = __webpack_require__(2951);
       function useMergedRef(refA, refB) {
         const cleanupA = (0, _react.useRef)(() => {});
         const cleanupB = (0, _react.useRef)(() => {});
@@ -414,11 +414,7 @@
       /***/
     },
 
-    /***/ 8842: /***/ (
-      __unused_webpack_module,
-      exports,
-      __webpack_require__
-    ) => {
+    /***/ 38: /***/ (__unused_webpack_module, exports, __webpack_require__) => {
       Object.defineProperty(exports, "__esModule", {
         value: true,
       });
@@ -428,9 +424,9 @@
           return AmpStateContext;
         },
       });
-      const _interop_require_default = __webpack_require__(1870);
+      const _interop_require_default = __webpack_require__(648);
       const _react = /*#__PURE__*/ _interop_require_default._(
-        __webpack_require__(3921)
+        __webpack_require__(2951)
       );
       const AmpStateContext = _react.default.createContext({});
       if (false) {
@@ -439,7 +435,7 @@
       /***/
     },
 
-    /***/ 2251: /***/ (__unused_webpack_module, exports) => {
+    /***/ 2714: /***/ (__unused_webpack_module, exports) => {
       Object.defineProperty(exports, "__esModule", {
         value: true,
       });
@@ -461,7 +457,7 @@
       /***/
     },
 
-    /***/ 1406: /***/ (
+    /***/ 8474: /***/ (
       __unused_webpack_module,
       exports,
       __webpack_require__
@@ -475,9 +471,9 @@
           return getImgProps;
         },
       });
-      const _warnonce = __webpack_require__(8307);
-      const _imageblursvg = __webpack_require__(3881);
-      const _imageconfig = __webpack_require__(8957);
+      const _warnonce = __webpack_require__(8063);
+      const _imageblursvg = __webpack_require__(5029);
+      const _imageconfig = __webpack_require__(8148);
       const VALID_LOADING_VALUES =
         /* unused pure expression or super */ null && [
           "lazy",
@@ -850,8 +846,8 @@
       /***/
     },
 
-    /***/ 6911: /***/ (module, exports, __webpack_require__) => {
-      /* provided dependency */ var process = __webpack_require__(7838);
+    /***/ 8883: /***/ (module, exports, __webpack_require__) => {
+      /* provided dependency */ var process = __webpack_require__(4966);
       /* __next_internal_client_entry_do_not_use__  cjs */
       Object.defineProperty(exports, "__esModule", {
         value: true,
@@ -872,19 +868,19 @@
           return defaultHead;
         },
       });
-      const _interop_require_default = __webpack_require__(1870);
-      const _interop_require_wildcard = __webpack_require__(969);
-      const _jsxruntime = __webpack_require__(5180);
+      const _interop_require_default = __webpack_require__(648);
+      const _interop_require_wildcard = __webpack_require__(9474);
+      const _jsxruntime = __webpack_require__(6110);
       const _react = /*#__PURE__*/ _interop_require_wildcard._(
-        __webpack_require__(3921)
+        __webpack_require__(2951)
       );
       const _sideeffect = /*#__PURE__*/ _interop_require_default._(
-        __webpack_require__(7231)
+        __webpack_require__(9230)
       );
-      const _ampcontextsharedruntime = __webpack_require__(8842);
-      const _headmanagercontextsharedruntime = __webpack_require__(2992);
-      const _ampmode = __webpack_require__(2251);
-      const _warnonce = __webpack_require__(8307);
+      const _ampcontextsharedruntime = __webpack_require__(38);
+      const _headmanagercontextsharedruntime = __webpack_require__(6516);
+      const _ampmode = __webpack_require__(2714);
+      const _warnonce = __webpack_require__(8063);
       function defaultHead(inAmpMode) {
         if (inAmpMode === void 0) inAmpMode = false;
         const head = [
@@ -1068,7 +1064,7 @@
       /***/
     },
 
-    /***/ 3881: /***/ (__unused_webpack_module, exports) => {
+    /***/ 5029: /***/ (__unused_webpack_module, exports) => {
       /**
        * A shared function, used on both client and server, to generate a SVG blur placeholder.
        */
@@ -1122,7 +1118,7 @@
       /***/
     },
 
-    /***/ 746: /***/ (
+    /***/ 903: /***/ (
       __unused_webpack_module,
       exports,
       __webpack_require__
@@ -1136,11 +1132,11 @@
           return ImageConfigContext;
         },
       });
-      const _interop_require_default = __webpack_require__(1870);
+      const _interop_require_default = __webpack_require__(648);
       const _react = /*#__PURE__*/ _interop_require_default._(
-        __webpack_require__(3921)
+        __webpack_require__(2951)
       );
-      const _imageconfig = __webpack_require__(8957);
+      const _imageconfig = __webpack_require__(8148);
       const ImageConfigContext = _react.default.createContext(
         _imageconfig.imageConfigDefault
       );
@@ -1150,7 +1146,7 @@
       /***/
     },
 
-    /***/ 8957: /***/ (__unused_webpack_module, exports) => {
+    /***/ 8148: /***/ (__unused_webpack_module, exports) => {
       Object.defineProperty(exports, "__esModule", {
         value: true,
       });
@@ -1198,7 +1194,7 @@
       /***/
     },
 
-    /***/ 9194: /***/ (__unused_webpack_module, exports) => {
+    /***/ 4343: /***/ (__unused_webpack_module, exports) => {
       Object.defineProperty(exports, "__esModule", {
         value: true,
       });
@@ -1231,7 +1227,7 @@
       /***/
     },
 
-    /***/ 6922: /***/ (
+    /***/ 5586: /***/ (
       __unused_webpack_module,
       exports,
       __webpack_require__
@@ -1245,9 +1241,9 @@
           return RouterContext;
         },
       });
-      const _interop_require_default = __webpack_require__(1870);
+      const _interop_require_default = __webpack_require__(648);
       const _react = /*#__PURE__*/ _interop_require_default._(
-        __webpack_require__(3921)
+        __webpack_require__(2951)
       );
       const RouterContext = _react.default.createContext(null);
       if (false) {
@@ -1256,7 +1252,7 @@
       /***/
     },
 
-    /***/ 7231: /***/ (
+    /***/ 9230: /***/ (
       __unused_webpack_module,
       exports,
       __webpack_require__
@@ -1270,7 +1266,7 @@
           return SideEffect;
         },
       });
-      const _react = __webpack_require__(3921);
+      const _react = __webpack_require__(2951);
       const isServer = typeof window === "undefined";
       const useClientOnlyLayoutEffect = isServer
         ? () => {}
Diff for main-HASH.js

Diff too large to display

Diff for app-page-exp..ntime.dev.js
failed to diff
Diff for app-page-exp..time.prod.js

Diff too large to display

Diff for app-page-tur..time.prod.js

Diff too large to display

Diff for app-page-tur..time.prod.js

Diff too large to display

Diff for app-page.runtime.dev.js
failed to diff
Diff for app-page.runtime.prod.js

Diff too large to display

Commit: 8677690

Copy link

New and removed dependencies detected. Learn more about Socket for GitHub ↗︎

Package New capabilities Transitives Size Publisher
npm/babel-plugin-react-compiler@0.0.0-experimental-734b737-20241003 None +7 5.95 MB fb, mofeiz, react-bot, ...1 more
npm/react-dom@0.0.0-experimental-1460d67c-20241003 None 0 8.25 MB fb, gnoff, react-bot, ...2 more
npm/react-dom@19.0.0-rc-1460d67c-20241003 None 0 6.34 MB fb, gnoff, react-bot, ...2 more
npm/react-is@19.0.0-rc-1460d67c-20241003 None 0 13.6 kB react-bot
npm/react-server-dom-webpack@19.0.0-rc-1460d67c-20241003 None +1 1.68 MB acdlite, brianvaughn, gaearon, ...2 more
npm/react@0.0.0-experimental-1460d67c-20241003 environment 0 178 kB fb, gnoff, react-bot, ...1 more
npm/react@19.0.0-rc-1460d67c-20241003 environment 0 237 kB fb, gnoff, react-bot, ...1 more
npm/scheduler@0.0.0-experimental-1460d67c-20241003 None 0 84.2 kB fb, gnoff, react-bot, ...1 more
npm/scheduler@0.25.0-rc-1460d67c-20241003 None 0 84.2 kB fb, gnoff, react-bot, ...1 more

🚮 Removed packages: npm/babel-plugin-react-compiler@0.0.0-experimental-27e0f40-20241002, npm/react-dom@0.0.0-experimental-2d16326d-20240930, npm/react-dom@19.0.0-rc-2d16326d-20240930, npm/react-is@19.0.0-rc-2d16326d-20240930, npm/react-server-dom-turbopack@0.0.0-experimental-2d16326d-20240930, npm/react-server-dom-turbopack@19.0.0-rc-2d16326d-20240930, npm/react-server-dom-webpack@0.0.0-experimental-2d16326d-20240930, npm/react-server-dom-webpack@19.0.0-rc-2d16326d-20240930, npm/react@0.0.0-experimental-2d16326d-20240930, npm/react@19.0.0-rc-2d16326d-20240930, npm/scheduler@0.0.0-experimental-2d16326d-20240930, npm/scheduler@0.25.0-rc-2d16326d-20240930

View full report↗︎

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
CI approved Approve running CI for fork create-next-app Related to our CLI tool for quickly starting a new Next.js application. examples Issue/PR related to examples tests type: next type: react-sync
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants