73 lines
2.2 KiB
JavaScript
73 lines
2.2 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
|
|
*/
|
|
|
|
import typeof {enable} from 'promise/setimmediate/rejection-tracking';
|
|
|
|
import LogBox from './LogBox/LogBox';
|
|
|
|
let rejectionTrackingOptions: $NonMaybeType<Parameters<enable>[0]> = {
|
|
allRejections: true,
|
|
onUnhandled: (id, rejection = {}) => {
|
|
let message: string;
|
|
let stack: ?string;
|
|
|
|
// $FlowFixMe[method-unbinding] added when improving typing for this parameters
|
|
const stringValue = Object.prototype.toString.call(rejection);
|
|
if (stringValue === '[object Error]') {
|
|
// $FlowFixMe[method-unbinding] added when improving typing for this parameters
|
|
message = Error.prototype.toString.call(rejection);
|
|
const error: Error = (rejection: $FlowFixMe);
|
|
stack = error.stack;
|
|
} else {
|
|
try {
|
|
message = require('pretty-format').format(rejection);
|
|
} catch {
|
|
message =
|
|
typeof rejection === 'string'
|
|
? rejection
|
|
: JSON.stringify((rejection: $FlowFixMe));
|
|
}
|
|
// It could although this object is not a standard error, it still has stack information to unwind
|
|
// $FlowFixMe ignore types just check if stack is there
|
|
if (rejection?.stack && typeof rejection.stack === 'string') {
|
|
stack = rejection.stack;
|
|
}
|
|
}
|
|
|
|
const warning = `Possible unhandled promise rejection (id: ${id}):\n${
|
|
message ?? ''
|
|
}`;
|
|
if (__DEV__) {
|
|
LogBox.addLog({
|
|
level: 'warn',
|
|
message: {
|
|
content: warning,
|
|
substitutions: [],
|
|
},
|
|
componentStack: [],
|
|
componentStackType: null,
|
|
stack,
|
|
category: 'possible_unhandled_promise_rejection',
|
|
});
|
|
} else {
|
|
console.warn(warning);
|
|
}
|
|
},
|
|
onHandled: id => {
|
|
const warning =
|
|
`Promise rejection handled (id: ${id})\n` +
|
|
'This means you can ignore any previous messages of the form ' +
|
|
`"Possible unhandled promise rejection (id: ${id}):"`;
|
|
console.warn(warning);
|
|
},
|
|
};
|
|
|
|
export default rejectionTrackingOptions;
|