Files
react-native/Libraries/Utilities/__tests__/logError-test.js
Casper Boone f541c34067 Add tests for utilities (#23989)
Summary:
This PR add tests for several utilities in `Libraries/Utilities`, as a follow-up of #23903.

The following utilities are now tested:
* `clamp.js`
* `binareToBase64.js`
* `DeviceInfo.js`
* `mergeIntoFast.js`
* `PixelRatio.js`
* `infoLog.js`
* `logError.js`
* `warnOnce.js`
* `mapWithSeparator` (added a missing test)

Not applicable, since it only adds tests.
Pull Request resolved: https://github.com/facebook/react-native/pull/23989

Differential Revision: D14502806

Pulled By: cpojer

fbshipit-source-id: e2c3b3a35f4f765d5336b998ab92dba14eeac7bc
2019-03-18 07:40:55 -07:00

49 lines
1.1 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.
*
* @format
* @emails oncall+react_native
*/
'use strict';
describe('logError', () => {
const logError = require('logError');
it('logs error messages to the console', () => {
console.error.apply = jest.fn();
logError('This is a log message');
expect(console.error.apply).toHaveBeenCalledWith(console, [
'This is a log message',
]);
});
it('logs error messages with multiple arguments to the console', () => {
console.error.apply = jest.fn();
const data = 'log';
logError('This is a', data, 'message');
expect(console.error.apply).toHaveBeenCalledWith(console, [
'This is a',
'log',
'message',
]);
});
it('logs errors to the console', () => {
console.error = jest.fn();
logError(new Error('The error message'));
expect(console.error.mock.calls[0][0]).toContain(
'Error: "The error message". Stack:',
);
});
});