profileSummaryPage.spec.tsx 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. import type {Location} from 'history';
  2. import {GlobalSelectionFixture} from 'sentry-fixture/globalSelection';
  3. import {OrganizationFixture} from 'sentry-fixture/organization';
  4. import {ProjectFixture} from 'sentry-fixture/project';
  5. import {render, screen} from 'sentry-test/reactTestingLibrary';
  6. import OrganizationStore from 'sentry/stores/organizationStore';
  7. import ProfileSummaryPage from 'sentry/views/profiling/profileSummary';
  8. Object.defineProperty(window, 'matchMedia', {
  9. writable: true,
  10. value: jest.fn().mockImplementation(query => ({
  11. matches: false,
  12. media: query,
  13. onchange: null,
  14. addListener: jest.fn(), // Deprecated
  15. removeListener: jest.fn(), // Deprecated
  16. addEventListener: jest.fn(),
  17. removeEventListener: jest.fn(),
  18. dispatchEvent: jest.fn(),
  19. })),
  20. });
  21. // Replace the webgl renderer with a dom renderer for tests
  22. jest.mock('sentry/utils/profiling/renderers/flamegraphRendererWebGL', () => {
  23. const {
  24. FlamegraphRendererDOM,
  25. } = require('sentry/utils/profiling/renderers/flamegraphRendererDOM');
  26. return {
  27. FlamegraphRendererWebGL: FlamegraphRendererDOM,
  28. };
  29. });
  30. window.ResizeObserver =
  31. window.ResizeObserver ||
  32. jest.fn().mockImplementation(() => ({
  33. disconnect: jest.fn(),
  34. observe: jest.fn(),
  35. unobserve: jest.fn(),
  36. }));
  37. describe('ProfileSummaryPage', () => {
  38. it('renders new page', async () => {
  39. const organization = OrganizationFixture({
  40. features: [],
  41. projects: [ProjectFixture()],
  42. });
  43. OrganizationStore.onUpdate(organization);
  44. MockApiClient.addMockResponse({
  45. url: `/organizations/${organization.slug}/projects/`,
  46. body: [ProjectFixture()],
  47. });
  48. MockApiClient.addMockResponse({
  49. url: `/organizations/${organization.slug}/profiling/filters/`,
  50. body: [],
  51. });
  52. MockApiClient.addMockResponse({
  53. url: `/organizations/${organization.slug}/events-stats/`,
  54. body: {},
  55. });
  56. MockApiClient.addMockResponse({
  57. url: `/organizations/${organization.slug}/profiling/flamegraph/`,
  58. body: [],
  59. });
  60. MockApiClient.addMockResponse({
  61. url: `/organizations/${organization.slug}/events/`,
  62. body: {
  63. data: [{'last_seen()': new Date()}],
  64. },
  65. });
  66. MockApiClient.addMockResponse({
  67. url: `/organizations/${organization.slug}/profiling/function-trends/`,
  68. body: [],
  69. });
  70. render(
  71. <ProfileSummaryPage
  72. view="flamegraph"
  73. params={{}}
  74. selection={GlobalSelectionFixture()}
  75. location={
  76. {
  77. query: {transaction: 'fancyservice'},
  78. } as unknown as Location
  79. }
  80. />,
  81. {
  82. organization: OrganizationFixture({
  83. features: ['profiling-summary-redesign'],
  84. }),
  85. }
  86. );
  87. expect(await screen.findByTestId(/profile-summary-redesign/i)).toBeInTheDocument();
  88. });
  89. });