mirror of
https://github.com/zhigang1992/react-native.git
synced 2026-05-09 13:37:58 +08:00
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
66 lines
1.9 KiB
JavaScript
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: '·'})).toBe(
|
|
'He·',
|
|
);
|
|
});
|
|
|
|
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);
|
|
});
|
|
});
|