123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158 |
- import {ProjectFixture} from 'sentry-fixture/project';
- import {render, screen} from 'sentry-test/reactTestingLibrary';
- import type {Project} from 'sentry/types';
- import usePageFilters from 'sentry/utils/usePageFilters';
- import {Referrer} from 'sentry/views/performance/mobile/ui/referrers';
- import {UIScreens} from 'sentry/views/performance/mobile/ui/screens';
- import {useReleaseSelection} from 'sentry/views/starfish/queries/useReleases';
- jest.mock('sentry/utils/usePageFilters');
- jest.mock('sentry/views/starfish/queries/useReleases');
- jest.mocked(useReleaseSelection).mockReturnValue({
- primaryRelease: 'com.example.vu.android@2.10.5',
- isLoading: false,
- secondaryRelease: 'com.example.vu.android@2.10.3+42',
- });
- const createMockTablePayload = ({
- transaction,
- project,
- }: {
- project: Project;
- transaction: string;
- }) => ({
- 'avg_compare(mobile.frames_delay,release,com.example.vu.android@2.10.5,com.example.vu.android@2.10.3+42)':
- null,
- 'avg_compare(mobile.frozen_frames,release,com.example.vu.android@2.10.5,com.example.vu.android@2.10.3+42)':
- null,
- 'avg_compare(mobile.slow_frames,release,com.example.vu.android@2.10.5,com.example.vu.android@2.10.3+42)':
- null,
- 'avg_if(mobile.frames_delay,release,com.example.vu.android@2.10.5)': 0,
- 'avg_if(mobile.frames_delay,release,com.example.vu.android@2.10.3+42)': 0.259326119,
- 'avg_if(mobile.frozen_frames,release,com.example.vu.android@2.10.5)': 0,
- 'avg_if(mobile.frozen_frames,release,com.example.vu.android@2.10.3+42)': 0,
- 'avg_if(mobile.slow_frames,release,com.example.vu.android@2.10.5)': 0,
- 'avg_if(mobile.slow_frames,release,com.example.vu.android@2.10.3+42)': 2,
- 'project.id': project.id,
- transaction,
- });
- describe('Performance Mobile UI Screens', () => {
- const project = ProjectFixture({platform: 'apple-ios'});
- beforeEach(() => {
- MockApiClient.clearMockResponses();
- jest.mocked(usePageFilters).mockReturnValue({
- isReady: true,
- desyncedFilters: new Set(),
- pinnedFilters: new Set(),
- shouldPersist: true,
- selection: {
- datetime: {
- period: '10d',
- start: null,
- end: null,
- utc: false,
- },
- environments: [],
- projects: [parseInt(project.id, 10)],
- },
- });
- });
- it('queries for the correct table data', async () => {
- const tableRequestMock = MockApiClient.addMockResponse({
- url: '/organizations/org-slug/events/',
- body: [],
- match: [MockApiClient.matchQuery({referrer: Referrer.OVERVIEW_SCREENS_TABLE})],
- });
- render(<UIScreens />);
- expect(await screen.findByRole('columnheader', {name: 'Screen'})).toBeInTheDocument();
- [
- 'Slow (R1)',
- 'Slow (R2)',
- 'Frozen (R1)',
- 'Frozen (R2)',
- 'Delay (R1)',
- 'Delay (R2)',
- ].forEach(header => {
- expect(screen.getByRole('columnheader', {name: header})).toBeInTheDocument();
- });
- expect(screen.getAllByRole('columnheader', {name: 'Change'})).toHaveLength(3);
- expect(tableRequestMock).toHaveBeenCalledWith(
- '/organizations/org-slug/events/',
- expect.objectContaining({
- query: expect.objectContaining({
- field: [
- 'project.id',
- 'transaction',
- 'avg_if(mobile.slow_frames,release,com.example.vu.android@2.10.5)',
- 'avg_if(mobile.slow_frames,release,com.example.vu.android@2.10.3+42)',
- 'avg_if(mobile.frozen_frames,release,com.example.vu.android@2.10.5)',
- 'avg_if(mobile.frozen_frames,release,com.example.vu.android@2.10.3+42)',
- 'avg_if(mobile.frames_delay,release,com.example.vu.android@2.10.5)',
- 'avg_if(mobile.frames_delay,release,com.example.vu.android@2.10.3+42)',
- 'avg_compare(mobile.slow_frames,release,com.example.vu.android@2.10.5,com.example.vu.android@2.10.3+42)',
- 'avg_compare(mobile.frozen_frames,release,com.example.vu.android@2.10.5,com.example.vu.android@2.10.3+42)',
- 'avg_compare(mobile.frames_delay,release,com.example.vu.android@2.10.5,com.example.vu.android@2.10.3+42)',
- ],
- }),
- })
- );
- });
- it('queries for the correct chart data using the top transactions', async () => {
- MockApiClient.addMockResponse({
- url: '/organizations/org-slug/events/',
- body: {
- data: [
- createMockTablePayload({transaction: 'top 1', project}),
- createMockTablePayload({transaction: 'top 2', project}),
- createMockTablePayload({transaction: 'top 3', project}),
- createMockTablePayload({transaction: 'top 4', project}),
- createMockTablePayload({transaction: 'top 5', project}),
- createMockTablePayload({transaction: 'top 6', project}), // excluded
- ],
- },
- match: [MockApiClient.matchQuery({referrer: Referrer.OVERVIEW_SCREENS_TABLE})],
- });
- const chartDataRequest = MockApiClient.addMockResponse({
- url: '/organizations/org-slug/events/',
- body: [],
- match: [MockApiClient.matchQuery({referrer: Referrer.MOBILE_UI_BAR_CHART})],
- });
- render(<UIScreens />);
- await screen.findByText('top 1');
- screen.getByText('Top 5 Screen Slow Frames');
- screen.getByText('Top 5 Screen Frozen Frames');
- screen.getByText('Top 5 Screen Frames Delay');
- expect(chartDataRequest).toHaveBeenCalledWith(
- '/organizations/org-slug/events/',
- expect.objectContaining({
- query: expect.objectContaining({
- field: [
- 'transaction',
- 'release',
- 'avg(mobile.slow_frames)',
- 'avg(mobile.frozen_frames)',
- 'avg(mobile.frames_delay)',
- ],
- query:
- 'release:[com.example.vu.android@2.10.5,com.example.vu.android@2.10.3+42] transaction:["top 1","top 2","top 3","top 4","top 5"]',
- }),
- })
- );
- });
- });
|