From b3dc4d34f64a4e577b17d14e68a03f12a87099e2 Mon Sep 17 00:00:00 2001 From: daniele-mng Date: Fri, 29 Nov 2024 15:34:42 +0100 Subject: [PATCH] add: test --- .../dialog/__tests__/SaveDialogFooter.jsx | 59 +++++++++++++++++++ 1 file changed, 59 insertions(+) create mode 100644 src/web/components/dialog/__tests__/SaveDialogFooter.jsx diff --git a/src/web/components/dialog/__tests__/SaveDialogFooter.jsx b/src/web/components/dialog/__tests__/SaveDialogFooter.jsx new file mode 100644 index 0000000000..c73862983a --- /dev/null +++ b/src/web/components/dialog/__tests__/SaveDialogFooter.jsx @@ -0,0 +1,59 @@ +/* SPDX-FileCopyrightText: 2024 Greenbone AG + * + * SPDX-License-Identifier: AGPL-3.0-or-later + */ + +import {describe, test, expect, testing} from '@gsa/testing'; + +import {render, fireEvent, screen} from 'web/utils/testing'; +import SaveDialogFooter from '../SaveDialogFooter'; + +describe('SaveDialogFooter', () => { + const defaultProps = { + multiStep: 0, + isLoading: false, + prevDisabled: false, + nextDisabled: false, + buttonTitle: 'Save', + currentStep: 0, + setCurrentStep: testing.fn(), + onClose: testing.fn(), + handleSaveClick: testing.fn(), + }; + + test('renders DialogFooter when multiStep is 0', () => { + render(); + expect(screen.getByText('Save')).toBeInTheDocument(); + }); + + test('renders MultiStepFooter when multiStep is greater than 0', () => { + render(); + expect(screen.getByText('Save')).toBeInTheDocument(); + }); + + test('calls setCurrentStep with incremented value on next button click in MultiStepFooter', () => { + render(); + fireEvent.click(screen.getByTestId('dialog-next-button')); + expect(defaultProps.setCurrentStep).toHaveBeenCalledWith(1); + }); + + test('calls setCurrentStep with decremented value on previous button click in MultiStepFooter', () => { + render( + , + ); + fireEvent.click(screen.getByTestId('dialog-previous-button')); + expect(defaultProps.setCurrentStep).toHaveBeenCalledWith(1); + }); + + test('calls onClose when left button is clicked', () => { + render(); + fireEvent.click(screen.getByText('Cancel')); + expect(defaultProps.onClose).toHaveBeenCalled(); + }); + + test('calls handleSaveClick when right button is clicked', () => { + render(); + fireEvent.click(screen.getByText('Save')); + expect(defaultProps.handleSaveClick).toHaveBeenCalled(); + }); +});