From 8be7708ac8095d3243a88b5d35f45c9d603053d9 Mon Sep 17 00:00:00 2001 From: koji Date: Wed, 1 May 2024 10:31:20 -0400 Subject: [PATCH] fix(app): fix restore default values button behavior (#15017) * fix(app): fix restore default values button behavior --- app/src/organisms/ChildNavigation/index.tsx | 5 ++++- .../__tests__/ProtocolSetupParameters.test.tsx | 13 +++++++++++++ app/src/organisms/ProtocolSetupParameters/index.tsx | 1 + 3 files changed, 18 insertions(+), 1 deletion(-) diff --git a/app/src/organisms/ChildNavigation/index.tsx b/app/src/organisms/ChildNavigation/index.tsx index e076f7191af..d45e79280f8 100644 --- a/app/src/organisms/ChildNavigation/index.tsx +++ b/app/src/organisms/ChildNavigation/index.tsx @@ -83,7 +83,10 @@ export function ChildNavigation({ {onClickButton != null && buttonText != null ? ( {secondaryButtonProps != null ? ( - + ) : null} { .calledWith(expect.anything()) .thenReturn({ createRun: mockCreateRun } as any) }) + it('renders the parameters labels and mock data', () => { render(props) screen.getByText('Parameters') @@ -63,27 +64,39 @@ describe('ProtocolSetupParameters', () => { screen.getByText('Dry Run') screen.getByText('a dry run description') }) + it('renders the ChooseEnum component when a str param is selected', () => { render(props) fireEvent.click(screen.getByText('Default Module Offsets')) screen.getByText('mock ChooseEnum') }) + it('renders the other setting when boolean param is selected', () => { render(props) expect(screen.getAllByText('On')).toHaveLength(2) fireEvent.click(screen.getByText('Dry Run')) expect(screen.getAllByText('On')).toHaveLength(3) }) + it('renders the back icon and calls useHistory', () => { render(props) fireEvent.click(screen.getAllByRole('button')[0]) expect(mockGoBack).toHaveBeenCalled() }) + it('renders the confirm values button and clicking on it creates a run', () => { render(props) fireEvent.click(screen.getByRole('button', { name: 'Confirm values' })) expect(mockCreateRun).toHaveBeenCalled() }) + + it('should restore default values button is disabled when tapping confirm values button', async () => { + render(props) + const resetButton = screen.getByTestId('ChildNavigation_Secondary_Button') + fireEvent.click(screen.getByText('Confirm values')) + expect(resetButton).toBeDisabled() + }) + it('renders the reset values modal', () => { render(props) fireEvent.click( diff --git a/app/src/organisms/ProtocolSetupParameters/index.tsx b/app/src/organisms/ProtocolSetupParameters/index.tsx index 5dae07260f6..7326a506895 100644 --- a/app/src/organisms/ProtocolSetupParameters/index.tsx +++ b/app/src/organisms/ProtocolSetupParameters/index.tsx @@ -151,6 +151,7 @@ export function ProtocolSetupParameters({ secondaryButtonProps={{ buttonType: 'tertiaryLowLight', buttonText: t('restore_defaults'), + disabled: isLoading || startSetup, onClick: () => showResetValuesModal(true), }} />