import {render, screen, userEvent} from 'sentry-test/reactTestingLibrary'; import RadioGroup from 'sentry/components/forms/controls/radioGroup'; describe('RadioGroup', function () { it('renders', function () { const {container} = render( ); expect(container).toSnapshot(); }); it('renders disabled', function () { const {container} = render( ); expect(container).toSnapshot(); expect(screen.getByRole('radio', {name: 'Choice One'})).toBeDisabled(); }); it('renders disabled choice', async function () { const {container} = render( ); expect(container).toSnapshot(); expect(screen.getByRole('radio', {name: 'Choice One'})).toBeEnabled(); expect(screen.getByRole('radio', {name: 'Choice Two'})).toBeDisabled(); userEvent.hover(screen.getByRole('radio', {name: 'Choice Two'})); expect( await screen.findByText('Reason why choice two is disabled') ).toBeInTheDocument(); }); it('can select a different item', function () { const {container} = render( ); expect(container).toSnapshot(); }); it('calls onChange when clicked', function () { const mock = jest.fn(); render( ); userEvent.click(screen.getByRole('radio', {name: 'Choice Three'})); expect(mock).toHaveBeenCalledTimes(1); }); });