timeSince.spec.tsx 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. import {render, screen} from 'sentry-test/reactTestingLibrary';
  2. import TimeSince from 'sentry/components/timeSince';
  3. describe('TimeSince', function () {
  4. const now = new Date();
  5. const pastFiveSec = new Date(now.getTime() - 5 * 1000);
  6. const pastTenMin = new Date(now.getTime() - 10 * 60 * 1000);
  7. const futureTenMin = new Date(now.getTime() + 10 * 60 * 1000);
  8. it('renders a human relative date', () => {
  9. const {rerender} = render(<TimeSince date={now} />);
  10. expect(screen.getByText('a few seconds ago')).toBeInTheDocument();
  11. rerender(<TimeSince date={pastTenMin} />);
  12. expect(screen.getByText('10 minutes ago')).toBeInTheDocument();
  13. rerender(<TimeSince date={futureTenMin} />);
  14. expect(screen.getByText('in 10 minutes')).toBeInTheDocument();
  15. });
  16. it('renders regular style', () => {
  17. render(<TimeSince date={pastFiveSec} unitStyle="regular" />);
  18. expect(screen.getByText('5 seconds ago')).toBeInTheDocument();
  19. });
  20. it('renders a shortened date', () => {
  21. render(<TimeSince unitStyle="short" date={pastTenMin} />);
  22. expect(screen.getByText('10min ago')).toBeInTheDocument();
  23. });
  24. it('renders a extrashort date', () => {
  25. render(<TimeSince unitStyle="extraShort" date={pastTenMin} />);
  26. expect(screen.getByText('10m ago')).toBeInTheDocument();
  27. });
  28. it('renders a relative date without suffix', () => {
  29. render(<TimeSince date={pastTenMin} suffix="" />);
  30. expect(screen.getByText('10 minutes')).toBeInTheDocument();
  31. });
  32. it('renders a relative date without prefix', () => {
  33. render(<TimeSince date={futureTenMin} prefix="" />);
  34. expect(screen.getByText('10 minutes')).toBeInTheDocument();
  35. });
  36. it('renders a custom suffix', () => {
  37. render(<TimeSince date={pastTenMin} suffix="until lunch" />);
  38. expect(screen.getByText('10 minutes until lunch')).toBeInTheDocument();
  39. });
  40. it('renders a custom prefix', () => {
  41. render(<TimeSince date={futureTenMin} prefix="lunch is in" />);
  42. expect(screen.getByText('lunch is in 10 minutes')).toBeInTheDocument();
  43. });
  44. it('renders a custom suffix with shortened', () => {
  45. render(<TimeSince unitStyle="extraShort" date={pastTenMin} suffix="atrás" />);
  46. expect(screen.getByText('10m atrás')).toBeInTheDocument();
  47. });
  48. });