nameAndDescFields.spec.tsx 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. import {OrganizationFixture} from 'sentry-fixture/organization';
  2. import {RouterFixture} from 'sentry-fixture/routerFixture';
  3. import {render, screen, userEvent} from 'sentry-test/reactTestingLibrary';
  4. import {useNavigate} from 'sentry/utils/useNavigate';
  5. import WidgetBuilderNameAndDescription from 'sentry/views/dashboards/widgetBuilder/components/nameAndDescFields';
  6. import {WidgetBuilderProvider} from 'sentry/views/dashboards/widgetBuilder/contexts/widgetBuilderContext';
  7. jest.mock('sentry/utils/useNavigate', () => ({
  8. useNavigate: jest.fn(),
  9. }));
  10. const mockUseNavigate = jest.mocked(useNavigate);
  11. describe('WidgetBuilder', () => {
  12. let router!: ReturnType<typeof RouterFixture>;
  13. let organization!: ReturnType<typeof OrganizationFixture>;
  14. beforeEach(function () {
  15. router = RouterFixture({
  16. location: {
  17. pathname: '/organizations/org-slug/dashboard/1/',
  18. query: {project: '-1'},
  19. },
  20. params: {},
  21. });
  22. organization = OrganizationFixture({});
  23. });
  24. it('edits name and description', async function () {
  25. const mockNavigate = jest.fn();
  26. mockUseNavigate.mockReturnValue(mockNavigate);
  27. render(
  28. <WidgetBuilderProvider>
  29. <WidgetBuilderNameAndDescription />
  30. </WidgetBuilderProvider>,
  31. {
  32. router,
  33. organization,
  34. }
  35. );
  36. await userEvent.type(await screen.findByPlaceholderText('Name'), 'some name');
  37. expect(mockNavigate).toHaveBeenLastCalledWith(
  38. expect.objectContaining({
  39. ...router.location,
  40. query: expect.objectContaining({title: 'some name'}),
  41. }),
  42. {replace: true}
  43. );
  44. await userEvent.click(await screen.findByTestId('add-description'));
  45. await userEvent.type(
  46. await screen.findByPlaceholderText('Description'),
  47. 'some description'
  48. );
  49. expect(mockNavigate).toHaveBeenLastCalledWith(
  50. expect.objectContaining({
  51. ...router.location,
  52. query: expect.objectContaining({description: 'some description'}),
  53. }),
  54. {replace: true}
  55. );
  56. });
  57. it('displays error', async function () {
  58. render(
  59. <WidgetBuilderProvider>
  60. <WidgetBuilderNameAndDescription
  61. error={{title: 'Title is required during creation.'}}
  62. />
  63. </WidgetBuilderProvider>,
  64. {router, organization}
  65. );
  66. expect(
  67. await screen.findByText('Title is required during creation.')
  68. ).toBeInTheDocument();
  69. });
  70. });