import React from 'react';
import { render, screen } from '../../jest/test-helpers';
import { isIntegerId, shortNumberFormat } from '../numbers';
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);
expect(isIntegerId(null as any)).toBe(false);
expect(isIntegerId(undefined as any)).toBe(false);
});
describe('shortNumberFormat', () => {
test('handles non-numbers', () => {
render(
{shortNumberFormat('not-number')}
, undefined, null);
expect(screen.getByTestId('num')).toHaveTextContent('•');
});
test('formats numbers under 1,000', () => {
render({shortNumberFormat(555)}
, undefined, null);
expect(screen.getByTestId('num')).toHaveTextContent('555');
});
test('formats numbers under 1,000,000', () => {
render({shortNumberFormat(5555)}
, undefined, null);
expect(screen.getByTestId('num')).toHaveTextContent('5.55k');
});
test('formats numbers over 1,000,000', () => {
render({shortNumberFormat(5555555)}
, undefined, null);
expect(screen.getByTestId('num')).toHaveTextContent('5.55M');
});
test('formats a multitude of numbers', () => {
let result = render({shortNumberFormat(0)}
, undefined, null);
expect(screen.getByTestId('num')).toHaveTextContent('0');
result.unmount();
result = render({shortNumberFormat(1)}
);
expect(screen.getByTestId('num')).toHaveTextContent('1');
result.unmount();
result = render({shortNumberFormat(999)}
, undefined, null);
expect(screen.getByTestId('num')).toHaveTextContent('999');
result.unmount();
result = render({shortNumberFormat(1000)}
, undefined, null);
expect(screen.getByTestId('num')).toHaveTextContent('1k');
result.unmount();
result = render({shortNumberFormat(1001)}
, undefined, null);
expect(screen.getByTestId('num')).toHaveTextContent('1k');
result.unmount();
result = render({shortNumberFormat(1005)}
, undefined, null);
expect(screen.getByTestId('num')).toHaveTextContent('1k');
result.unmount();
result = render({shortNumberFormat(1006)}
, undefined, null);
expect(screen.getByTestId('num')).toHaveTextContent('1k');
result.unmount();
result = render({shortNumberFormat(1010)}
, undefined, null);
expect(screen.getByTestId('num')).toHaveTextContent('1.01k');
result.unmount();
result = render({shortNumberFormat(1530)}
, undefined, null);
expect(screen.getByTestId('num')).toHaveTextContent('1.53k');
result.unmount();
result = render({shortNumberFormat(10530)}
, undefined, null);
expect(screen.getByTestId('num')).toHaveTextContent('10.5k');
result.unmount();
result = render({shortNumberFormat(999500)}
, undefined, null);
expect(screen.getByTestId('num')).toHaveTextContent('999k');
result.unmount();
result = render({shortNumberFormat(999999)}
, undefined, null);
expect(screen.getByTestId('num')).toHaveTextContent('999k');
result.unmount();
result = render({shortNumberFormat(999499)}
, undefined, null);
expect(screen.getByTestId('num')).toHaveTextContent('999k');
result.unmount();
result = render({shortNumberFormat(1000000)}
, undefined, null);
expect(screen.getByTestId('num')).toHaveTextContent('1M');
result.unmount();
result = render({shortNumberFormat(3905558)}
, undefined, null);
expect(screen.getByTestId('num')).toHaveTextContent('3.9M');
result.unmount();
result = render({shortNumberFormat(1031511)}
, undefined, null);
expect(screen.getByTestId('num')).toHaveTextContent('1.03M');
result.unmount();
});
});