2022-04-25 08:08:32 -07:00
|
|
|
import React from 'react';
|
|
|
|
|
|
|
|
import { render, screen } from '../../jest/test-helpers';
|
2022-10-26 10:08:02 -07:00
|
|
|
import { isIntegerId, secondsToDays, shortNumberFormat } from '../numbers';
|
2022-04-25 08:08:32 -07:00
|
|
|
|
|
|
|
test('isIntegerId()', () => {
|
|
|
|
expect(isIntegerId('0')).toBe(true);
|
|
|
|
expect(isIntegerId('1')).toBe(true);
|
|
|
|
expect(isIntegerId('508107650')).toBe(true);
|
|
|
|
expect(isIntegerId('-1764036199')).toBe(true);
|
|
|
|
expect(isIntegerId('106801667066418367')).toBe(true);
|
|
|
|
expect(isIntegerId('9v5bmRalQvjOy0ECcC')).toBe(false);
|
2022-07-06 09:36:01 -07:00
|
|
|
expect(isIntegerId(null as any)).toBe(false);
|
|
|
|
expect(isIntegerId(undefined as any)).toBe(false);
|
2022-04-25 08:08:32 -07:00
|
|
|
});
|
|
|
|
|
2022-10-26 10:08:02 -07:00
|
|
|
test('secondsToDays', () => {
|
|
|
|
expect(secondsToDays(604800)).toEqual(7);
|
|
|
|
expect(secondsToDays(1209600)).toEqual(14);
|
|
|
|
expect(secondsToDays(2592000)).toEqual(30);
|
|
|
|
expect(secondsToDays(7776000)).toEqual(90);
|
|
|
|
});
|
|
|
|
|
2022-04-25 08:08:32 -07:00
|
|
|
describe('shortNumberFormat', () => {
|
|
|
|
test('handles non-numbers', () => {
|
2022-07-06 09:36:01 -07:00
|
|
|
render(<div data-testid='num'>{shortNumberFormat('not-number')}</div>, undefined, null);
|
2022-04-25 08:08:32 -07:00
|
|
|
expect(screen.getByTestId('num')).toHaveTextContent('•');
|
|
|
|
});
|
|
|
|
|
2022-11-03 09:13:45 -07:00
|
|
|
test('handles max argument', () => {
|
|
|
|
render(<div data-testid='num'>{shortNumberFormat(25, 20)}</div>, undefined, null);
|
|
|
|
expect(screen.getByTestId('num')).toHaveTextContent('20+');
|
|
|
|
});
|
|
|
|
|
2022-04-25 08:08:32 -07:00
|
|
|
test('formats numbers under 1,000', () => {
|
2022-07-06 09:36:01 -07:00
|
|
|
render(<div data-testid='num'>{shortNumberFormat(555)}</div>, undefined, null);
|
2022-04-25 08:08:32 -07:00
|
|
|
expect(screen.getByTestId('num')).toHaveTextContent('555');
|
|
|
|
});
|
|
|
|
|
|
|
|
test('formats numbers under 1,000,000', () => {
|
2022-07-06 09:36:01 -07:00
|
|
|
render(<div data-testid='num'>{shortNumberFormat(5555)}</div>, undefined, null);
|
2022-08-24 11:46:40 -07:00
|
|
|
expect(screen.getByTestId('num')).toHaveTextContent('5.55k');
|
2022-04-25 08:08:32 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
test('formats numbers over 1,000,000', () => {
|
2022-07-06 09:36:01 -07:00
|
|
|
render(<div data-testid='num'>{shortNumberFormat(5555555)}</div>, undefined, null);
|
2022-08-24 11:46:40 -07:00
|
|
|
expect(screen.getByTestId('num')).toHaveTextContent('5.55M');
|
|
|
|
});
|
|
|
|
|
|
|
|
test('formats a multitude of numbers', () => {
|
|
|
|
let result = render(<div data-testid='num'>{shortNumberFormat(0)}</div>, undefined, null);
|
|
|
|
expect(screen.getByTestId('num')).toHaveTextContent('0');
|
|
|
|
result.unmount();
|
|
|
|
|
|
|
|
result = render(<div data-testid='num'>{shortNumberFormat(1)}</div>);
|
|
|
|
expect(screen.getByTestId('num')).toHaveTextContent('1');
|
|
|
|
result.unmount();
|
|
|
|
|
|
|
|
result = render(<div data-testid='num'>{shortNumberFormat(999)}</div>, undefined, null);
|
|
|
|
expect(screen.getByTestId('num')).toHaveTextContent('999');
|
|
|
|
result.unmount();
|
|
|
|
|
|
|
|
result = render(<div data-testid='num'>{shortNumberFormat(1000)}</div>, undefined, null);
|
|
|
|
expect(screen.getByTestId('num')).toHaveTextContent('1k');
|
|
|
|
result.unmount();
|
|
|
|
|
|
|
|
result = render(<div data-testid='num'>{shortNumberFormat(1001)}</div>, undefined, null);
|
|
|
|
expect(screen.getByTestId('num')).toHaveTextContent('1k');
|
|
|
|
result.unmount();
|
|
|
|
|
|
|
|
result = render(<div data-testid='num'>{shortNumberFormat(1005)}</div>, undefined, null);
|
|
|
|
expect(screen.getByTestId('num')).toHaveTextContent('1k');
|
|
|
|
result.unmount();
|
|
|
|
|
|
|
|
result = render(<div data-testid='num'>{shortNumberFormat(1006)}</div>, undefined, null);
|
|
|
|
expect(screen.getByTestId('num')).toHaveTextContent('1k');
|
|
|
|
result.unmount();
|
|
|
|
|
|
|
|
result = render(<div data-testid='num'>{shortNumberFormat(1010)}</div>, undefined, null);
|
|
|
|
expect(screen.getByTestId('num')).toHaveTextContent('1.01k');
|
|
|
|
result.unmount();
|
|
|
|
|
|
|
|
result = render(<div data-testid='num'>{shortNumberFormat(1530)}</div>, undefined, null);
|
|
|
|
expect(screen.getByTestId('num')).toHaveTextContent('1.53k');
|
|
|
|
result.unmount();
|
|
|
|
|
|
|
|
result = render(<div data-testid='num'>{shortNumberFormat(10530)}</div>, undefined, null);
|
|
|
|
expect(screen.getByTestId('num')).toHaveTextContent('10.5k');
|
|
|
|
result.unmount();
|
|
|
|
|
|
|
|
result = render(<div data-testid='num'>{shortNumberFormat(999500)}</div>, undefined, null);
|
|
|
|
expect(screen.getByTestId('num')).toHaveTextContent('999k');
|
|
|
|
result.unmount();
|
|
|
|
|
|
|
|
result = render(<div data-testid='num'>{shortNumberFormat(999999)}</div>, undefined, null);
|
|
|
|
expect(screen.getByTestId('num')).toHaveTextContent('999k');
|
|
|
|
result.unmount();
|
|
|
|
|
|
|
|
result = render(<div data-testid='num'>{shortNumberFormat(999499)}</div>, undefined, null);
|
|
|
|
expect(screen.getByTestId('num')).toHaveTextContent('999k');
|
|
|
|
result.unmount();
|
|
|
|
|
|
|
|
result = render(<div data-testid='num'>{shortNumberFormat(1000000)}</div>, undefined, null);
|
|
|
|
expect(screen.getByTestId('num')).toHaveTextContent('1M');
|
|
|
|
result.unmount();
|
|
|
|
|
|
|
|
result = render(<div data-testid='num'>{shortNumberFormat(3905558)}</div>, undefined, null);
|
|
|
|
expect(screen.getByTestId('num')).toHaveTextContent('3.9M');
|
|
|
|
result.unmount();
|
|
|
|
|
|
|
|
result = render(<div data-testid='num'>{shortNumberFormat(1031511)}</div>, undefined, null);
|
|
|
|
expect(screen.getByTestId('num')).toHaveTextContent('1.03M');
|
|
|
|
result.unmount();
|
2022-04-25 08:08:32 -07:00
|
|
|
});
|
|
|
|
});
|