mirror of
https://github.com/zebrajr/react.git
synced 2025-12-06 12:20:20 +01:00
* Extract base Jest config This makes it easier to change the source config without affecting the build test config. * Statically import the host config This changes react-reconciler to import HostConfig instead of getting it through a function argument. Rather than start with packages like ReactDOM that want to inline it, I started with React Noop and ensured that *custom* renderers using react-reconciler package still work. To do this, I'm making HostConfig module in the reconciler look at a global variable by default (which, in case of the react-reconciler npm package, ends up being the host config argument in the top-level scope). This is still very broken. * Add scaffolding for importing an inlined renderer * Fix the build * ES exports for renderer methods * ES modules for host configs * Remove closures from the reconciler * Check each renderer's config with Flow * Fix uncovered Flow issue We know nextHydratableInstance doesn't get mutated inside this function, but Flow doesn't so it thinks it may be null. Help Flow. * Prettier * Get rid of enable*Reconciler flags They are not as useful anymore because for almost all cases (except third party renderers) we *know* whether it supports mutation or persistence. This refactoring means react-reconciler and react-reconciler/persistent third-party packages now ship the same thing. Not ideal, but this seems worth how simpler the code becomes. We can later look into addressing it by having a single toggle instead. * Prettier again * Fix Flow config creation issue * Fix imprecise Flow typing * Revert accidental changes
54 lines
1.8 KiB
JavaScript
54 lines
1.8 KiB
JavaScript
/* eslint-disable */
|
|
|
|
const NODE_ENV = process.env.NODE_ENV;
|
|
if (NODE_ENV !== 'development' && NODE_ENV !== 'production') {
|
|
throw new Error('NODE_ENV must either be set to development or production.');
|
|
}
|
|
global.__DEV__ = NODE_ENV === 'development';
|
|
|
|
global.requestAnimationFrame = function(callback) {
|
|
setTimeout(callback);
|
|
};
|
|
|
|
global.requestIdleCallback = function(callback) {
|
|
return setTimeout(() => {
|
|
callback({
|
|
timeRemaining() {
|
|
return Infinity;
|
|
},
|
|
});
|
|
});
|
|
};
|
|
|
|
global.cancelIdleCallback = function(callbackID) {
|
|
clearTimeout(callbackID);
|
|
};
|
|
|
|
// By default React console.error()'s any errors, caught or uncaught.
|
|
// However it is annoying to assert that a warning fired each time
|
|
// we assert that there is an exception in our tests. This lets us
|
|
// opt out of extra console error reporting for most tests except
|
|
// for the few that specifically test the logging by shadowing this
|
|
// property. In real apps, it would usually not be defined at all.
|
|
Error.prototype.suppressReactErrorLogging = true;
|
|
|
|
if (typeof window !== 'undefined') {
|
|
// Same as above.
|
|
DOMException.prototype.suppressReactErrorLogging = true;
|
|
|
|
// Also prevent JSDOM from logging intentionally thrown errors.
|
|
// TODO: it might make sense to do it the other way around.
|
|
// https://github.com/facebook/react/issues/11098#issuecomment-355032539
|
|
window.addEventListener('error', event => {
|
|
if (event.error != null && event.error.suppressReactErrorLogging) {
|
|
event.preventDefault();
|
|
}
|
|
});
|
|
}
|
|
|
|
// Preserve the empty object identity across module resets.
|
|
// This is needed for some tests that rely on string refs
|
|
// but reset modules between loading different renderers.
|
|
const obj = require.requireActual('fbjs/lib/emptyObject');
|
|
jest.mock('fbjs/lib/emptyObject', () => obj);
|