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

fix(deps): update react monorepo to v19 (major) #12686

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

Conversation

renovate[bot]
Copy link
Contributor

@renovate renovate bot commented Dec 9, 2024

This PR contains the following updates:

Package Change Age Adoption Passing Confidence
@types/react (source) ^18.3.12 -> ^19.0.3 age adoption passing confidence
@types/react-dom (source) ^18.3.1 -> ^19.0.2 age adoption passing confidence
react (source) ^18.3.1 -> ^19.0.0 age adoption passing confidence
react-dom (source) ^18.3.1 -> ^19.0.0 age adoption passing confidence

Release Notes

facebook/react (react)

v19.0.0

Compare Source

facebook/react (react-dom)

v19.0.0

Compare Source


Configuration

📅 Schedule: Branch creation - "* 0-3 * * 1" (UTC), Automerge - At any time (no schedule defined).

🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.

Rebasing: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.

🔕 Ignore: Close this PR and you won't be reminded about these updates again.


  • If you want to rebase/retry this PR, check this box

This PR was generated by Mend Renovate. View the repository job log.

@renovate renovate bot added the dependencies Pull requests that update a dependency file label Dec 9, 2024
Copy link

changeset-bot bot commented Dec 9, 2024

🦋 Changeset detected

Latest commit: 4e31dc9

The changes in this PR will be included in the next version bump.

Not sure what this means? Click here to learn what changesets are.

Click here if you're a maintainer who wants to add another changeset to this PR

@github-actions github-actions bot added pkg: example Related to an example package (scope) pkg: react Related to React (scope) pkg: integration Related to any renderer integration (scope) pkg: astro Related to the core `astro` package (scope) labels Dec 9, 2024
@renovate renovate bot force-pushed the renovate/major-react-monorepo branch 2 times, most recently from d90ddc4 to 831d92d Compare December 9, 2024 20:33
@renovate renovate bot changed the title chore(deps): update react monorepo to v19 (major) fix(deps): update react monorepo to v19 (major) Dec 10, 2024
@renovate renovate bot force-pushed the renovate/major-react-monorepo branch 5 times, most recently from a760f23 to 1144ea4 Compare December 17, 2024 03:08
@renovate renovate bot force-pushed the renovate/major-react-monorepo branch 5 times, most recently from 654fa1b to 937b878 Compare December 20, 2024 12:15
@renovate renovate bot force-pushed the renovate/major-react-monorepo branch 2 times, most recently from 622a602 to 8099ebe Compare January 3, 2025 09:06
@bluwy
Copy link
Member

bluwy commented Jan 3, 2025

It doesn't look like React 19 is properly working in Astro yet.

@renovate renovate bot force-pushed the renovate/major-react-monorepo branch from 8099ebe to 25c5473 Compare January 3, 2025 12:38
@bluwy bluwy mentioned this pull request Jan 3, 2025
1 task
@renovate renovate bot force-pushed the renovate/major-react-monorepo branch from 25c5473 to b46f764 Compare January 6, 2025 11:53
Copy link
Contributor Author

renovate bot commented Jan 6, 2025

Edited/Blocked Notification

Renovate will not automatically rebase this PR, because it does not recognize the last commit author and assumes somebody else may have edited the PR.

You can manually request rebase by checking the rebase/retry box above.

⚠️ Warning: custom changes will be lost.

@bluwy
Copy link
Member

bluwy commented Jan 7, 2025

The tests are failing as there's a pickle with how our tests runs and how tolerant React 19 is. In our tests, we run build and dev tests one after the other. The issue is that sometimes we import react or react-dom/server and it can give either the dev or prod version depending on process.env.NODE_ENV. However, if we import it once during production builds and get the production variant, we can't import it during dev again and get the development variant. Because imports are cached.

In practice I believe this is an issue for most frameworks including React 18, but they're tolerant enough that mismatching variants, e.g. react-dom/server (prod) + react/jsx-dev-runtime (dev) were fine. Overall I'm not really sure I to solve this yet that doesn't require rewriting our tests.

@ematipico
Copy link
Member

ematipico commented Jan 7, 2025

Because imports are cached.

Is this caused by the fact that we run all our tests in the same process, in one single file? Can we try with --parallel?

@bluwy
Copy link
Member

bluwy commented Jan 7, 2025

I don't think that would fix it. We'd have to split our build and dev tests as separate files so that each runs in their own process with their own import cache. I'm testing locally by running node ./packages/astro/0-css.test.js where its last test is failing because the HTML output got cut off due to React errors in @astrojs/react/server.js check() call. (you can add a log here where actual React components are erroring)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
dependencies Pull requests that update a dependency file pkg: astro Related to the core `astro` package (scope) pkg: example Related to an example package (scope) pkg: integration Related to any renderer integration (scope) pkg: react Related to React (scope)
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants