Files
react-native/Libraries/LogBox/__tests__/LogBox-test.js
T
Rick Hanlon c5aa26da41 Add log level to support errors
Summary:
This diff adds a level to LogBox logs so that we can store and display errors in later diffs

Changelog: [Internal]

Reviewed By: cpojer

Differential Revision: D18091101

fbshipit-source-id: 21661d28a7945bdcb56702e2a03ab3612c11fe35
2019-10-28 10:10:54 -07:00

80 lines
1.8 KiB
JavaScript

/**
* Copyright (c) Facebook, Inc. and its affiliates.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*
* @emails oncall+react_native
* @format
* @flow
*/
'use strict';
const LogBox = require('../LogBox');
const LogBoxData = require('../Data/LogBoxData');
declare var console: any;
describe('LogBox', () => {
const {error, warn} = console;
beforeEach(() => {
jest.resetModules();
console.error = jest.fn();
console.warn = jest.fn();
});
afterEach(() => {
LogBox.uninstall();
console.error = error;
console.warn = warn;
});
it('can set `disableLogBox` after installing', () => {
expect(console.disableLogBox).toBe(undefined);
LogBox.install();
expect(console.disableLogBox).toBe(false);
expect(LogBoxData.isDisabled()).toBe(false);
console.disableLogBox = true;
expect(console.disableLogBox).toBe(true);
expect(LogBoxData.isDisabled()).toBe(true);
});
it('can set `disableLogBox` before installing', () => {
expect(console.disableLogBox).toBe(undefined);
console.disableLogBox = true;
LogBox.install();
expect(console.disableLogBox).toBe(true);
expect(LogBoxData.isDisabled()).toBe(true);
});
it('registers warnings', () => {
jest.mock('../Data/LogBoxData');
LogBox.install();
expect(LogBoxData.add).not.toBeCalled();
console.warn('...');
expect(LogBoxData.add).toBeCalled();
});
it('registers errors beginning with "Warning: " as warnings', () => {
jest.mock('../Data/LogBoxData');
LogBox.install();
console.error('...');
expect(LogBoxData.add).toBeCalledWith('error', ['...']);
console.error('Warning: ...');
expect(LogBoxData.add).toBeCalledWith('warn', ['Warning: ...']);
});
});