Files
react-native/Libraries/Utilities/__tests__/PixelRatio-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

53 lines
1.2 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('PixelRatio', () => {
const Dimensions = require('Dimensions');
const PixelRatio = require('PixelRatio');
beforeEach(() => {
Dimensions.set({
windowPhysicalPixels: {
width: 400,
height: 800,
scale: 2,
fontScale: 3,
},
});
});
it('should give the pixel density', () => {
expect(PixelRatio.get()).toEqual(2);
});
it('should give the font scale when present', () => {
expect(PixelRatio.getFontScale()).toEqual(3);
});
it('should give the pixel density instead of the font scale when the front scale is not present', () => {
Dimensions.set({
windowPhysicalPixels: {
scale: 2,
},
});
expect(PixelRatio.getFontScale()).toEqual(2);
});
it('should convert a layout size to pixel size', () => {
expect(PixelRatio.getPixelSizeForLayoutSize(400)).toEqual(800);
});
it('should round a layout size to pixel size', () => {
expect(PixelRatio.roundToNearestPixel(8.4)).toEqual(8.5);
});
});