import {
render,
renderGlobalModal,
screen,
userEvent,
} from 'sentry-test/reactTestingLibrary';
import {Client} from 'sentry/api';
import RepositoryRow from 'sentry/components/repositoryRow';
describe('RepositoryRow', function () {
beforeEach(function () {
MockApiClient.clearMockResponses();
});
const repository = TestStubs.Repository();
const pendingRepo = TestStubs.Repository({
status: 'pending_deletion',
});
const customRepo = TestStubs.Repository({
provider: {
id: 'integrations:custom_scm',
},
});
const customPendingRepo = TestStubs.Repository({
provider: {
id: 'integrations:custom_scm',
},
status: 'pending_deletion',
});
const api = new Client();
describe('rendering with access', function () {
const organization = TestStubs.Organization({
access: ['org:integrations'],
});
const routerContext = TestStubs.routerContext([{organization}]);
it('displays provider information', function () {
render(
,
{context: routerContext}
);
expect(screen.getByText(repository.name)).toBeInTheDocument();
expect(screen.getByText('github.com/example/repo-name')).toBeInTheDocument();
// Trash button should display enabled
expect(screen.getByRole('button', {name: 'delete'})).toBeEnabled();
// No cancel button
expect(screen.queryByRole('button', {name: 'Cancel'})).not.toBeInTheDocument();
});
it('displays cancel pending button', function () {
render(
,
{context: routerContext}
);
// Trash button should be disabled
expect(screen.getByRole('button', {name: 'delete'})).toBeDisabled();
// Cancel button active
expect(screen.getByRole('button', {name: 'Cancel'})).toBeInTheDocument();
expect(screen.getByRole('button', {name: 'Cancel'})).toBeEnabled();
});
});
describe('rendering without access', function () {
const organization = TestStubs.Organization({
access: ['org:write'],
});
const routerContext = TestStubs.routerContext([{organization}]);
it('displays disabled trash', function () {
render(
,
{context: routerContext}
);
// Trash button should be disabled
expect(screen.getByRole('button', {name: 'delete'})).toBeDisabled();
});
it('displays disabled cancel', function () {
render(
,
{context: routerContext}
);
// Cancel should be disabled
expect(screen.getByRole('button', {name: 'Cancel'})).toBeDisabled();
});
});
describe('deletion', function () {
const organization = TestStubs.Organization({
access: ['org:integrations'],
});
const routerContext = TestStubs.routerContext([{organization}]);
it('sends api request on delete', function () {
const deleteRepo = MockApiClient.addMockResponse({
url: `/organizations/${organization.slug}/repos/${repository.id}/`,
method: 'DELETE',
statusCode: 204,
body: {},
});
render(
,
{context: routerContext}
);
renderGlobalModal();
userEvent.click(screen.getByRole('button', {name: 'delete'}));
// Confirm modal
userEvent.click(screen.getByRole('button', {name: 'Confirm'}));
expect(deleteRepo).toHaveBeenCalled();
});
});
describe('cancel deletion', function () {
const organization = TestStubs.Organization({
access: ['org:integrations'],
});
const routerContext = TestStubs.routerContext([{organization}]);
it('sends api request to cancel', function () {
const cancel = MockApiClient.addMockResponse({
url: `/organizations/${organization.slug}/repos/${pendingRepo.id}/`,
method: 'PUT',
statusCode: 204,
body: {},
});
render(
,
{context: routerContext}
);
userEvent.click(screen.getByRole('button', {name: 'Cancel'}));
expect(cancel).toHaveBeenCalled();
});
});
describe('renders custom_scm repo', function () {
const organization = TestStubs.Organization({
access: ['org:integrations'],
features: ['integrations-custom-scm'],
});
const routerContext = TestStubs.routerContext([{organization}]);
it('displays edit button', function () {
render(
,
{context: routerContext}
);
// Trash button should display enabled
expect(screen.getByRole('button', {name: 'delete'})).toBeEnabled();
// No cancel button
expect(screen.queryByRole('button', {name: 'Cancel'})).not.toBeInTheDocument();
// Edit button should display enabled
expect(screen.getByRole('button', {name: 'edit'})).toBeEnabled();
});
it('disables edit button when cancel pending', function () {
render(
,
{context: routerContext}
);
// Trash button should be disabled
expect(screen.getByRole('button', {name: 'delete'})).toBeDisabled();
// Edit button should be disabled
expect(screen.getByRole('button', {name: 'edit'})).toBeDisabled();
// Cancel button active
expect(screen.queryByRole('button', {name: 'Cancel'})).toBeEnabled();
});
});
});