import {initializeData as _initializeData} from 'sentry-test/performance/initializePerformanceData';
import {act, render, screen, within} from 'sentry-test/reactTestingLibrary';
import ProjectsStore from 'sentry/stores/projectsStore';
import EventView from 'sentry/utils/discover/eventView';
import {DEFAULT_EVENT_VIEW} from 'sentry/views/eventsV2/data';
import TraceDetailsContent from 'sentry/views/performance/traceDetails/content';
const SAMPLE_ERROR_DATA = {
data: [
{id: '1', level: 'error', title: 'Test error 1', project: 'sentry'},
{id: '2', level: 'fatal', title: 'Test error 2', project: 'sentry'},
],
};
const initializeData = () => {
const data = _initializeData({
features: ['performance-view', 'trace-view'],
});
act(() => ProjectsStore.loadInitialData(data.organization.projects));
return data;
};
describe('TraceDetailsContent', () => {
describe('Without Transactions', () => {
beforeEach(() => {
MockApiClient.addMockResponse({
url: '/organizations/org-slug/events/',
body: SAMPLE_ERROR_DATA,
});
});
afterEach(function () {
MockApiClient.clearMockResponses();
ProjectsStore.reset();
});
it('should render a list of errors when a trace contains only error events', async () => {
const initialData = initializeData();
const eventView = EventView.fromSavedQuery(DEFAULT_EVENT_VIEW);
const meta = {errors: 2, projects: 1, transactions: 0};
render(
);
const errorList = await screen.findByTestId('trace-view-errors');
expect(
await within(errorList).findByText(SAMPLE_ERROR_DATA.data[0].title)
).toBeInTheDocument();
expect(
await within(errorList).findByText(SAMPLE_ERROR_DATA.data[1].title)
).toBeInTheDocument();
expect(
await within(errorList).findByText(SAMPLE_ERROR_DATA.data[0].level)
).toBeInTheDocument();
expect(
await within(errorList).findByText(SAMPLE_ERROR_DATA.data[1].level)
).toBeInTheDocument();
});
it('should should display an error if the error events could not be fetched', async () => {
MockApiClient.addMockResponse({
url: '/organizations/org-slug/events/',
statusCode: 404,
body: {detail: 'This is a test error'},
});
const initialData = initializeData();
const eventView = EventView.fromSavedQuery(DEFAULT_EVENT_VIEW);
const meta = {errors: 2, projects: 1, transactions: 0};
render(
);
const errorText = await screen.findByText(
'The trace cannot be shown when all events are errors. An error occurred when attempting to fetch these error events:'
);
const errorContainer = errorText.parentElement;
expect(errorContainer).not.toBeNull();
expect(
within(errorContainer!).getByText('This is a test error')
).toBeInTheDocument();
});
});
});