12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788 |
- import {Organization} from 'sentry-fixture/organization';
- 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 = TestStubs.Project();
- const organization = Organization({
- 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 = TestStubs.Event();
- event.tags.push({key: 'sample_event', value: 'yes'});
- MockApiClient.addMockResponse({
- url: `/organizations/${organization.slug}/events/latest/`,
- statusCode: 200,
- body: {
- ...event,
- },
- });
- render(
- <EventDetails
- {...TestStubs.routeComponentProps({params: {eventSlug: 'latest'}})}
- />,
- {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 = TestStubs.Event();
- MockApiClient.addMockResponse({
- url: `/organizations/${organization.slug}/events/latest/`,
- statusCode: 200,
- body: {
- ...event,
- },
- });
- render(
- <EventDetails
- {...TestStubs.routeComponentProps({params: {eventSlug: 'latest'}})}
- />,
- {organization}
- );
- expect(screen.queryByText(alertText)).not.toBeInTheDocument();
- // Expect stores to be updated
- await act(tick);
- });
- });
|