import {render, screen} from 'sentry-test/reactTestingLibrary'; import TimeSince from 'sentry/components/timeSince'; describe('TimeSince', function () { const now = new Date(); const pastFiveSec = new Date(now.getTime() - 5 * 1000); const pastTenMin = new Date(now.getTime() - 10 * 60 * 1000); const futureTenMin = new Date(now.getTime() + 10 * 60 * 1000); it('renders a human relative date', () => { const {rerender} = render(); expect(screen.getByText('a few seconds ago')).toBeInTheDocument(); rerender(); expect(screen.getByText('10 minutes ago')).toBeInTheDocument(); rerender(); expect(screen.getByText('in 10 minutes')).toBeInTheDocument(); }); it('renders regular style', () => { render(); expect(screen.getByText('5 seconds ago')).toBeInTheDocument(); }); it('renders a shortened date', () => { render(); expect(screen.getByText('10min ago')).toBeInTheDocument(); }); it('renders a extrashort date', () => { render(); expect(screen.getByText('10m ago')).toBeInTheDocument(); }); it('renders a relative date without suffix', () => { render(); expect(screen.getByText('10 minutes')).toBeInTheDocument(); }); it('renders a relative date without prefix', () => { render(); expect(screen.getByText('10 minutes')).toBeInTheDocument(); }); it('renders a custom suffix', () => { render(); expect(screen.getByText('10 minutes until lunch')).toBeInTheDocument(); }); it('renders a custom prefix', () => { render(); expect(screen.getByText('lunch is in 10 minutes')).toBeInTheDocument(); }); it('renders a custom suffix with shortened', () => { render(); expect(screen.getByText('10m atrás')).toBeInTheDocument(); }); });