import {EventFixture} from 'sentry-fixture/event';
import {OrganizationFixture} from 'sentry-fixture/organization';
import {ProjectFixture} from 'sentry-fixture/project';
import {RouteComponentPropsFixture} from 'sentry-fixture/routeComponentPropsFixture';
import {act, render, screen} from 'sentry-test/reactTestingLibrary';
import ProjectsStore from 'sentry/stores/projectsStore';
import EventDetails from 'sentry/views/performance/transactionDetails';
const alertText =
'You are viewing a sample transaction. Configure performance to start viewing real transactions.';
describe('EventDetails', () => {
const project = ProjectFixture();
const organization = OrganizationFixture({
features: ['performance-view'],
projects: [project],
});
beforeEach(() => {
ProjectsStore.loadInitialData([project]);
MockApiClient.addMockResponse({
url: `/organizations/${organization.slug}/projects/`,
statusCode: 200,
body: [],
});
MockApiClient.addMockResponse({
url: `/projects/${organization.slug}/latest/events/1/grouping-info/`,
statusCode: 200,
body: {},
});
MockApiClient.addMockResponse({
url: `/projects/${organization.slug}/latest/events/1/committers/`,
statusCode: 200,
body: [],
});
});
afterEach(() => {
ProjectsStore.reset();
MockApiClient.clearMockResponses();
});
it('renders alert for sample transaction', async () => {
const event = EventFixture();
event.tags.push({key: 'sample_event', value: 'yes'});
MockApiClient.addMockResponse({
url: `/organizations/${organization.slug}/events/latest/`,
statusCode: 200,
body: {
...event,
},
});
render(
,
{organization}
);
expect(screen.getByText(alertText)).toBeInTheDocument();
// Expect stores to be updated
await act(tick);
});
it('does not reender alert if already received transaction', async () => {
const event = EventFixture();
MockApiClient.addMockResponse({
url: `/organizations/${organization.slug}/events/latest/`,
statusCode: 200,
body: {
...event,
},
});
render(
,
{organization}
);
expect(screen.queryByText(alertText)).not.toBeInTheDocument();
// Expect stores to be updated
await act(tick);
});
});