Files
react-native/packages/rn-tester/js/utils/useJsStalls.js
Moti Zilberman d6e0bc714a Enable lint/sort-imports everywhere (#41334)
Summary:
Pull Request resolved: https://github.com/facebook/react-native/pull/41334

TSIA.

Changelog: [Internal]

Reviewed By: robhogan

Differential Revision: D51025812

fbshipit-source-id: e10d437be775a6b80946483aa96460f34927f870
2023-11-06 12:59:38 -08:00

98 lines
2.5 KiB
JavaScript

/**
* Copyright (c) Meta Platforms, Inc. and affiliates.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*
* @format
* @flow strict-local
*/
import type {RNTesterJsStallsState} from '../types/RNTesterTypes';
import * as React from 'react';
const INITIAL_STATE: RNTesterJsStallsState = {
stallIntervalId: null,
busyTime: null,
filteredStall: 0,
tracking: false,
};
const FILTERED_STALL_MULTIPLIER = 0.97;
const BUSY_TIME_MULTIPLIER = 1 - FILTERED_STALL_MULTIPLIER;
const useJsStalls = (): ({
onDisableForceJsStalls: () => void,
onDisableJsStallsTracking: () => void,
onEnableForceJsStalls: () => void,
onEnableJsStallsTracking: () => void,
state: RNTesterJsStallsState,
}) => {
const [stallsState, setStallsState] =
React.useState<RNTesterJsStallsState>(INITIAL_STATE);
const {stallIntervalId} = stallsState;
React.useEffect(() => {
return () => clearInterval(stallIntervalId);
}, [stallIntervalId]);
const onDisableForceJsStalls = React.useCallback(
() => setStallsState(state => ({...state, stallIntervalId: null})),
[],
);
const onEnableForceJsStalls = React.useCallback(() => {
const intervalId = setInterval(() => {
const start = Date.now();
console.warn('burn CPU');
while (Date.now() - start < 100) {}
}, 300);
setStallsState(state => ({...state, stallIntervalId: intervalId}));
}, []);
const onEnableJsStallsTracking = React.useCallback(() => {
const JSEventLoopWatchdog = require('react-native/Libraries/Interaction/JSEventLoopWatchdog');
JSEventLoopWatchdog.install({thresholdMS: 25});
setStallsState(state => ({...state, tracking: true}));
JSEventLoopWatchdog.addHandler({
onStall: ({busyTime}) =>
setStallsState(state => {
// If previous interval was cleared
if (!state.stallIntervalId) {
return state;
}
return {
...state,
busyTime: busyTime || state.busyTime,
filteredStall:
state.filteredStall * FILTERED_STALL_MULTIPLIER +
(busyTime || 0) * BUSY_TIME_MULTIPLIER,
};
}),
});
}, []);
const onDisableJsStallsTracking = React.useCallback(() => {
console.warn('Cannot disable yet...');
}, []);
return {
state: stallsState,
onDisableForceJsStalls,
onEnableForceJsStalls,
onEnableJsStallsTracking,
onDisableJsStallsTracking,
};
};
export default useJsStalls;