mirror of
https://github.com/status-im/react-native.git
synced 2025-01-17 21:11:45 +00:00
5d4d62f474
Summary: The stall watchdog is handy to detect stalls, but it doesn't really tell us what was happening. This diff makes it easy to track React perf and bridge traffic during any stall, and prints it out if the stall exceeds the threshold. Reviewed By: yungsters Differential Revision: D4479439 fbshipit-source-id: 87f94913ec341a648d7744249597dc30b29759ab
36 lines
893 B
JavaScript
36 lines
893 B
JavaScript
/**
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
|
* All rights reserved.
|
|
*
|
|
* This source code is licensed under the BSD-style license found in the
|
|
* LICENSE file in the root directory of this source tree. An additional grant
|
|
* of patent rights can be found in the PATENTS file in the same directory.
|
|
*
|
|
* @providesModule ReactPerfStallHandler
|
|
* @flow
|
|
*/
|
|
'use strict';
|
|
|
|
const JSEventLoopWatchdog = require('JSEventLoopWatchdog');
|
|
const ReactPerf = require('ReactPerf');
|
|
|
|
const ReactPerfStallHandler = {
|
|
register: function() {
|
|
ReactPerf.start();
|
|
JSEventLoopWatchdog.addHandler({
|
|
onStall: () => {
|
|
ReactPerf.stop();
|
|
ReactPerf.printInclusive();
|
|
ReactPerf.printWasted();
|
|
ReactPerf.start();
|
|
},
|
|
onIterate: () => {
|
|
ReactPerf.stop();
|
|
ReactPerf.start();
|
|
},
|
|
});
|
|
},
|
|
};
|
|
|
|
module.exports = ReactPerfStallHandler;
|