import {render, screen, userEvent} from 'sentry-test/reactTestingLibrary';
import ProjectPerformance from 'sentry/views/settings/projectPerformance/projectPerformance';
describe('projectPerformance', function () {
const org = TestStubs.Organization({
features: ['performance-view', 'performance-issues-dev'],
});
const project = TestStubs.ProjectDetails();
const configUrl = '/projects/org-slug/project-slug/transaction-threshold/configure/';
let getMock, postMock, deleteMock, performanceIssuesMock;
beforeEach(function () {
MockApiClient.clearMockResponses();
getMock = MockApiClient.addMockResponse({
url: configUrl,
method: 'GET',
body: {
id: project.id,
threshold: '300',
metric: 'duration',
},
statusCode: 200,
});
postMock = MockApiClient.addMockResponse({
url: configUrl,
method: 'POST',
body: {
id: project.id,
threshold: '400',
metric: 'lcp',
},
statusCode: 200,
});
deleteMock = MockApiClient.addMockResponse({
url: configUrl,
method: 'DELETE',
statusCode: 200,
});
MockApiClient.addMockResponse({
url: '/projects/org-slug/project-slug/',
method: 'GET',
body: {},
statusCode: 200,
});
performanceIssuesMock = MockApiClient.addMockResponse({
url: '/projects/org-slug/project-slug/performance-issues/configure/',
method: 'GET',
body: {},
statusCode: 200,
});
});
it('renders the fields', function () {
render(
);
expect(
screen.getByRole('textbox', {name: 'Response Time Threshold (ms)'})
).toHaveValue('300');
expect(getMock).toHaveBeenCalledTimes(1);
});
it('updates the field', function () {
render(
);
const input = screen.getByRole('textbox', {name: 'Response Time Threshold (ms)'});
userEvent.clear(input);
userEvent.type(input, '400');
userEvent.tab();
expect(postMock).toHaveBeenCalledWith(
configUrl,
expect.objectContaining({
data: {threshold: '400'},
})
);
expect(input).toHaveValue('400');
});
it('clears the data', function () {
render(
);
userEvent.click(screen.getByRole('button', {name: 'Reset All'}));
expect(deleteMock).toHaveBeenCalled();
});
it('does not get performance issues settings without the feature flag', function () {
const orgWithoutPerfIssues = TestStubs.Organization({
features: ['performance-view'],
});
render(
);
expect(performanceIssuesMock).not.toHaveBeenCalled();
});
});