mirror of
https://github.com/status-im/react-native.git
synced 2025-01-22 15:29:07 +00:00
d5e9e55fa3
Summary: This PR removes the need for having the `providesModule` tags in all the modules in the repository. It configures Flow, Jest and Metro to get the module names from the filenames (`Libraries/Animated/src/nodes/AnimatedInterpolation.js` => `AnimatedInterpolation`) * Checked the Flow configuration by running flow on the project root (no errors): ``` yarn flow ``` * Checked the Jest configuration by running the tests with a clean cache: ``` yarn jest --clearCache && yarn test ``` * Checked the Metro configuration by starting the server with a clean cache and requesting some bundles: ``` yarn run start --reset-cache curl 'localhost:8081/IntegrationTests/AccessibilityManagerTest.bundle?platform=android' curl 'localhost:8081/Libraries/Alert/Alert.bundle?platform=ios' ``` [INTERNAL] [FEATURE] [All] - Removed providesModule from all modules and configured tools. Closes https://github.com/facebook/react-native/pull/18995 Reviewed By: mjesun Differential Revision: D7729509 Pulled By: rubennorte fbshipit-source-id: 892f760a05ce1fddb088ff0cd2e97e521fb8e825
89 lines
2.7 KiB
JavaScript
89 lines
2.7 KiB
JavaScript
/**
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*
|
|
* @flow
|
|
*/
|
|
'use strict';
|
|
|
|
const infoLog = require('infoLog');
|
|
/* $FlowFixMe(>=0.54.0 site=react_native_oss) This comment suppresses an error
|
|
* found when Flow v0.54 was deployed. To see the error delete this comment and
|
|
* run Flow. */
|
|
const performanceNow = require('fbjs/lib/performanceNow');
|
|
|
|
type Handler = {
|
|
onIterate?: () => void,
|
|
onStall: (params: {lastInterval: number, busyTime: number}) => ?string,
|
|
};
|
|
|
|
/**
|
|
* A utility for tracking stalls in the JS event loop that prevent timers and
|
|
* other events from being processed in a timely manner.
|
|
*
|
|
* The "stall" time is defined as the amount of time in access of the acceptable
|
|
* threshold, which is typically around 100-200ms. So if the treshold is set to
|
|
* 100 and a timer fires 150 ms later than it was scheduled because the event
|
|
* loop was tied up, that would be considered a 50ms stall.
|
|
*
|
|
* By default, logs stall events to the console when installed. Can also be
|
|
* queried with `getStats`.
|
|
*/
|
|
const JSEventLoopWatchdog = {
|
|
getStats: function(): Object {
|
|
return {stallCount, totalStallTime, longestStall, acceptableBusyTime};
|
|
},
|
|
reset: function() {
|
|
infoLog('JSEventLoopWatchdog: reset');
|
|
totalStallTime = 0;
|
|
stallCount = 0;
|
|
longestStall = 0;
|
|
lastInterval = performanceNow();
|
|
},
|
|
addHandler: function(handler: Handler) {
|
|
handlers.push(handler);
|
|
},
|
|
install: function({thresholdMS}: {thresholdMS: number}) {
|
|
acceptableBusyTime = thresholdMS;
|
|
if (installed) {
|
|
return;
|
|
}
|
|
installed = true;
|
|
lastInterval = performanceNow();
|
|
function iteration() {
|
|
const now = performanceNow();
|
|
const busyTime = now - lastInterval;
|
|
if (busyTime >= thresholdMS) {
|
|
const stallTime = busyTime - thresholdMS;
|
|
stallCount++;
|
|
totalStallTime += stallTime;
|
|
longestStall = Math.max(longestStall, stallTime);
|
|
let msg = `JSEventLoopWatchdog: JS thread busy for ${busyTime}ms. ` +
|
|
`${totalStallTime}ms in ${stallCount} stalls so far. `;
|
|
handlers.forEach((handler) => {
|
|
msg += handler.onStall({lastInterval, busyTime}) || '';
|
|
});
|
|
infoLog(msg);
|
|
}
|
|
handlers.forEach((handler) => {
|
|
handler.onIterate && handler.onIterate();
|
|
});
|
|
lastInterval = now;
|
|
setTimeout(iteration, thresholdMS / 5);
|
|
}
|
|
iteration();
|
|
},
|
|
};
|
|
|
|
let acceptableBusyTime = 0;
|
|
let installed = false;
|
|
let totalStallTime = 0;
|
|
let stallCount = 0;
|
|
let longestStall = 0;
|
|
let lastInterval = 0;
|
|
const handlers: Array<Handler> = [];
|
|
|
|
module.exports = JSEventLoopWatchdog;
|