Files
omni-tools/src/pages/tools/string/truncate/truncateText.service.test.ts
EugSh 19bdc5a53c feat: add Text Truncate tool
Implement Text Truncate tool with options for truncating text from the right, left, and line-by-line.
Allows setting custom truncation length and defining a truncation indicator.
2025-03-10 13:09:22 +03:00

136 lines
4.5 KiB
TypeScript

import { describe, expect, it } from 'vitest';
import { truncateText } from './service';
import { initialValues } from './initialValues';
describe('repeatText function (normal mode)', () => {
const text =
'Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.';
it('should truncate the text correctly on the right side', () => {
const maxLength = '30';
const result = truncateText({ ...initialValues, maxLength }, text);
expect(result).toBe('Lorem ipsum dolor sit amet, co');
});
it('should truncate the text correctly on the left side', () => {
const maxLength = '30';
const truncationSide = 'left';
const result = truncateText(
{ ...initialValues, maxLength, truncationSide },
text
);
expect(result).toBe('labore et dolore magna aliqua.');
});
it('should truncate the text and add the indicator correctly on the right side', () => {
const maxLength = '24';
const addIndicator = true;
const indicator = '...';
const result = truncateText(
{ ...initialValues, maxLength, addIndicator, indicator },
text
);
expect(result).toBe('Lorem ipsum dolor sit...');
});
it('should truncate the text and add the indicator correctly on the left side', () => {
const maxLength = '23';
const truncationSide = 'left';
const addIndicator = true;
const indicator = '...';
const result = truncateText(
{ ...initialValues, maxLength, truncationSide, addIndicator, indicator },
text
);
expect(result).toBe('...dolore magna aliqua.');
});
it('should throw an error if maxLength is less than zero', () => {
const maxLength = '-1';
expect(() =>
truncateText({ ...initialValues, maxLength }, text)
).toThrowError('Length value cannot be negative');
});
it('should throw an error if the indicator length is greater than the truncate length', () => {
const maxLength = '10';
const addIndicator = true;
const indicator = '.'.repeat(11);
expect(() =>
truncateText(
{ ...initialValues, maxLength, addIndicator, indicator },
text
)
).toThrowError('Indicator length is greater than truncation length');
});
});
describe('repeatText function (line by line mode)', () => {
const text = `
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.
Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.
Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur.`;
const maxLength = '45';
it('should truncate the multi-line text correctly on the right side', () => {
const lineByLine = true;
const result = truncateText(
{ ...initialValues, maxLength, lineByLine },
text
);
expect(result).toBe(`
Lorem ipsum dolor sit amet, consectetur adipi
Ut enim ad minim veniam, quis nostrud exercit
Duis aute irure dolor in reprehenderit in vol`);
});
it('should truncate the multi-line text correctly on the left side', () => {
const truncationSide = 'left';
const lineByLine = true;
const result = truncateText(
{ ...initialValues, maxLength, truncationSide, lineByLine },
text
);
expect(result).toBe(`
incididunt ut labore et dolore magna aliqua.
oris nisi ut aliquip ex ea commodo consequat.
esse cillum dolore eu fugiat nulla pariatur.`);
});
it('should truncate the multi-line and add the indicator text correctly on the right side', () => {
const lineByLine = true;
const addIndicator = true;
const indicator = '...';
const result = truncateText(
{ ...initialValues, maxLength, lineByLine, addIndicator, indicator },
text
);
expect(result).toBe(`
Lorem ipsum dolor sit amet, consectetur ad...
Ut enim ad minim veniam, quis nostrud exer...
Duis aute irure dolor in reprehenderit in ...`);
});
it('should truncate the multi-line and add the indicator text correctly on the left side', () => {
const lineByLine = true;
const truncationSide = 'left';
const addIndicator = true;
const indicator = '...';
const result = truncateText(
{
...initialValues,
maxLength,
truncationSide,
lineByLine,
addIndicator,
indicator
},
text
);
expect(result).toBe(`
...cididunt ut labore et dolore magna aliqua.
...s nisi ut aliquip ex ea commodo consequat.
...se cillum dolore eu fugiat nulla pariatur.`);
});
});