Files
react-native/Libraries/Utilities/__tests__/truncate-test.js
Georgios Andreadis 47e061549f Add tests for utility functions of library (#23903)
Summary:
I was looking at the coverage report of the JavaScript code in the `Libraries` folder, and found some of the modules and functions to be (partially) untested. I believe that adding tests to them would formally capture their behaviour and avoid future regressions. In this PR, I've added some unit tests for 3 utility components.

Perhaps a more general question: Are these kinds of PRs appreciated? I'd be interested in submitting more of them in the future.

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

Differential Revision: D14477601

Pulled By: cpojer

fbshipit-source-id: c0700c5b514cd0df983fecfd91c93fc2bd049f5d
2019-03-15 04:46:48 -07:00

66 lines
1.9 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('truncate', () => {
const truncate = require('truncate');
it('should truncate', () => {
expect(truncate('Hello, world.', 5)).toBe('He...');
});
it('should not truncate', () => {
expect(truncate('Hello, world.', 50)).toBe('Hello, world.');
});
it('should not truncate more than minDelta chars.', () => {
expect(truncate('Hello, world.', 7, {minDelta: 10})).toBe('Hello, world.');
expect(truncate('Hello, world.', 7, {minDelta: 9})).toBe('Hell...');
});
it('should break in the middle of words', () => {
expect(
truncate('Hello, world. How are you?', 18, {breakOnWords: false}),
).toBe('Hello, world. H...');
expect(
truncate('Hello, world.\nHow are you?', 18, {breakOnWords: false}),
).toBe('Hello, world.\nHo...');
});
it('should add another character if the truncations happens in the middle of a wide char', () => {
expect(
truncate('Hello, world. āA weird character', 18, {breakOnWords: false}),
).toBe('Hello, world. āA...');
});
it('should break at word boundaries', () => {
expect(
truncate('Hello, world. How are you?', 18, {breakOnWords: true}),
).toBe('Hello, world....');
expect(
truncate('Hello, world.\nHow are you?', 18, {breakOnWords: true}),
).toBe('Hello, world....');
});
it('should uses custom elipses', () => {
expect(truncate('Hello, world.', 9, {elipsis: '&middot'})).toBe(
'He&middot',
);
});
it("shouldn't barf with weird input", () => {
expect(truncate('Hello, world.', 0)).toBe('Hello,...');
expect(truncate('Hello, world.', -132)).toBe('...');
expect(truncate('', 0)).toBe('');
expect(truncate(null, 0)).toBe(null);
});
});