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

Client cache incorrectly resolves nested force-dynamic routes despite query parameter change (does not happen on / route) #58057

Open
1 task done
oreqizer opened this issue Nov 5, 2023 · 2 comments
Labels
bug Issue was opened via the bug report template. Linking and Navigating Related to Next.js linking (e.g., <Link>) and navigation. Pages Router Related to Pages Router.

Comments

@oreqizer
Copy link

oreqizer commented Nov 5, 2023

Link to the code that reproduces this issue

https://codesandbox.io/p/sandbox/next-caching-5t73nd

To Reproduce

  1. do next build && next start (works ok in next dev)
  2. Go to / and see that the Load # link works (updating query parameters)
  3. Go to /route and see that clicking Load # only works initially, and subsequently only every ~15s when client cache is invalidated
  4. Comment out the export const dynamic = "force-dynamic"; in /route to fix the problem

Current vs. Expected behavior

Clicking Load # in nested routes marked as "force-dynamic" would correctly load server components and not hit client cache.

Verify canary release

  • I verified that the issue exists in the latest Next.js canary release

Provide environment information

Operating System:
  Platform: linux
  Arch: x64
  Version: #1 SMP PREEMPT_DYNAMIC Sun Aug  6 20:05:33 UTC 2023
Binaries:
  Node: 20.5.1
  npm: 9.8.0
  Yarn: 1.22.19
  pnpm: N/A
Relevant Packages:
  next: 14.0.1
  eslint-config-next: N/A
  react: 18.2.0
  react-dom: 18.2.0
  typescript: N/A
Next.js Config:
  output: N/A

Which area(s) are affected? (Select all that apply)

App Router, Data fetching (gS(S)P, getInitialProps), Routing (next/router, next/navigation, next/link)

Additional context

Next 14.0.1. I noticed this happening as soon as 13.5.x, but 13.4.12 worked fine.

@oreqizer oreqizer added the bug Issue was opened via the bug report template. label Nov 5, 2023
@github-actions github-actions bot added Pages Router Related to Pages Router. Linking and Navigating Related to Next.js linking (e.g., <Link>) and navigation. labels Nov 5, 2023
@oreqizer oreqizer changed the title Client cache incorrectly loads nested routes despite query parameter change (does not happen on "/" route) Client cache incorrectly resolves nested routes despite query parameter change (does not happen on / route) Nov 6, 2023
@oreqizer
Copy link
Author

oreqizer commented Nov 6, 2023

Update: I noticed this is only happening with export const dynamic = "force-dynamic";. Removing this export gets rid of the issue

Updated the ticket

@oreqizer oreqizer changed the title Client cache incorrectly resolves nested routes despite query parameter change (does not happen on / route) Client cache incorrectly resolves nested force-dynamic routes despite query parameter change (does not happen on / route) Nov 6, 2023
@samcx
Copy link
Member

samcx commented Dec 23, 2023

@oreqizer Thank you for sharing!

I was not able to replicate this with the latest stable v14.0.4—can you also confirm this?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Issue was opened via the bug report template. Linking and Navigating Related to Next.js linking (e.g., <Link>) and navigation. Pages Router Related to Pages Router.
Projects
None yet
Development

No branches or pull requests

2 participants