import selectEvent from 'react-select-event'; import { act, render, renderGlobalModal, screen, userEvent, } from 'sentry-test/reactTestingLibrary'; import ResolveActions from 'sentry/components/actions/resolve'; import ModalStore from 'sentry/stores/modalStore'; describe('ResolveActions', function () { const spy = jest.fn(); beforeEach(() => { ModalStore.reset(); }); afterEach(() => { spy.mockClear(); MockApiClient.clearMockResponses(); ModalStore.teardown(); }); describe('disabled', function () { it('does not call onUpdate when clicked', function () { render( ); const button = screen.getByRole('button', {name: 'Resolve'}); expect(button).toBeDisabled(); userEvent.click(button); expect(spy).not.toHaveBeenCalled(); }); }); describe('disableDropdown', function () { it('main button calls onUpdate when clicked and dropdown menu disabled', function () { render( ); const button = screen.getByRole('button', {name: 'Resolve'}); expect(button).toBeEnabled(); userEvent.click(button); expect(spy).toHaveBeenCalled(); // Dropdown menu is disabled expect(screen.getByRole('button', {name: 'More resolve options'})).toBeDisabled(); }); }); describe('resolved', function () { it('calls onUpdate with unresolved status when clicked', function () { render( ); const button = screen.getByRole('button', {name: 'Unresolve'}); expect(button).toBeInTheDocument(); expect(button).toHaveTextContent(''); userEvent.click(button); expect(spy).toHaveBeenCalledWith({status: 'unresolved', statusDetails: {}}); }); }); describe('auto resolved', function () { it('cannot be unresolved manually', function () { render( ); userEvent.click(screen.getByRole('button', {name: 'Unresolve'})); expect(spy).not.toHaveBeenCalled(); }); }); describe('without confirmation', function () { it('calls spy with resolved status when clicked', function () { render( ); userEvent.click(screen.getByRole('button', {name: 'Resolve'})); expect(spy).toHaveBeenCalledTimes(1); expect(spy).toHaveBeenCalledWith({status: 'resolved', statusDetails: {}}); }); }); describe('with confirmation step', function () { it('displays confirmation modal with message provided', function () { render( ); renderGlobalModal(); const button = screen.getByRole('button', {name: 'Resolve'}); userEvent.click(button); const confirmButton = screen.getByTestId('confirm-button'); expect(confirmButton).toBeInTheDocument(); expect(spy).not.toHaveBeenCalled(); userEvent.click(confirmButton); expect(spy).toHaveBeenCalled(); }); }); it('can resolve in "another version"', async function () { const onUpdate = jest.fn(); MockApiClient.addMockResponse({ url: '/projects/org-slug/project-slug/releases/', body: [TestStubs.Release()], }); render( ); renderGlobalModal(); userEvent.click(screen.getByLabelText('More resolve options')); act(() => userEvent.click(screen.getByText('Another existing releaseā€¦'))); selectEvent.openMenu(screen.getByText('e.g. 1.0.4')); expect(await screen.findByText('1.2.0')).toBeInTheDocument(); userEvent.click(screen.getByText('1.2.0')); userEvent.click(screen.getByRole('button', {name: 'Save Changes'})); expect(onUpdate).toHaveBeenCalledWith({ status: 'resolved', statusDetails: { inRelease: 'sentry-android-shop@1.2.0', }, }); }); });