import {cleanup, render, screen} from 'sentry-test/reactTestingLibrary';
import ProjectsStore from 'sentry/stores/projectsStore';
import {OrganizationContext} from 'sentry/views/organizationContext';
import EventDetails from 'sentry/views/performance/transactionDetails';
const alertText =
'You are viewing a sample transaction. Configure performance to start viewing real transactions.';
describe('EventDetails', () => {
afterEach(cleanup);
it('renders alert for sample transaction', () => {
const project = TestStubs.Project();
ProjectsStore.loadInitialData([project]);
const organization = TestStubs.Organization({
features: ['performance-view'],
projects: [project],
});
const event = TestStubs.Event();
event.tags.push({key: 'sample_event', value: 'yes'});
const routerContext = TestStubs.routerContext([]);
MockApiClient.addMockResponse({
url: `/organizations/${organization.slug}/events/latest/`,
statusCode: 200,
body: {
...event,
},
});
MockApiClient.warnOnMissingMocks();
render(
);
expect(screen.getByText(alertText)).toBeInTheDocument();
});
it('does not reender alert if already received transaction', () => {
const project = TestStubs.Project();
ProjectsStore.loadInitialData([project]);
const organization = TestStubs.Organization({
features: ['performance-view'],
projects: [project],
});
const event = TestStubs.Event();
const routerContext = TestStubs.routerContext([]);
MockApiClient.addMockResponse({
url: `/organizations/${organization.slug}/events/latest/`,
statusCode: 200,
body: {
...event,
},
});
MockApiClient.warnOnMissingMocks();
render(
);
expect(screen.queryByText(alertText)).not.toBeInTheDocument();
});
});