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

React 19 hydration error ignoring #15886

Open
astrodomas opened this issue Mar 27, 2025 · 6 comments
Open

React 19 hydration error ignoring #15886

astrodomas opened this issue Mar 27, 2025 · 6 comments
Labels
Package: react Issues related to the Sentry React SDK

Comments

@astrodomas
Copy link

astrodomas commented Mar 27, 2025

Environment

self-hosted (https://develop.sentry.dev/self-hosted/)

What are you trying to accomplish?

Hello,
I'm trying to ignore the react 418 error:

Hydration failed because the server rendered  didn't match the client. As a result this tree will be regenerated on the client. This can happen if a SSR-ed Client Component used:

- A server/client branch `if (typeof window !== 'undefined')`.
- Variable input such as `Date.now()` or `Math.random()` which changes each time it's called.
- Date formatting in a user's locale which doesn't match the server.
- External changing data without sending a snapshot of it along with the HTML.
- Invalid HTML tag nesting.

It can also happen if the client has a browser extension installed which messes with the HTML before React loaded.

https://react.dev/link/hydration-mismatch<redacted>

And sentry does not seem to ignore this error.

How are you getting stuck?

Using: "@sentry/nextjs": "^8.47.0"

tried to paste the following ignore strings + regexp matches inside sentry.client.config.ts:

  • "Hydration failed because the server rendered HTML didn't match the client. As a result this tree will be regenerated on the client. This can happen if a SSR-ed Client Component used:\n\n- A server/client branch if (typeof window !== 'undefined').\n- Variable input such as Date.now()orMath.random() which changes each time it's called.\n- Date formatting in a user's locale which doesn't match the server.\n- External changing data without sending a snapshot of it along with the HTML.\n- Invalid HTML tag nesting.\n\nIt can also happen if the client has a browser extension installed which messes with the HTML before React loaded.\n\nhttps://react.dev/link/hydration-mismatch" NOTE: Copied the message title from react repo itself
  • /Error: Hydration failed because the server rendered HTML/i
  • Hydration failed because the server rendered HTML

Also, I had seen this issue that indicates that Sentry handles react errors behind the scenes and prints the title, however these ignorations also don't work:

  • https://reactjs.org/docs/error-decoder.html?invariant=418
  • https://react.dev/errors/418

Where in the product are you?

Issues

Link

No response

DSN

No response

Version

24.2.0

@getsantry
Copy link

getsantry bot commented Mar 27, 2025

Assigning to @getsentry/support for routing ⏲️

@getsantry getsantry bot moved this to Waiting for: Support in GitHub Issues with 👀 3 Mar 27, 2025
@getsantry getsantry bot moved this to Waiting for: Product Owner in GitHub Issues with 👀 3 Mar 28, 2025
@InterstellarStella InterstellarStella transferred this issue from getsentry/sentry Mar 28, 2025
@lforst
Copy link
Member

lforst commented Mar 28, 2025

Ignoring the short form ones should work. There is a filter in the Sentry settings itself which you can use to ignore hydration errors.

@astrodomas
Copy link
Author

Image
I believe it is turned on, any other ideas?

@getsantry getsantry bot moved this from Waiting for: Community to Waiting for: Product Owner in GitHub Issues with 👀 3 Mar 28, 2025
@lforst
Copy link
Member

lforst commented Mar 28, 2025

Do you have the captureConsole integration active? I think to debug this further we need a reproduction.

@astrodomas
Copy link
Author

astrodomas commented Mar 28, 2025

Image
Can this be the issue? ?args[]=

@getsantry getsantry bot moved this to Waiting for: Product Owner in GitHub Issues with 👀 3 Mar 28, 2025
@lforst
Copy link
Member

lforst commented Mar 28, 2025

In general ignoreErrors does substring matching when you provide a string, and RegEx.test(errormessage) when you provide a RegEx.

@AbhiPrasad AbhiPrasad added the Package: react Issues related to the Sentry React SDK label Mar 28, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Package: react Issues related to the Sentry React SDK
Projects
Status: No status
Development

No branches or pull requests

3 participants