import {initializeOrg} from 'sentry-test/initializeOrg';
import {
render,
renderGlobalModal,
screen,
userEvent,
} from 'sentry-test/reactTestingLibrary';
import ProjectSourceMaps from 'sentry/views/settings/projectSourceMaps/list';
describe('ProjectSourceMaps', function () {
const {organization, project, routerContext, router} = initializeOrg({});
const endpoint = `/projects/${organization.slug}/${project.slug}/files/source-maps/`;
const props = {
organization,
project,
params: {orgId: organization.slug, projectId: project.slug},
location: routerContext.context.location,
router,
};
afterEach(() => {
MockApiClient.clearMockResponses();
});
it('renders', function () {
MockApiClient.addMockResponse({
url: endpoint,
body: [
TestStubs.SourceMapArchive(),
TestStubs.SourceMapArchive({id: 2, name: 'abc'}),
],
});
render();
const rows = screen.getAllByLabelText('Remove All Artifacts');
expect(rows).toHaveLength(2);
expect(screen.getByText('1234')).toBeInTheDocument();
});
it('renders empty', function () {
MockApiClient.addMockResponse({
url: endpoint,
body: [],
});
render();
expect(
screen.getByText('There are no archives for this project.')
).toBeInTheDocument();
});
it('deletes the archive', async function () {
const archive = TestStubs.SourceMapArchive();
MockApiClient.addMockResponse({
url: endpoint,
body: [archive],
});
const deleteMock = MockApiClient.addMockResponse({
method: 'DELETE',
url: endpoint,
});
render();
renderGlobalModal();
await userEvent.click(screen.getByRole('button', {name: 'Remove All Artifacts'}));
// Confirm Modal
await userEvent.click(screen.getByRole('button', {name: 'Confirm'}));
expect(deleteMock).toHaveBeenCalledWith(
endpoint,
expect.objectContaining({query: {name: archive.name}})
);
});
it('filters archives', async function () {
const mockRouter = {push: jest.fn()};
const mock = MockApiClient.addMockResponse({
url: endpoint,
body: [],
});
render(
);
expect(mock).toHaveBeenCalledWith(
endpoint,
expect.objectContaining({
query: {query: 'abc'},
})
);
const filterInput = screen.getByPlaceholderText('Filter Archives');
await userEvent.clear(filterInput);
await userEvent.type(filterInput, 'defg{enter}');
expect(mockRouter.push).toHaveBeenCalledWith({
query: {cursor: undefined, query: 'defg'},
});
});
});