version.spec.tsx 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. import {act, render, screen, userEvent} from 'sentry-test/reactTestingLibrary';
  2. import Version from 'sentry/components/version';
  3. const VERSION = 'foo.bar.Baz@1.0.0+20200101';
  4. describe('Version', () => {
  5. const context = TestStubs.routerContext();
  6. afterEach(() => {
  7. jest.resetAllMocks();
  8. });
  9. it('renders', () => {
  10. render(<Version version={VERSION} />);
  11. });
  12. it('shows correct parsed version', () => {
  13. // component uses @sentry/release-parser package for parsing versions
  14. render(<Version version={VERSION} />);
  15. expect(screen.getByText('1.0.0 (20200101)')).toBeInTheDocument();
  16. });
  17. it('links to release page', async () => {
  18. render(<Version version={VERSION} projectId="1" />, {
  19. context,
  20. });
  21. await userEvent.click(screen.getByText('1.0.0 (20200101)'));
  22. expect(context.context.router.push).toHaveBeenCalledWith({
  23. pathname: '/organizations/org-slug/releases/foo.bar.Baz%401.0.0%2B20200101/',
  24. query: {project: '1'},
  25. });
  26. });
  27. it('shows raw version in tooltip', async () => {
  28. jest.useFakeTimers();
  29. render(<Version version={VERSION} tooltipRawVersion />, {
  30. context,
  31. });
  32. expect(screen.queryByText(VERSION)).not.toBeInTheDocument();
  33. // Activate tooltip
  34. await userEvent.hover(screen.getByText('1.0.0 (20200101)'), {delay: null});
  35. act(() => jest.advanceTimersByTime(50));
  36. expect(screen.getByText(VERSION)).toBeInTheDocument();
  37. });
  38. });