Files
react-native/Libraries/LogBox/__tests__/LogBox-test.js
T
Rick Hanlon a09ab64874 Don't pass through ignored warnings to console
Summary:
This diff check if warnings are ignored before calling through to the wrapped console.warn implementation below, thus preventing ignored logs from being sent to adb/metro/flipper and cleaning them up a bit.

Changelog: [Internal]

Reviewed By: cpojer

Differential Revision: D18239936

fbshipit-source-id: 533beced3e66ad1a4d0810933862c63a0b88628c
2019-10-31 16:26:44 -07:00

121 lines
2.8 KiB
JavaScript
Raw Blame History

This file contains invisible Unicode characters
This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
/**
* 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.addLog).not.toBeCalled();
console.warn('...');
expect(LogBoxData.addLog).toBeCalled();
});
it('registers errors beginning with "Warning: " as warnings', () => {
jest.mock('../Data/LogBoxData');
LogBox.install();
console.error('...');
expect(LogBoxData.addLog).not.toBeCalled();
console.error('Warning: ...');
expect(LogBoxData.addLog).toBeCalledWith({
category: 'Warning: ...',
componentStack: [],
level: 'warn',
message: {content: 'Warning: ...', substitutions: []},
});
});
it('ignores logs that are pattern ignored"', () => {
jest.mock('../Data/LogBoxData');
(LogBoxData.isMessageIgnored: any).mockReturnValue(true);
LogBox.install();
console.warn('ignored message');
expect(LogBoxData.addLog).not.toBeCalled();
});
it('ignores logs starting with "(ADVICE)"', () => {
jest.mock('../Data/LogBoxData');
LogBox.install();
console.warn('(ADVICE) ...');
expect(LogBoxData.addLog).not.toBeCalled();
});
it('does not ignore logs formatted to start with "(ADVICE)"', () => {
jest.mock('../Data/LogBoxData');
LogBox.install();
console.warn('%s ...', '(ADVICE)');
expect(LogBoxData.addLog).toBeCalledWith({
category: '%s ...',
componentStack: [],
level: 'warn',
message: {
content: '(ADVICE) ...',
substitutions: [{length: 8, offset: 0}],
},
});
});
});