Skip to content

[noop] Fix createContainer argument order in the Fiber implementation#35945

Merged
eps1lon merged 6 commits intofacebook:mainfrom
eps1lon:sebbie/03-02-_noop_match_fiber_host_config
Mar 4, 2026
Merged

[noop] Fix createContainer argument order in the Fiber implementation#35945
eps1lon merged 6 commits intofacebook:mainfrom
eps1lon:sebbie/03-02-_noop_match_fiber_host_config

Conversation

@eps1lon
Copy link
Collaborator

@eps1lon eps1lon commented Mar 2, 2026

...and fix most of the type issues in the Fiber implementation of react-noop-renderer

Stacked on #35944

Only addressed the most obvious issues. There's still some issues relating to loosely accessing object properties but those don't feel urgent. Especially because this is a test-only renderer.

The argument order of createContainer was the main concern.

@meta-cla meta-cla bot added the CLA Signed label Mar 2, 2026
@github-actions github-actions bot added the React Core Team Opened by a member of the React Core Team label Mar 2, 2026
@react-sizebot
Copy link

react-sizebot commented Mar 2, 2026

Comparing: 5e42791...8127022

Critical size changes

Includes critical production bundles, as well as any change greater than 2%:

Name +/- Base Current +/- gzip Base gzip Current gzip
oss-stable/react-dom/cjs/react-dom.production.js = 6.84 kB 6.84 kB = 1.88 kB 1.88 kB
oss-stable/react-dom/cjs/react-dom-client.production.js = 611.79 kB 611.79 kB = 108.12 kB 108.12 kB
oss-experimental/react-dom/cjs/react-dom.production.js = 6.84 kB 6.84 kB = 1.88 kB 1.88 kB
oss-experimental/react-dom/cjs/react-dom-client.production.js = 677.72 kB 677.72 kB = 119.08 kB 119.08 kB
facebook-www/ReactDOM-prod.classic.js = 697.67 kB 697.67 kB = 122.58 kB 122.58 kB
facebook-www/ReactDOM-prod.modern.js = 687.98 kB 687.98 kB = 120.96 kB 120.96 kB
oss-stable-semver/react-noop-renderer/cjs/react-noop-renderer.development.js +13.54% 42.81 kB 48.61 kB +12.24% 7.74 kB 8.68 kB
oss-stable/react-noop-renderer/cjs/react-noop-renderer.development.js +13.53% 42.84 kB 48.63 kB +12.14% 7.77 kB 8.71 kB
oss-experimental/react-noop-renderer/cjs/react-noop-renderer.development.js +13.53% 42.84 kB 48.64 kB +12.16% 7.77 kB 8.72 kB
oss-stable-semver/react-noop-renderer/cjs/react-noop-renderer-persistent.development.js +13.49% 42.95 kB 48.75 kB +12.20% 7.76 kB 8.70 kB
oss-stable/react-noop-renderer/cjs/react-noop-renderer-persistent.development.js +13.48% 42.98 kB 48.77 kB +12.11% 7.79 kB 8.73 kB
oss-experimental/react-noop-renderer/cjs/react-noop-renderer-persistent.development.js +13.48% 42.98 kB 48.78 kB +12.11% 7.79 kB 8.73 kB
oss-stable-semver/react-noop-renderer/cjs/react-noop-renderer.production.js +13.04% 38.49 kB 43.51 kB +12.94% 7.13 kB 8.06 kB
oss-stable/react-noop-renderer/cjs/react-noop-renderer.production.js +13.03% 38.52 kB 43.54 kB +12.84% 7.16 kB 8.08 kB
oss-experimental/react-noop-renderer/cjs/react-noop-renderer.production.js +13.03% 38.53 kB 43.55 kB +12.85% 7.17 kB 8.09 kB
oss-stable-semver/react-noop-renderer/cjs/react-noop-renderer-persistent.production.js +13.00% 38.62 kB 43.64 kB +12.88% 7.15 kB 8.07 kB
oss-stable/react-noop-renderer/cjs/react-noop-renderer-persistent.production.js +12.99% 38.65 kB 43.67 kB +12.76% 7.18 kB 8.10 kB
oss-experimental/react-noop-renderer/cjs/react-noop-renderer-persistent.production.js +12.99% 38.65 kB 43.67 kB +12.77% 7.19 kB 8.11 kB

Significant size changes

Includes any change greater than 0.2%:

Expand to show
Name +/- Base Current +/- gzip Base gzip Current gzip
oss-stable-semver/react-noop-renderer/cjs/react-noop-renderer.development.js +13.54% 42.81 kB 48.61 kB +12.24% 7.74 kB 8.68 kB
oss-stable/react-noop-renderer/cjs/react-noop-renderer.development.js +13.53% 42.84 kB 48.63 kB +12.14% 7.77 kB 8.71 kB
oss-experimental/react-noop-renderer/cjs/react-noop-renderer.development.js +13.53% 42.84 kB 48.64 kB +12.16% 7.77 kB 8.72 kB
oss-stable-semver/react-noop-renderer/cjs/react-noop-renderer-persistent.development.js +13.49% 42.95 kB 48.75 kB +12.20% 7.76 kB 8.70 kB
oss-stable/react-noop-renderer/cjs/react-noop-renderer-persistent.development.js +13.48% 42.98 kB 48.77 kB +12.11% 7.79 kB 8.73 kB
oss-experimental/react-noop-renderer/cjs/react-noop-renderer-persistent.development.js +13.48% 42.98 kB 48.78 kB +12.11% 7.79 kB 8.73 kB
oss-stable-semver/react-noop-renderer/cjs/react-noop-renderer.production.js +13.04% 38.49 kB 43.51 kB +12.94% 7.13 kB 8.06 kB
oss-stable/react-noop-renderer/cjs/react-noop-renderer.production.js +13.03% 38.52 kB 43.54 kB +12.84% 7.16 kB 8.08 kB
oss-experimental/react-noop-renderer/cjs/react-noop-renderer.production.js +13.03% 38.53 kB 43.55 kB +12.85% 7.17 kB 8.09 kB
oss-stable-semver/react-noop-renderer/cjs/react-noop-renderer-persistent.production.js +13.00% 38.62 kB 43.64 kB +12.88% 7.15 kB 8.07 kB
oss-stable/react-noop-renderer/cjs/react-noop-renderer-persistent.production.js +12.99% 38.65 kB 43.67 kB +12.76% 7.18 kB 8.10 kB
oss-experimental/react-noop-renderer/cjs/react-noop-renderer-persistent.production.js +12.99% 38.65 kB 43.67 kB +12.77% 7.19 kB 8.11 kB

Generated by 🚫 dangerJS against 8127022

@eps1lon eps1lon changed the title [noop] Fix createContainer argument order [noop] Fix createContainer argument order in the Fiber implementation Mar 2, 2026
jest.restoreAllMocks();
});

// @gate enableViewTransition || fb
Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Outside of enableViewTransition, <ViewTransition> is rendered as a Scope Component due to how messy feature flags are with switch statements:

// Fall through
case REACT_VIEW_TRANSITION_TYPE:
if (enableViewTransition) {
return createFiberFromViewTransition(pendingProps, mode, lanes, key);
}
// Fall through
case REACT_SCOPE_TYPE:
if (enableScopeAPI) {
return createFiberFromScope(type, pendingProps, mode, lanes, key);
}

This used to just pass the test since react-noop-renderer didn't throw when Scope host config APIs were used. Now we do so the test fails in fb builds that have enableViewTransition off but enableScope on.

@eps1lon eps1lon marked this pull request as ready for review March 2, 2026 22:33
@eps1lon eps1lon force-pushed the sebbie/03-02-_noop_match_fiber_host_config branch from 5374ae3 to 05bf806 Compare March 4, 2026 12:54
eps1lon added 6 commits March 4, 2026 14:07
Notable `now` and `logRecoverableError` were removed
due to being unused by Fiber.

The rest is either adding throwing shims for missing
host config properties or using the shared shims
when the whole feature isn't implemented.
They can't be imported from `react-reconciler`
since that package is treated as an external of react-noop-renderer
@eps1lon eps1lon force-pushed the sebbie/03-02-_noop_match_fiber_host_config branch from 05bf806 to 8127022 Compare March 4, 2026 13:07
@eps1lon eps1lon merged commit 3bc2d41 into facebook:main Mar 4, 2026
236 checks passed
@eps1lon eps1lon deleted the sebbie/03-02-_noop_match_fiber_host_config branch March 4, 2026 13:20
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

CLA Signed React Core Team Opened by a member of the React Core Team

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants