diff --git a/app/src/organisms/PipetteWizardFlows/__tests__/AttachProbe.test.tsx b/app/src/organisms/PipetteWizardFlows/__tests__/AttachProbe.test.tsx index e664558d75b..cfada91df6d 100644 --- a/app/src/organisms/PipetteWizardFlows/__tests__/AttachProbe.test.tsx +++ b/app/src/organisms/PipetteWizardFlows/__tests__/AttachProbe.test.tsx @@ -1,8 +1,14 @@ import * as React from 'react' import { fireEvent, screen, waitFor } from '@testing-library/react' -import { nestedTextMatcher, renderWithProviders } from '@opentrons/components' +import { describe, it, beforeEach, vi, expect } from 'vitest' + import { useDeckConfigurationQuery } from '@opentrons/react-api-client' import { LEFT, SINGLE_MOUNT_PIPETTES } from '@opentrons/shared-data' + +import { + nestedTextMatcher, + renderWithProviders, +} from '../../../__testing-utils__' import { i18n } from '../../../i18n' import { mock8ChannelAttachedPipetteInformation, @@ -18,20 +24,16 @@ const render = (props: React.ComponentProps) => { i18nInstance: i18n, })[0] } -jest.mock('@opentrons/react-api-client') - -const mockUseDeckConfigurationQuery = useDeckConfigurationQuery as jest.MockedFunction< - typeof useDeckConfigurationQuery -> +vi.mock('@opentrons/react-api-client') describe('AttachProbe', () => { let props: React.ComponentProps beforeEach(() => { props = { mount: LEFT, - goBack: jest.fn(), - proceed: jest.fn(), - chainRunCommands: jest + goBack: vi.fn(), + proceed: vi.fn(), + chainRunCommands: vi .fn() .mockImplementationOnce(() => Promise.resolve()) .mockImplementationOnce(() => Promise.resolve()), @@ -39,13 +41,13 @@ describe('AttachProbe', () => { attachedPipettes: { left: mockAttachedPipetteInformation, right: null }, flowType: FLOWS.CALIBRATE, errorMessage: null, - setShowErrorMessage: jest.fn(), + setShowErrorMessage: vi.fn(), isRobotMoving: false, isExiting: false, selectedPipette: SINGLE_MOUNT_PIPETTES, isOnDevice: false, } - mockUseDeckConfigurationQuery.mockReturnValue({ + vi.mocked(useDeckConfigurationQuery).mockReturnValue({ data: [ { cutoutId: 'cutoutD3', diff --git a/app/src/organisms/PipetteWizardFlows/__tests__/BeforeBeginning.test.tsx b/app/src/organisms/PipetteWizardFlows/__tests__/BeforeBeginning.test.tsx index d6d75f881fd..2150bb8fb78 100644 --- a/app/src/organisms/PipetteWizardFlows/__tests__/BeforeBeginning.test.tsx +++ b/app/src/organisms/PipetteWizardFlows/__tests__/BeforeBeginning.test.tsx @@ -1,12 +1,15 @@ import * as React from 'react' -import { fireEvent, waitFor } from '@testing-library/react' -import { renderWithProviders } from '@opentrons/components' +import { fireEvent, waitFor, screen } from '@testing-library/react' +import { describe, it, vi, beforeEach, expect, afterEach } from 'vitest' + import { LEFT, NINETY_SIX_CHANNEL, RIGHT, SINGLE_MOUNT_PIPETTES, } from '@opentrons/shared-data' + +import { renderWithProviders } from '../../../__testing-utils__' import { i18n } from '../../../i18n' import { mockAttachedPipetteInformation } from '../../../redux/pipettes/__fixtures__' import { InProgressModal } from '../../../molecules/InProgressModal/InProgressModal' @@ -19,15 +22,9 @@ import { getIsGantryEmpty } from '../utils' // TODO(jr, 11/3/22): uncomment out the get help link when we have // the correct URL to link it to // jest.mock('../../CalibrationPanels') -jest.mock('../../../molecules/InProgressModal/InProgressModal') -jest.mock('../utils') +vi.mock('../../../molecules/InProgressModal/InProgressModal') +vi.mock('../utils') -const mockGetIsGantryEmpty = getIsGantryEmpty as jest.MockedFunction< - typeof getIsGantryEmpty -> -const mockInProgressModal = InProgressModal as jest.MockedFunction< - typeof InProgressModal -> // const mockNeedHelpLink = NeedHelpLink as jest.MockedFunction< // typeof NeedHelpLink // > @@ -44,17 +41,15 @@ describe('BeforeBeginning', () => { props = { selectedPipette: SINGLE_MOUNT_PIPETTES, mount: LEFT, - goBack: jest.fn(), - proceed: jest.fn(), - chainRunCommands: jest - .fn() - .mockImplementationOnce(() => Promise.resolve()), + goBack: vi.fn(), + proceed: vi.fn(), + chainRunCommands: vi.fn().mockImplementationOnce(() => Promise.resolve()), maintenanceRunId: RUN_ID_1, attachedPipettes: { left: mockAttachedPipetteInformation, right: null }, flowType: FLOWS.CALIBRATE, - createMaintenanceRun: jest.fn(), + createMaintenanceRun: vi.fn(), errorMessage: null, - setShowErrorMessage: jest.fn(), + setShowErrorMessage: vi.fn(), isCreateLoading: false, isRobotMoving: false, isOnDevice: false, @@ -62,26 +57,28 @@ describe('BeforeBeginning', () => { createdMaintenanceRunId: null, } // mockNeedHelpLink.mockReturnValue(
mock need help link
) - mockInProgressModal.mockReturnValue(
mock in progress
) - mockGetIsGantryEmpty.mockReturnValue(false) + vi.mocked(InProgressModal).mockReturnValue(
mock in progress
) + vi.mocked(getIsGantryEmpty).mockReturnValue(false) }) afterEach(() => { - jest.resetAllMocks() + vi.resetAllMocks() }) describe('calibrate flow single mount', () => { it('returns the correct information for calibrate flow', async () => { - const { getByText, getByAltText, getByRole } = render(props) - getByText('Before you begin') - getByText( + render(props) + screen.getByText('Before you begin') + screen.getByText( 'To get started, remove labware from the deck and clean up the working area to make calibration easier. Also gather the needed equipment shown to the right.' ) - getByText( + screen.getByText( 'The calibration probe is included with the robot and should be stored on the front pillar of the robot.' ) - getByText('You will need:') + screen.getByText('You will need:') // getByText('mock need help link') - getByAltText('Calibration Probe') - const proceedBtn = getByRole('button', { name: 'Move gantry to front' }) + screen.getByAltText('Calibration Probe') + const proceedBtn = screen.getByRole('button', { + name: 'Move gantry to front', + }) fireEvent.click(proceedBtn) expect(props.chainRunCommands).toHaveBeenCalledWith( [ @@ -105,13 +102,14 @@ describe('BeforeBeginning', () => { expect(props.proceed).toHaveBeenCalled() }) }) + it('returns the correct information for in progress modal when robot is moving', () => { props = { ...props, isRobotMoving: true, } - const { getByText } = render(props) - getByText('mock in progress') + render(props) + screen.getByText('mock in progress') }) it('continue button is disabled when isCreateLoading is true', () => { @@ -119,8 +117,10 @@ describe('BeforeBeginning', () => { ...props, isCreateLoading: true, } - const { getByRole } = render(props) - const proceedBtn = getByRole('button', { name: 'Move gantry to front' }) + render(props) + const proceedBtn = screen.getByRole('button', { + name: 'Move gantry to front', + }) expect(proceedBtn).toBeDisabled() }) @@ -129,11 +129,12 @@ describe('BeforeBeginning', () => { ...props, errorMessage: 'error shmerror', } - const { getByText } = render(props) - getByText('Error encountered') - getByText('error shmerror') + render(props) + screen.getByText('Error encountered') + screen.getByText('error shmerror') }) }) + describe('attach flow single mount', () => { it('renders the modal with all correct text. clicking on proceed button sends commands', async () => { props = { @@ -141,22 +142,24 @@ describe('BeforeBeginning', () => { attachedPipettes: { left: null, right: null }, flowType: FLOWS.ATTACH, } - const { getByText, getByAltText, getByRole } = render(props) - getByText('Before you begin') - getByText( + render(props) + screen.getByText('Before you begin') + screen.getByText( 'To get started, remove labware from the deck and clean up the working area to make attachment and calibration easier. Also gather the needed equipment shown to the right.' ) - getByText( + screen.getByText( 'The calibration probe is included with the robot and should be stored on the front pillar of the robot.' ) - getByAltText('1- or 8-Channel Pipette') - getByText('You will need:') - getByAltText('Calibration Probe') - getByAltText('2.5 mm Hex Screwdriver') - getByText( + screen.getByAltText('1- or 8-Channel Pipette') + screen.getByText('You will need:') + screen.getByAltText('Calibration Probe') + screen.getByAltText('2.5 mm Hex Screwdriver') + screen.getByText( 'Provided with the robot. Using another size can strip the instruments’s screws.' ) - const proceedBtn = getByRole('button', { name: 'Move gantry to front' }) + const proceedBtn = screen.getByRole('button', { + name: 'Move gantry to front', + }) fireEvent.click(proceedBtn) expect(props.chainRunCommands).toHaveBeenCalledWith( [ @@ -172,6 +175,7 @@ describe('BeforeBeginning', () => { expect(props.proceed).toHaveBeenCalled() }) }) + it('renders the attach flow when swapping pipettes is needed', async () => { props = { ...props, @@ -183,22 +187,24 @@ describe('BeforeBeginning', () => { pipetteName: 'p1000_single_flex', }, } - const { getByText, getByAltText, getByRole } = render(props) - getByText('Before you begin') - getByText( + render(props) + screen.getByText('Before you begin') + screen.getByText( 'To get started, remove labware from the deck and clean up the working area to make attachment and calibration easier. Also gather the needed equipment shown to the right.' ) - getByText( + screen.getByText( 'The calibration probe is included with the robot and should be stored on the front pillar of the robot.' ) - getByAltText('Flex 1-Channel 1000 μL') - getByText('You will need:') - getByAltText('Calibration Probe') - getByAltText('2.5 mm Hex Screwdriver') - getByText( + screen.getByAltText('Flex 1-Channel 1000 μL') + screen.getByText('You will need:') + screen.getByAltText('Calibration Probe') + screen.getByAltText('2.5 mm Hex Screwdriver') + screen.getByText( 'Provided with the robot. Using another size can strip the instruments’s screws.' ) - const proceedBtn = getByRole('button', { name: 'Move gantry to front' }) + const proceedBtn = screen.getByRole('button', { + name: 'Move gantry to front', + }) fireEvent.click(proceedBtn) expect(props.chainRunCommands).toHaveBeenCalledWith( [ @@ -223,6 +229,7 @@ describe('BeforeBeginning', () => { }) }) }) + describe('detach flow single mount', () => { it('renders the modal with all correct text. clicking on proceed button sends commands for detach flow', async () => { props = { @@ -264,34 +271,35 @@ describe('BeforeBeginning', () => { }) }) }) + describe('attach flow 96 channel', () => { it('renders the modal with all the correct text, clicking on proceed button sends commands for attach flow with an empty gantry', async () => { - mockGetIsGantryEmpty.mockReturnValue(true) + vi.mocked(getIsGantryEmpty).mockReturnValue(true) props = { ...props, attachedPipettes: { left: null, right: null }, flowType: FLOWS.ATTACH, selectedPipette: NINETY_SIX_CHANNEL, } - const { getByText, getByAltText, getByRole } = render(props) - getByText('Before you begin') - getByText( + render(props) + screen.getByText('Before you begin') + screen.getByText( 'To get started, remove labware from the deck and clean up the working area to make attachment and calibration easier. Also gather the needed equipment shown to the right.' ) - getByText( + screen.getByText( 'The calibration probe is included with the robot and should be stored on the front pillar of the robot.' ) - getByText( + screen.getByText( 'The 96-Channel Pipette is heavy (~10kg). Ask a labmate for help, if needed.' ) - getByAltText('2.5 mm Hex Screwdriver') - getByAltText('Calibration Probe') - getByAltText('96-Channel Pipette') - getByAltText('96-Channel Mounting Plate') - getByText( + screen.getByAltText('2.5 mm Hex Screwdriver') + screen.getByAltText('Calibration Probe') + screen.getByAltText('96-Channel Pipette') + screen.getByAltText('96-Channel Mounting Plate') + screen.getByText( 'Provided with the robot. Using another size can strip the instruments’s screws.' ) - const proceedBtn = getByRole('button', { + const proceedBtn = screen.getByRole('button', { name: 'Move gantry to front', }) fireEvent.click(proceedBtn) @@ -309,8 +317,9 @@ describe('BeforeBeginning', () => { expect(props.proceed).toHaveBeenCalled() }) }) + it('renders the 96 channel flow when there is a pipette on the gantry on the right mount', async () => { - mockGetIsGantryEmpty.mockReturnValue(false) + vi.mocked(getIsGantryEmpty).mockReturnValue(false) props = { ...props, mount: RIGHT, @@ -318,25 +327,25 @@ describe('BeforeBeginning', () => { flowType: FLOWS.ATTACH, selectedPipette: NINETY_SIX_CHANNEL, } - const { getByText, getByAltText, getByRole } = render(props) - getByText('Before you begin') - getByText( + render(props) + screen.getByText('Before you begin') + screen.getByText( 'To get started, remove labware from the deck and clean up the working area to make attachment and calibration easier. Also gather the needed equipment shown to the right.' ) - getByText( + screen.getByText( 'The calibration probe is included with the robot and should be stored on the front pillar of the robot.' ) - getByText( + screen.getByText( 'The 96-Channel Pipette is heavy (~10kg). Ask a labmate for help, if needed.' ) - getByAltText('2.5 mm Hex Screwdriver') - getByAltText('Calibration Probe') - getByAltText('96-Channel Pipette') - getByAltText('96-Channel Mounting Plate') - getByText( + screen.getByAltText('2.5 mm Hex Screwdriver') + screen.getByAltText('Calibration Probe') + screen.getByAltText('96-Channel Pipette') + screen.getByAltText('96-Channel Mounting Plate') + screen.getByText( 'Provided with the robot. Using another size can strip the instruments’s screws.' ) - const proceedBtn = getByRole('button', { + const proceedBtn = screen.getByRole('button', { name: 'Move gantry to front', }) fireEvent.click(proceedBtn) @@ -362,33 +371,34 @@ describe('BeforeBeginning', () => { expect(props.proceed).toHaveBeenCalled() }) }) + it('renders the 96 channel flow when there is a pipette on the gantry on the left mount', async () => { - mockGetIsGantryEmpty.mockReturnValue(false) + vi.mocked(getIsGantryEmpty).mockReturnValue(false) props = { ...props, attachedPipettes: { left: mockAttachedPipetteInformation, right: null }, flowType: FLOWS.ATTACH, selectedPipette: NINETY_SIX_CHANNEL, } - const { getByText, getByAltText, getByRole } = render(props) - getByText('Before you begin') - getByText( + render(props) + screen.getByText('Before you begin') + screen.getByText( 'To get started, remove labware from the deck and clean up the working area to make attachment and calibration easier. Also gather the needed equipment shown to the right.' ) - getByText( + screen.getByText( 'The calibration probe is included with the robot and should be stored on the front pillar of the robot.' ) - getByText( + screen.getByText( 'The 96-Channel Pipette is heavy (~10kg). Ask a labmate for help, if needed.' ) - getByAltText('2.5 mm Hex Screwdriver') - getByAltText('Calibration Probe') - getByAltText('96-Channel Pipette') - getByAltText('96-Channel Mounting Plate') - getByText( + screen.getByAltText('2.5 mm Hex Screwdriver') + screen.getByAltText('Calibration Probe') + screen.getByAltText('96-Channel Pipette') + screen.getByAltText('96-Channel Mounting Plate') + screen.getByText( 'Provided with the robot. Using another size can strip the instruments’s screws.' ) - const proceedBtn = getByRole('button', { + const proceedBtn = screen.getByRole('button', { name: 'Move gantry to front', }) fireEvent.click(proceedBtn) @@ -414,8 +424,9 @@ describe('BeforeBeginning', () => { expect(props.proceed).toHaveBeenCalled() }) }) + it('renders the detach and attach 96 channel flow when there is a required 96-channel', async () => { - mockGetIsGantryEmpty.mockReturnValue(false) + vi.mocked(getIsGantryEmpty).mockReturnValue(false) props = { ...props, attachedPipettes: { left: mockAttachedPipetteInformation, right: null }, @@ -427,25 +438,25 @@ describe('BeforeBeginning', () => { mount: 'left', }, } - const { getByText, getByAltText, getByRole } = render(props) - getByText('Before you begin') - getByText( + render(props) + screen.getByText('Before you begin') + screen.getByText( 'To get started, remove labware from the deck and clean up the working area to make attachment and calibration easier. Also gather the needed equipment shown to the right.' ) - getByText( + screen.getByText( 'The calibration probe is included with the robot and should be stored on the front pillar of the robot.' ) - getByText( + screen.getByText( 'The 96-Channel Pipette is heavy (~10kg). Ask a labmate for help, if needed.' ) - getByAltText('2.5 mm Hex Screwdriver') - getByAltText('Calibration Probe') - getByAltText('Flex 96-Channel 1000 μL') - getByAltText('96-Channel Mounting Plate') - getByText( + screen.getByAltText('2.5 mm Hex Screwdriver') + screen.getByAltText('Calibration Probe') + screen.getByAltText('Flex 96-Channel 1000 μL') + screen.getByAltText('96-Channel Mounting Plate') + screen.getByText( 'Provided with the robot. Using another size can strip the instruments’s screws.' ) - const proceedBtn = getByRole('button', { + const proceedBtn = screen.getByRole('button', { name: 'Move gantry to front', }) fireEvent.click(proceedBtn) @@ -472,6 +483,7 @@ describe('BeforeBeginning', () => { }) }) }) + describe('detach flow 96 channel', () => { it('renders the banner for 96 channel with correct info for on device display', () => { props = { @@ -481,16 +493,17 @@ describe('BeforeBeginning', () => { selectedPipette: NINETY_SIX_CHANNEL, isOnDevice: true, } - const { getByLabelText, getByText } = render(props) - getByLabelText('icon_warning') - getByText('Before you begin') - getByText( + render(props) + screen.getByLabelText('icon_warning') + screen.getByText('Before you begin') + screen.getByText( 'The 96-Channel Pipette is heavy (~10kg). Ask a labmate for help, if needed.' ) - getByText( + screen.getByText( 'To get started, remove labware from the deck and clean up the working area to make detachment easier. Also gather the needed equipment shown to the right.' ) }) + it('renders the modal with all correct text. clicking on proceed button sends commands for detach flow', async () => { props = { ...props, @@ -498,16 +511,18 @@ describe('BeforeBeginning', () => { flowType: FLOWS.DETACH, selectedPipette: NINETY_SIX_CHANNEL, } - const { getByText, getByAltText, getByRole } = render(props) - getByText('Before you begin') - getByText( + render(props) + screen.getByText('Before you begin') + screen.getByText( 'The 96-Channel Pipette is heavy (~10kg). Ask a labmate for help, if needed.' ) - getByText( + screen.getByText( 'To get started, remove labware from the deck and clean up the working area to make detachment easier. Also gather the needed equipment shown to the right.' ) - getByAltText('2.5 mm Hex Screwdriver') - const proceedBtn = getByRole('button', { name: 'Move gantry to front' }) + screen.getByAltText('2.5 mm Hex Screwdriver') + const proceedBtn = screen.getByRole('button', { + name: 'Move gantry to front', + }) fireEvent.click(proceedBtn) expect(props.chainRunCommands).toHaveBeenCalledWith( [ diff --git a/app/src/organisms/PipetteWizardFlows/__tests__/Carriage.test.tsx b/app/src/organisms/PipetteWizardFlows/__tests__/Carriage.test.tsx index c044154bc4d..c8fe21c3d17 100644 --- a/app/src/organisms/PipetteWizardFlows/__tests__/Carriage.test.tsx +++ b/app/src/organisms/PipetteWizardFlows/__tests__/Carriage.test.tsx @@ -1,7 +1,10 @@ import * as React from 'react' import { fireEvent, screen } from '@testing-library/react' -import { renderWithProviders } from '@opentrons/components' +import { describe, it, beforeEach, vi, expect } from 'vitest' + import { LEFT, NINETY_SIX_CHANNEL } from '@opentrons/shared-data' + +import { renderWithProviders } from '../../../__testing-utils__' import { i18n } from '../../../i18n' import { mockAttachedPipetteInformation } from '../../../redux/pipettes/__fixtures__' import { RUN_ID_1 } from '../../RunTimeControl/__fixtures__' @@ -19,49 +22,50 @@ describe('Carriage', () => { beforeEach(() => { props = { mount: LEFT, - goBack: jest.fn(), - proceed: jest.fn(), - chainRunCommands: jest - .fn() - .mockImplementationOnce(() => Promise.resolve()), + goBack: vi.fn(), + proceed: vi.fn(), + chainRunCommands: vi.fn().mockImplementationOnce(() => Promise.resolve()), maintenanceRunId: RUN_ID_1, attachedPipettes: { left: mockAttachedPipetteInformation, right: null }, flowType: FLOWS.ATTACH, errorMessage: null, - setShowErrorMessage: jest.fn(), + setShowErrorMessage: vi.fn(), isRobotMoving: false, selectedPipette: NINETY_SIX_CHANNEL, isOnDevice: false, } }) + it('returns the correct information, buttons work as expected when flow is attach', () => { - const { getByText, getByTestId, getByRole } = render(props) - getByText('Unscrew z-axis carriage') - getByTestId('Pipette_Zaxis_Attach_96.webm') - getByRole('button', { name: 'Continue' }) + render(props) + screen.getByText('Unscrew z-axis carriage') + screen.getByTestId('Pipette_Zaxis_Attach_96.webm') + screen.getByRole('button', { name: 'Continue' }) expect(screen.queryByLabelText('back')).not.toBeInTheDocument() }) + it('returns the correct information, buttons work as expected when flow is detach', () => { props = { ...props, flowType: FLOWS.DETACH, } - const { getByTestId, getByText, getByRole, getByLabelText } = render(props) - getByText('Reattach z-axis carriage') - getByText( + render(props) + screen.getByText('Reattach z-axis carriage') + screen.getByText( 'Push the right pipette mount up to the top of the z-axis. Then tighten the captive screw at the top right of the gantry carriage.' ) - getByText( + screen.getByText( 'When reattached, the right mount should no longer freely move up and down.' ) - getByTestId('Pipette_Zaxis_Detach_96.webm') - getByRole('button', { name: 'Continue' }) - fireEvent.click(getByLabelText('back')) + screen.getByTestId('Pipette_Zaxis_Detach_96.webm') + screen.getByRole('button', { name: 'Continue' }) + fireEvent.click(screen.getByLabelText('back')) expect(props.goBack).toHaveBeenCalled() }) + it('clicking on continue button executes the commands correctly', () => { - const { getByRole } = render(props) - const contBtn = getByRole('button', { name: 'Continue' }) + render(props) + const contBtn = screen.getByRole('button', { name: 'Continue' }) fireEvent.click(contBtn) expect(props.proceed).toHaveBeenCalled() }) diff --git a/app/src/organisms/PipetteWizardFlows/__tests__/CheckPipetteButton.test.tsx b/app/src/organisms/PipetteWizardFlows/__tests__/CheckPipetteButton.test.tsx index 1ec006c34db..31bc7e6994c 100644 --- a/app/src/organisms/PipetteWizardFlows/__tests__/CheckPipetteButton.test.tsx +++ b/app/src/organisms/PipetteWizardFlows/__tests__/CheckPipetteButton.test.tsx @@ -1,45 +1,44 @@ import * as React from 'react' -import { fireEvent, waitFor } from '@testing-library/react' -import { renderWithProviders } from '@opentrons/components' +import { fireEvent, waitFor, screen } from '@testing-library/react' +import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest' + import { useInstrumentsQuery } from '@opentrons/react-api-client' + +import { renderWithProviders } from '../../../__testing-utils__' import { CheckPipetteButton } from '../CheckPipetteButton' const render = (props: React.ComponentProps) => { return renderWithProviders()[0] } -jest.mock('@opentrons/react-api-client') - -const mockUseInstrumentsQuery = useInstrumentsQuery as jest.MockedFunction< - typeof useInstrumentsQuery -> +vi.mock('@opentrons/react-api-client') describe('CheckPipetteButton', () => { let props: React.ComponentProps - const refetch = jest.fn(() => Promise.resolve()) + const refetch = vi.fn(() => Promise.resolve()) beforeEach(() => { props = { - proceed: jest.fn(), + proceed: vi.fn(), proceedButtonText: 'continue', - setFetching: jest.fn(), + setFetching: vi.fn(), isOnDevice: false, isFetching: false, } - mockUseInstrumentsQuery.mockReturnValue({ + vi.mocked(useInstrumentsQuery).mockReturnValue({ refetch, } as any) }) afterEach(() => { - jest.resetAllMocks() + vi.resetAllMocks() }) it('clicking on the button calls refetch and proceed', async () => { - const { getByRole } = render(props) - fireEvent.click(getByRole('button', { name: 'continue' })) + render(props) + fireEvent.click(screen.getByRole('button', { name: 'continue' })) expect(refetch).toHaveBeenCalled() await waitFor(() => expect(props.proceed).toHaveBeenCalled()) }) it('button is disabled when fetching is true', () => { - const { getByRole } = render({ ...props, isFetching: true }) - expect(getByRole('button', { name: 'continue' })).toBeDisabled() + render({ ...props, isFetching: true }) + expect(screen.getByRole('button', { name: 'continue' })).toBeDisabled() }) }) diff --git a/app/src/organisms/PipetteWizardFlows/__tests__/ChoosePipette.test.tsx b/app/src/organisms/PipetteWizardFlows/__tests__/ChoosePipette.test.tsx index f071e015037..37570d8c5ff 100644 --- a/app/src/organisms/PipetteWizardFlows/__tests__/ChoosePipette.test.tsx +++ b/app/src/organisms/PipetteWizardFlows/__tests__/ChoosePipette.test.tsx @@ -5,7 +5,11 @@ import { SINGLE_MOUNT_PIPETTES, } from '@opentrons/shared-data' import { fireEvent, screen } from '@testing-library/react' -import { COLORS, renderWithProviders } from '@opentrons/components' +import { describe, it, beforeEach, vi, expect, afterEach } from 'vitest' + +import { COLORS } from '@opentrons/components' + +import { renderWithProviders } from '../../../__testing-utils__' import { i18n } from '../../../i18n' import { mockAttachedPipetteInformation } from '../../../redux/pipettes/__fixtures__' import { getIsOnDevice } from '../../../redux/config' @@ -13,19 +17,10 @@ import { useAttachedPipettesFromInstrumentsQuery } from '../../Devices/hooks' import { ChoosePipette } from '../ChoosePipette' import { getIsGantryEmpty } from '../utils' -jest.mock('../utils') -jest.mock('../../Devices/hooks') -jest.mock('../../../redux/config') - -const mockUseAttachedPipettesFromInstrumentsQuery = useAttachedPipettesFromInstrumentsQuery as jest.MockedFunction< - typeof useAttachedPipettesFromInstrumentsQuery -> -const mockGetIsGantryEmpty = getIsGantryEmpty as jest.MockedFunction< - typeof getIsGantryEmpty -> -const mockGetIsOnDevice = getIsOnDevice as jest.MockedFunction< - typeof getIsOnDevice -> +vi.mock('../utils') +vi.mock('../../Devices/hooks') +vi.mock('../../../redux/config') + const render = (props: React.ComponentProps) => { return renderWithProviders(, { i18nInstance: i18n, @@ -35,23 +30,24 @@ const render = (props: React.ComponentProps) => { describe('ChoosePipette', () => { let props: React.ComponentProps beforeEach(() => { - mockGetIsOnDevice.mockReturnValue(false) - mockGetIsGantryEmpty.mockReturnValue(true) - mockUseAttachedPipettesFromInstrumentsQuery.mockReturnValue({ + vi.mocked(getIsOnDevice).mockReturnValue(false) + vi.mocked(getIsGantryEmpty).mockReturnValue(true) + vi.mocked(useAttachedPipettesFromInstrumentsQuery).mockReturnValue({ left: null, right: null, }) props = { - proceed: jest.fn(), - exit: jest.fn(), - setSelectedPipette: jest.fn(), + proceed: vi.fn(), + exit: vi.fn(), + setSelectedPipette: vi.fn(), selectedPipette: SINGLE_MOUNT_PIPETTES, mount: LEFT, } }) afterEach(() => { - jest.resetAllMocks() + vi.resetAllMocks() }) + it('returns the correct information, buttons work as expected', () => { render(props) screen.getByText('Attach Left Pipette') @@ -69,7 +65,7 @@ describe('ChoosePipette', () => { // Single and 8-Channel pipettes are selected first by default expect(singleMountPipettes).toHaveStyle( - `background-color: ${COLORS.blue10}` + `background-color: ${COLORS.blue30}` ) expect(ninetySixPipette).toHaveStyle(`background-color: ${COLORS.white}`) @@ -85,8 +81,9 @@ describe('ChoosePipette', () => { fireEvent.click(proceedBtn) expect(props.proceed).toHaveBeenCalled() }) + it('returns the correct information, buttons work as expected for on device display', () => { - mockGetIsOnDevice.mockReturnValue(true) + vi.mocked(getIsOnDevice).mockReturnValue(true) render(props) screen.getByText('Attach Left Pipette') screen.getByText('Choose a pipette to attach') @@ -105,6 +102,7 @@ describe('ChoosePipette', () => { fireEvent.click(proceedBtn) expect(props.proceed).toHaveBeenCalled() }) + it('renders exit button and clicking on it renders the exit modal, clicking on back button works', () => { render(props) const exit = screen.getByLabelText('Exit') @@ -117,6 +115,7 @@ describe('ChoosePipette', () => { fireEvent.click(goBack) screen.getByText('Choose a pipette to attach') }) + it('renders exit button and clicking on it renders the exit modal, clicking on exit button works', () => { render(props) const exit = screen.getByLabelText('Exit') @@ -129,6 +128,7 @@ describe('ChoosePipette', () => { fireEvent.click(exitButton) expect(props.exit).toHaveBeenCalled() }) + it('renders the 96 channel pipette option selected', () => { props = { ...props, selectedPipette: NINETY_SIX_CHANNEL } render(props) @@ -139,11 +139,11 @@ describe('ChoosePipette', () => { name: '96-Channel pipette 96-Channel pipette', }) expect(singleMountPipettes).toHaveStyle(`background-color: ${COLORS.white}`) - expect(ninetySixPipette).toHaveStyle(`background-color: ${COLORS.blue10}`) + expect(ninetySixPipette).toHaveStyle(`background-color: ${COLORS.blue30}`) }) it('renders the correct text for the 96 channel button when there is a left pipette attached', () => { - mockGetIsGantryEmpty.mockReturnValue(false) - mockUseAttachedPipettesFromInstrumentsQuery.mockReturnValue({ + vi.mocked(getIsGantryEmpty).mockReturnValue(false) + vi.mocked(useAttachedPipettesFromInstrumentsQuery).mockReturnValue({ left: mockAttachedPipetteInformation, right: null, }) @@ -153,9 +153,10 @@ describe('ChoosePipette', () => { 'Detach Flex 1-Channel 1000 μL and attach 96-Channel pipette' ) }) + it('renders the correct text for the 96 channel button when there is a right pipette attached', () => { - mockGetIsGantryEmpty.mockReturnValue(false) - mockUseAttachedPipettesFromInstrumentsQuery.mockReturnValue({ + vi.mocked(getIsGantryEmpty).mockReturnValue(false) + vi.mocked(useAttachedPipettesFromInstrumentsQuery).mockReturnValue({ left: null, right: mockAttachedPipetteInformation, }) diff --git a/app/src/organisms/PipetteWizardFlows/__tests__/DetachPipette.test.tsx b/app/src/organisms/PipetteWizardFlows/__tests__/DetachPipette.test.tsx index c122c46df1b..249fc27f6b4 100644 --- a/app/src/organisms/PipetteWizardFlows/__tests__/DetachPipette.test.tsx +++ b/app/src/organisms/PipetteWizardFlows/__tests__/DetachPipette.test.tsx @@ -1,11 +1,14 @@ import * as React from 'react' -import { fireEvent } from '@testing-library/react' -import { renderWithProviders } from '@opentrons/components' +import { fireEvent, screen } from '@testing-library/react' +import { describe, it, beforeEach, vi, expect } from 'vitest' + import { LEFT, NINETY_SIX_CHANNEL, SINGLE_MOUNT_PIPETTES, } from '@opentrons/shared-data' + +import { renderWithProviders } from '../../../__testing-utils__' import { i18n } from '../../../i18n' import { mock96ChannelAttachedPipetteInformation, @@ -16,12 +19,9 @@ import { RUN_ID_1 } from '../../RunTimeControl/__fixtures__' import { FLOWS } from '../constants' import { DetachPipette } from '../DetachPipette' -jest.mock('../CheckPipetteButton') -jest.mock('../../../molecules/InProgressModal/InProgressModal') +vi.mock('../CheckPipetteButton') +vi.mock('../../../molecules/InProgressModal/InProgressModal') -const mockInProgressModal = InProgressModal as jest.MockedFunction< - typeof InProgressModal -> const render = (props: React.ComponentProps) => { return renderWithProviders(, { i18nInstance: i18n, @@ -34,20 +34,20 @@ describe('DetachPipette', () => { props = { selectedPipette: SINGLE_MOUNT_PIPETTES, mount: LEFT, - goBack: jest.fn(), - proceed: jest.fn(), - chainRunCommands: jest.fn(), + goBack: vi.fn(), + proceed: vi.fn(), + chainRunCommands: vi.fn(), maintenanceRunId: RUN_ID_1, attachedPipettes: { left: mockAttachedPipetteInformation, right: null }, flowType: FLOWS.DETACH, errorMessage: null, - setShowErrorMessage: jest.fn(), + setShowErrorMessage: vi.fn(), isRobotMoving: false, isFetching: false, - setFetching: jest.fn(), + setFetching: vi.fn(), isOnDevice: false, } - mockInProgressModal.mockReturnValue(
mock in progress
) + vi.mocked(InProgressModal).mockReturnValue(
mock in progress
) }) it('returns the correct information, buttons work as expected for single mount pipettes', () => { const { getByText, getByTestId, getByLabelText } = render(props) @@ -66,8 +66,8 @@ describe('DetachPipette', () => { ...props, isRobotMoving: true, } - const { getByText } = render(props) - getByText('mock in progress') + render(props) + screen.getByText('mock in progress') }) it('returns the correct information, buttons work as expected for 96 channel pipettes', () => { props = { @@ -79,14 +79,14 @@ describe('DetachPipette', () => { right: null, }, } - const { getByText, getByTestId, getByLabelText } = render(props) - getByText('Loosen screws and detach Flex 96-Channel 1000 μL') - getByText( + render(props) + screen.getByText('Loosen screws and detach Flex 96-Channel 1000 μL') + screen.getByText( 'Hold the pipette in place and loosen the pipette screws. (The screws are captive and will not come apart from the pipette.) Then carefully remove the pipette.' ) - getByTestId('Pipette_Detach_96.webm') - getByText('Continue') - const backBtn = getByLabelText('back') + screen.getByTestId('Pipette_Detach_96.webm') + screen.getByText('Continue') + const backBtn = screen.getByLabelText('back') fireEvent.click(backBtn) expect(props.goBack).toHaveBeenCalled() }) @@ -96,9 +96,9 @@ describe('DetachPipette', () => { selectedPipette: NINETY_SIX_CHANNEL, isFetching: true, } - const { getAllByTestId, getByLabelText } = render(props) - getAllByTestId('Skeleton') - const backBtn = getByLabelText('back') + render(props) + screen.getAllByTestId('Skeleton') + const backBtn = screen.getByLabelText('back') expect(backBtn).toBeDisabled() }) it('returns the correct information, buttons work as expected for 96 channel pipette flow when single mount is attached', () => { @@ -107,14 +107,14 @@ describe('DetachPipette', () => { flowType: FLOWS.ATTACH, selectedPipette: NINETY_SIX_CHANNEL, } - const { getByText, getByTestId, getByLabelText } = render(props) - getByText('Loosen screws and detach Flex 1-Channel 1000 μL') - getByText( + render(props) + screen.getByText('Loosen screws and detach Flex 1-Channel 1000 μL') + screen.getByText( 'Hold the pipette in place and loosen the pipette screws. (The screws are captive and will not come apart from the pipette.) Then carefully remove the pipette.' ) - getByTestId('Pipette_Detach_1_L.webm') - getByText('Continue') - fireEvent.click(getByLabelText('back')) + screen.getByTestId('Pipette_Detach_1_L.webm') + screen.getByText('Continue') + fireEvent.click(screen.getByLabelText('back')) expect(props.goBack).toHaveBeenCalled() }) }) diff --git a/app/src/organisms/PipetteWizardFlows/__tests__/DetachProbe.test.tsx b/app/src/organisms/PipetteWizardFlows/__tests__/DetachProbe.test.tsx index 596d3d9c234..467f71d6a78 100644 --- a/app/src/organisms/PipetteWizardFlows/__tests__/DetachProbe.test.tsx +++ b/app/src/organisms/PipetteWizardFlows/__tests__/DetachProbe.test.tsx @@ -1,7 +1,10 @@ import * as React from 'react' import { fireEvent, screen } from '@testing-library/react' -import { renderWithProviders } from '@opentrons/components' +import { describe, it, beforeEach, vi } from 'vitest' + import { LEFT, SINGLE_MOUNT_PIPETTES } from '@opentrons/shared-data' + +import { renderWithProviders } from '../../../__testing-utils__' import { i18n } from '../../../i18n' import { mockAttachedPipetteInformation } from '../../../redux/pipettes/__fixtures__' import { InProgressModal } from '../../../molecules/InProgressModal/InProgressModal' @@ -9,7 +12,7 @@ import { RUN_ID_1 } from '../../RunTimeControl/__fixtures__' import { FLOWS } from '../constants' import { DetachProbe } from '../DetachProbe' -jest.mock('../../../molecules/InProgressModal/InProgressModal') +vi.mock('../../../molecules/InProgressModal/InProgressModal') const mockInProgressModal = InProgressModal as jest.MockedFunction< typeof InProgressModal @@ -26,14 +29,14 @@ describe('DetachProbe', () => { props = { selectedPipette: SINGLE_MOUNT_PIPETTES, mount: LEFT, - goBack: jest.fn(), - proceed: jest.fn(), - chainRunCommands: jest.fn(), + goBack: vi.fn(), + proceed: vi.fn(), + chainRunCommands: vi.fn(), maintenanceRunId: RUN_ID_1, attachedPipettes: { left: mockAttachedPipetteInformation, right: null }, flowType: FLOWS.CALIBRATE, errorMessage: null, - setShowErrorMessage: jest.fn(), + setShowErrorMessage: vi.fn(), isRobotMoving: false, isOnDevice: false, } diff --git a/app/src/organisms/PipetteWizardFlows/__tests__/ExitModal.test.tsx b/app/src/organisms/PipetteWizardFlows/__tests__/ExitModal.test.tsx index 8220ef6da05..443535e4bcc 100644 --- a/app/src/organisms/PipetteWizardFlows/__tests__/ExitModal.test.tsx +++ b/app/src/organisms/PipetteWizardFlows/__tests__/ExitModal.test.tsx @@ -1,6 +1,8 @@ import * as React from 'react' import { fireEvent, screen } from '@testing-library/react' -import { renderWithProviders } from '@opentrons/components' +import { describe, it, beforeEach, vi, expect } from 'vitest' + +import { renderWithProviders } from '../../../__testing-utils__' import { i18n } from '../../../i18n' import { FLOWS } from '../constants' import { ExitModal } from '../ExitModal' @@ -16,8 +18,8 @@ describe('ExitModal', () => { beforeEach(() => { props = { - goBack: jest.fn(), - proceed: jest.fn(), + goBack: vi.fn(), + proceed: vi.fn(), flowType: FLOWS.CALIBRATE, isOnDevice: false, } diff --git a/app/src/organisms/PipetteWizardFlows/__tests__/MountPipette.test.tsx b/app/src/organisms/PipetteWizardFlows/__tests__/MountPipette.test.tsx index a9f58f1faac..9e6420cc146 100644 --- a/app/src/organisms/PipetteWizardFlows/__tests__/MountPipette.test.tsx +++ b/app/src/organisms/PipetteWizardFlows/__tests__/MountPipette.test.tsx @@ -1,11 +1,14 @@ import * as React from 'react' -import { fireEvent } from '@testing-library/react' -import { renderWithProviders } from '@opentrons/components' +import { fireEvent, screen } from '@testing-library/react' +import { describe, it, expect, beforeEach, vi } from 'vitest' + import { LEFT, NINETY_SIX_CHANNEL, SINGLE_MOUNT_PIPETTES, } from '@opentrons/shared-data' + +import { renderWithProviders } from '../../../__testing-utils__' import { i18n } from '../../../i18n' import { mockAttachedPipetteInformation } from '../../../redux/pipettes/__fixtures__' import { RUN_ID_1 } from '../../RunTimeControl/__fixtures__' @@ -13,7 +16,7 @@ import { FLOWS } from '../constants' import { CheckPipetteButton } from '../CheckPipetteButton' import { MountPipette } from '../MountPipette' -jest.mock('../CheckPipetteButton') +vi.mock('../CheckPipetteButton') const mockCheckPipetteButton = CheckPipetteButton as jest.MockedFunction< typeof CheckPipetteButton @@ -31,32 +34,32 @@ describe('MountPipette', () => { props = { selectedPipette: SINGLE_MOUNT_PIPETTES, mount: LEFT, - goBack: jest.fn(), - proceed: jest.fn(), - chainRunCommands: jest.fn(), + goBack: vi.fn(), + proceed: vi.fn(), + chainRunCommands: vi.fn(), maintenanceRunId: RUN_ID_1, attachedPipettes: { left: mockAttachedPipetteInformation, right: null }, flowType: FLOWS.ATTACH, errorMessage: null, - setShowErrorMessage: jest.fn(), + setShowErrorMessage: vi.fn(), isRobotMoving: false, isFetching: false, - setFetching: jest.fn(), + setFetching: vi.fn(), isOnDevice: false, } mockCheckPipetteButton.mockReturnValue(
mock check pipette button
) }) it('returns the correct information, buttons work as expected for single mount pipettes', () => { - const { getByText, getByTestId, getByLabelText } = render(props) - getByText('Connect and secure pipette') - getByText( + render(props) + screen.getByText('Connect and secure pipette') + screen.getByText( 'Attach the pipette to the robot by aligning the connector and pressing to ensure a secure connection. Hold the pipette in place and use the hex screwdriver to tighten the pipette screws. Then test that the pipette is securely attached by gently pulling it side to side.' ) - getByTestId('Pipette_Attach_1_8_L.webm') - const backBtn = getByLabelText('back') + screen.getByTestId('Pipette_Attach_1_8_L.webm') + const backBtn = screen.getByLabelText('back') fireEvent.click(backBtn) expect(props.goBack).toHaveBeenCalled() - getByText('mock check pipette button') + screen.getByText('mock check pipette button') }) it('returns the correct information, buttons work as expected for 96 channel pipettes', () => { @@ -64,28 +67,28 @@ describe('MountPipette', () => { ...props, selectedPipette: NINETY_SIX_CHANNEL, } - const { getByText, getByTestId, getByLabelText } = render(props) - getByText('Connect and attach 96-channel pipette') - getByText( + render(props) + screen.getByText('Connect and attach 96-channel pipette') + screen.getByText( 'The 96-Channel Pipette is heavy (~10kg). Ask a labmate for help, if needed.' ) - getByText( + screen.getByText( 'Hold onto the pipette so it does not fall. Connect the pipette by aligning the two protruding rods on the mounting plate. Ensure a secure attachment by screwing in the four front screws with the provided screwdriver.' ) - getByTestId('Pipette_Attach_96.webm') - const backBtn = getByLabelText('back') + screen.getByTestId('Pipette_Attach_96.webm') + const backBtn = screen.getByLabelText('back') fireEvent.click(backBtn) expect(props.goBack).toHaveBeenCalled() - getByText('mock check pipette button') + screen.getByText('mock check pipette button') }) it('returns skeletons and disabled buttons when isFetching is true', () => { props = { ...props, isFetching: true, } - const { getAllByTestId, getByLabelText } = render(props) - getAllByTestId('Skeleton') - const backBtn = getByLabelText('back') + render(props) + screen.getAllByTestId('Skeleton') + const backBtn = screen.getByLabelText('back') expect(backBtn).toBeDisabled() }) }) diff --git a/app/src/organisms/PipetteWizardFlows/__tests__/MountingPlate.test.tsx b/app/src/organisms/PipetteWizardFlows/__tests__/MountingPlate.test.tsx index 85a610a46c8..253f0295ade 100644 --- a/app/src/organisms/PipetteWizardFlows/__tests__/MountingPlate.test.tsx +++ b/app/src/organisms/PipetteWizardFlows/__tests__/MountingPlate.test.tsx @@ -1,7 +1,9 @@ import * as React from 'react' -import { fireEvent, waitFor } from '@testing-library/react' -import { renderWithProviders } from '@opentrons/components' +import { fireEvent, waitFor, screen } from '@testing-library/react' +import { describe, it, expect, beforeEach, vi } from 'vitest' + import { LEFT, NINETY_SIX_CHANNEL } from '@opentrons/shared-data' +import { renderWithProviders } from '../../../__testing-utils__' import { i18n } from '../../../i18n' import { mockAttachedPipetteInformation } from '../../../redux/pipettes/__fixtures__' import { RUN_ID_1 } from '../../RunTimeControl/__fixtures__' @@ -19,29 +21,27 @@ describe('MountingPlate', () => { beforeEach(() => { props = { mount: LEFT, - goBack: jest.fn(), - proceed: jest.fn(), - chainRunCommands: jest - .fn() - .mockImplementationOnce(() => Promise.resolve()), + goBack: vi.fn(), + proceed: vi.fn(), + chainRunCommands: vi.fn().mockImplementationOnce(() => Promise.resolve()), maintenanceRunId: RUN_ID_1, attachedPipettes: { left: mockAttachedPipetteInformation, right: null }, flowType: FLOWS.ATTACH, errorMessage: null, - setShowErrorMessage: jest.fn(), + setShowErrorMessage: vi.fn(), isRobotMoving: false, selectedPipette: NINETY_SIX_CHANNEL, isOnDevice: false, } }) it('returns the correct information, buttons work as expected for attach flow', async () => { - const { getByText, getByTestId, getByRole, getByLabelText } = render(props) - getByText('Attach Mounting Plate') - getByText( + render(props) + screen.getByText('Attach Mounting Plate') + screen.getByText( 'Attach the mounting plate by aligning the pins on the plate to the slots on the gantry carriage. You may need to adjust the position of the right pipette mount to achieve proper alignment.' ) - getByTestId('Pipette_Attach_Plate_96.webm') - const proceedBtn = getByRole('button', { name: 'Continue' }) + screen.getByTestId('Pipette_Detach_Plate_96.webm') + const proceedBtn = screen.getByRole('button', { name: 'Continue' }) fireEvent.click(proceedBtn) await waitFor(() => { expect(props.chainRunCommands).toHaveBeenCalledWith( @@ -59,7 +59,7 @@ describe('MountingPlate', () => { ) }) expect(props.proceed).toHaveBeenCalled() - const backBtn = getByLabelText('back') + const backBtn = screen.getByLabelText('back') fireEvent.click(backBtn) expect(props.goBack).toHaveBeenCalled() }) @@ -69,16 +69,16 @@ describe('MountingPlate', () => { ...props, flowType: FLOWS.DETACH, } - const { getByText, getByTestId, getByRole, getByLabelText } = render(props) - getByText('Loosen Screws and Detach Mounting Plate') - getByText( + render(props) + screen.getByText('Loosen Screws and Detach Mounting Plate') + screen.getByText( 'Hold onto the plate so it does not fall. Then remove the pins on the plate from the slots on the gantry carriage.' ) - getByTestId('Pipette_Detach_Plate_96.webm') - const proceedBtn = getByRole('button', { name: 'Continue' }) + screen.getByTestId('Pipette_Detach_Plate_96.webm') + const proceedBtn = screen.getByRole('button', { name: 'Continue' }) fireEvent.click(proceedBtn) expect(props.proceed).toHaveBeenCalled() - const backBtn = getByLabelText('back') + const backBtn = screen.getByLabelText('back') fireEvent.click(backBtn) expect(props.goBack).toHaveBeenCalled() }) diff --git a/app/src/organisms/PipetteWizardFlows/__tests__/Results.test.tsx b/app/src/organisms/PipetteWizardFlows/__tests__/Results.test.tsx index 3edeb0b3487..bf5a1d4d7aa 100644 --- a/app/src/organisms/PipetteWizardFlows/__tests__/Results.test.tsx +++ b/app/src/organisms/PipetteWizardFlows/__tests__/Results.test.tsx @@ -1,23 +1,25 @@ import * as React from 'react' import { act, fireEvent, screen, waitFor } from '@testing-library/react' +import { describe, it, expect, vi, beforeEach } from 'vitest' + import { LEFT, NINETY_SIX_CHANNEL, SINGLE_MOUNT_PIPETTES, } from '@opentrons/shared-data' -import { COLORS, renderWithProviders } from '@opentrons/components' +import { COLORS } from '@opentrons/components' import { useInstrumentsQuery } from '@opentrons/react-api-client' + +import { renderWithProviders } from '../../../__testing-utils__' import { mockAttachedPipetteInformation } from '../../../redux/pipettes/__fixtures__' import { i18n } from '../../../i18n' import { RUN_ID_1 } from '../../RunTimeControl/__fixtures__' import { Results } from '../Results' import { FLOWS } from '../constants' -jest.mock('@opentrons/react-api-client') +import type { Mock } from 'vitest' -const mockUseInstrumentsQuery = useInstrumentsQuery as jest.MockedFunction< - typeof useInstrumentsQuery -> +vi.mock('@opentrons/react-api-client') const render = (props: React.ComponentProps) => { return renderWithProviders(, { @@ -28,33 +30,31 @@ const render = (props: React.ComponentProps) => { describe('Results', () => { let props: React.ComponentProps let pipettePromise: Promise - let mockRefetchInstruments: jest.Mock + let mockRefetchInstruments: Mock beforeEach(() => { props = { selectedPipette: SINGLE_MOUNT_PIPETTES, mount: LEFT, - goBack: jest.fn(), - proceed: jest.fn(), - chainRunCommands: jest - .fn() - .mockImplementationOnce(() => Promise.resolve()), + goBack: vi.fn(), + proceed: vi.fn(), + chainRunCommands: vi.fn().mockImplementationOnce(() => Promise.resolve()), isRobotMoving: false, maintenanceRunId: RUN_ID_1, attachedPipettes: { left: mockAttachedPipetteInformation, right: null }, errorMessage: null, - setShowErrorMessage: jest.fn(), + setShowErrorMessage: vi.fn(), flowType: FLOWS.CALIBRATE, - handleCleanUpAndClose: jest.fn(), + handleCleanUpAndClose: vi.fn(), currentStepIndex: 2, totalStepCount: 6, isOnDevice: false, isFetching: false, - setFetching: jest.fn(), + setFetching: vi.fn(), hasCalData: false, } pipettePromise = Promise.resolve() - mockRefetchInstruments = jest.fn(() => pipettePromise) - mockUseInstrumentsQuery.mockReturnValue({ + mockRefetchInstruments = vi.fn(() => pipettePromise) + vi.mocked(useInstrumentsQuery).mockReturnValue({ refetch: mockRefetchInstruments, } as any) }) @@ -68,7 +68,9 @@ describe('Results', () => { render(props) screen.getByText('Flex 1-Channel 1000 μL successfully recalibrated') const image = screen.getByRole('img', { name: 'Success Icon' }) - expect(image.getAttribute('src')).toEqual('icon_success.png') + expect(image.getAttribute('src')).toEqual( + '/app/src/assets/images/icon_success.png' + ) screen.getByText('Exit') const exit = screen.getByRole('button', { name: 'Results_exit' }) @@ -84,7 +86,9 @@ describe('Results', () => { render(props) screen.getByText('Flex 1-Channel 1000 μL successfully attached') const image = screen.getByRole('img', { name: 'Success Icon' }) - expect(image.getAttribute('src')).toEqual('icon_success.png') + expect(image.getAttribute('src')).toEqual( + '/app/src/assets/images/icon_success.png' + ) screen.getByRole('img', { name: 'Success Icon' }) screen.getByRole('button', { name: 'Results_exit' }) fireEvent.click(screen.getByText('Calibrate pipette')) @@ -112,7 +116,7 @@ describe('Results', () => { it('calls setShowErrorMessage when chainRunCommands fails', async () => { props = { ...props, - chainRunCommands: jest + chainRunCommands: vi .fn() .mockImplementationOnce(() => Promise.reject(new Error('error'))), flowType: FLOWS.ATTACH, @@ -166,7 +170,9 @@ describe('Results', () => { render(props) screen.getByText('Pipette successfully detached') const image = screen.getByRole('img', { name: 'Success Icon' }) - expect(image.getAttribute('src')).toEqual('icon_success.png') + expect(image.getAttribute('src')).toEqual( + '/app/src/assets/images/icon_success.png' + ) screen.getByRole('img', { name: 'Success Icon' }) const exit = screen.getByRole('button', { name: 'Results_exit' }) fireEvent.click(exit) @@ -230,7 +236,9 @@ describe('Results', () => { render(props) screen.getByText('All pipettes successfully detached') const image = screen.getByRole('img', { name: 'Success Icon' }) - expect(image.getAttribute('src')).toEqual('icon_success.png') + expect(image.getAttribute('src')).toEqual( + '/app/src/assets/images/icon_success.png' + ) screen.getByRole('img', { name: 'Success Icon' }) screen.getByText('attach pipette') const exit = screen.getByRole('button', { name: 'Results_exit' }) @@ -245,7 +253,9 @@ describe('Results', () => { render(props) screen.getByText('Flex 1-Channel 1000 μL successfully calibrated') const image = screen.getByRole('img', { name: 'Success Icon' }) - expect(image.getAttribute('src')).toEqual('icon_success.png') + expect(image.getAttribute('src')).toEqual( + '/app/src/assets/images/icon_success.png' + ) screen.getByRole('img', { name: 'Success Icon' }) fireEvent.click(screen.getByRole('button', { name: 'Results_exit' })) expect(props.proceed).toHaveBeenCalled() @@ -260,7 +270,9 @@ describe('Results', () => { render(props) screen.getByText('Flex 1-Channel 1000 μL successfully calibrated') const image = screen.getByRole('img', { name: 'Success Icon' }) - expect(image.getAttribute('src')).toEqual('icon_success.png') + expect(image.getAttribute('src')).toEqual( + '/app/src/assets/images/icon_success.png' + ) screen.getByRole('img', { name: 'Success Icon' }) fireEvent.click(screen.getByRole('button', { name: 'Results_exit' })) expect(props.handleCleanUpAndClose).toHaveBeenCalled() @@ -275,7 +287,9 @@ describe('Results', () => { render(props) screen.getByText('Flex 1-Channel 1000 μL successfully calibrated') const image = screen.getByRole('img', { name: 'Success Icon' }) - expect(image.getAttribute('src')).toEqual('icon_success.png') + expect(image.getAttribute('src')).toEqual( + '/app/src/assets/images/icon_success.png' + ) screen.getByRole('img', { name: 'Success Icon' }) fireEvent.click(screen.getByRole('button', { name: 'Results_exit' })) expect(props.handleCleanUpAndClose).toHaveBeenCalled() @@ -289,7 +303,9 @@ describe('Results', () => { render(props) screen.getByText('Flex 1-Channel 1000 μL successfully recalibrated') const image = screen.getByRole('img', { name: 'Success Icon' }) - expect(image.getAttribute('src')).toEqual('icon_success.png') + expect(image.getAttribute('src')).toEqual( + '/app/src/assets/images/icon_success.png' + ) screen.getByRole('img', { name: 'Success Icon' }) fireEvent.click(screen.getByRole('button')) expect(props.proceed).toHaveBeenCalled() @@ -323,7 +339,9 @@ describe('Results', () => { render(props) screen.getByText('Flex 1-Channel 1000 μL successfully attached') const image = screen.getByRole('img', { name: 'Success Icon' }) - expect(image.getAttribute('src')).toEqual('icon_success.png') + expect(image.getAttribute('src')).toEqual( + '/app/src/assets/images/icon_success.png' + ) screen.getByRole('img', { name: 'Success Icon' }) }) it('renders the correct information when attaching wrong pipette for run setup', async () => { diff --git a/app/src/organisms/PipetteWizardFlows/__tests__/UnskippableModal.test.tsx b/app/src/organisms/PipetteWizardFlows/__tests__/UnskippableModal.test.tsx index d273556d5dd..fd28aa5e8df 100644 --- a/app/src/organisms/PipetteWizardFlows/__tests__/UnskippableModal.test.tsx +++ b/app/src/organisms/PipetteWizardFlows/__tests__/UnskippableModal.test.tsx @@ -1,6 +1,8 @@ import * as React from 'react' import { fireEvent, screen } from '@testing-library/react' -import { renderWithProviders } from '@opentrons/components' +import { describe, it, expect, vi } from 'vitest' + +import { renderWithProviders } from '../../../__testing-utils__' import { i18n } from '../../../i18n' import { UnskippableModal } from '../UnskippableModal' @@ -14,8 +16,8 @@ describe('UnskippableModal', () => { let props: React.ComponentProps it('returns the correct information for unskippable modal, pressing return button calls goBack prop', () => { props = { - goBack: jest.fn(), - proceed: jest.fn(), + goBack: vi.fn(), + proceed: vi.fn(), isOnDevice: false, isRobotMoving: false, } @@ -29,8 +31,8 @@ describe('UnskippableModal', () => { }) it('renders the is on device button with correct text when it is on device display', () => { props = { - goBack: jest.fn(), - proceed: jest.fn(), + goBack: vi.fn(), + proceed: vi.fn(), isOnDevice: true, isRobotMoving: false, } diff --git a/app/src/organisms/PipetteWizardFlows/__tests__/getPipetteWizardSteps.test.tsx b/app/src/organisms/PipetteWizardFlows/__tests__/getPipetteWizardSteps.test.tsx index c7e71cd78d4..4ad1bf92fc2 100644 --- a/app/src/organisms/PipetteWizardFlows/__tests__/getPipetteWizardSteps.test.tsx +++ b/app/src/organisms/PipetteWizardFlows/__tests__/getPipetteWizardSteps.test.tsx @@ -1,3 +1,4 @@ +import { describe, it, expect } from 'vitest' import { LEFT, RIGHT, diff --git a/app/src/organisms/PipetteWizardFlows/__tests__/getPipetteWizardStepsForProtocol.test.tsx b/app/src/organisms/PipetteWizardFlows/__tests__/getPipetteWizardStepsForProtocol.test.tsx index 40b73ffe313..4851a163f83 100644 --- a/app/src/organisms/PipetteWizardFlows/__tests__/getPipetteWizardStepsForProtocol.test.tsx +++ b/app/src/organisms/PipetteWizardFlows/__tests__/getPipetteWizardStepsForProtocol.test.tsx @@ -1,3 +1,4 @@ +import { describe, it, expect } from 'vitest' import { LEFT, RIGHT, LoadedPipette } from '@opentrons/shared-data' import { mock96ChannelAttachedPipetteInformation, diff --git a/app/src/organisms/PipetteWizardFlows/__tests__/hooks.test.tsx b/app/src/organisms/PipetteWizardFlows/__tests__/hooks.test.tsx index 62f6c281aae..9a3a6424ca3 100644 --- a/app/src/organisms/PipetteWizardFlows/__tests__/hooks.test.tsx +++ b/app/src/organisms/PipetteWizardFlows/__tests__/hooks.test.tsx @@ -1,4 +1,5 @@ import * as React from 'react' +import { describe, it, beforeEach, vi, afterEach, expect } from 'vitest' import { I18nextProvider } from 'react-i18next' import { renderHook } from '@testing-library/react' import { @@ -29,7 +30,7 @@ describe('usePipetteFlowWizardHeaderText', () => { ) }) afterEach(() => { - jest.resetAllMocks() + vi.resetAllMocks() }) it('should return correct title for calibrating single mount', () => { const { result } = renderHook( diff --git a/app/src/organisms/PipetteWizardFlows/__tests__/utils.test.ts b/app/src/organisms/PipetteWizardFlows/__tests__/utils.test.ts index e5799600e05..4b5231430a4 100644 --- a/app/src/organisms/PipetteWizardFlows/__tests__/utils.test.ts +++ b/app/src/organisms/PipetteWizardFlows/__tests__/utils.test.ts @@ -1,4 +1,5 @@ import { render, screen } from '@testing-library/react' +import { describe, it, expect } from 'vitest' import { LEFT, RIGHT } from '@opentrons/shared-data' import { mockAttachedPipetteInformation } from '../../../redux/pipettes/__fixtures__' import { @@ -12,11 +13,13 @@ describe('getIsGantryEmpty', () => { it('should return true when no pipettes attached', () => { expect(getIsGantryEmpty({ left: null, right: null })).toEqual(true) }) + it('should return false when 1 pipette is attached', () => { expect( getIsGantryEmpty({ left: mockAttachedPipetteInformation, right: null }) ).toEqual(false) }) + it('should return false when 2 pipettes are attached', () => { expect( getIsGantryEmpty({ @@ -40,8 +43,11 @@ describe('getPipetteAnimations', () => { channel: 1, }) ) - screen.getByTestId('Pipette_Detach_1_L.webm') + screen.getByTestId( + '/app/src/assets/videos/pipette-wizard-flows/Pipette_Detach_1_L.webm' + ) }) + it('should return correct video for detach left 8', () => { const mockPipetteWizardStep = { mount: LEFT, @@ -54,8 +60,11 @@ describe('getPipetteAnimations', () => { channel: 8, }) ) - screen.getByTestId('Pipette_Detach_8_L.webm') + screen.getByTestId( + '/app/src/assets/videos/pipette-wizard-flows/Pipette_Detach_8_L.webm' + ) }) + it('should return correct video for detach right 1', () => { const mockPipetteWizardStep = { mount: RIGHT, @@ -68,8 +77,11 @@ describe('getPipetteAnimations', () => { channel: 1, }) ) - screen.getByTestId('Pipette_Detach_1_R.webm') + screen.getByTestId( + '/app/src/assets/videos/pipette-wizard-flows/Pipette_Detach_1_R.webm' + ) }) + it('should return correct video for detach right 8', () => { const mockPipetteWizardStep = { mount: RIGHT, @@ -82,8 +94,11 @@ describe('getPipetteAnimations', () => { channel: 8, }) ) - screen.getByTestId('Pipette_Detach_8_R.webm') + screen.getByTestId( + '/app/src/assets/videos/pipette-wizard-flows/Pipette_Detach_8_R.webm' + ) }) + it('should return correct video for attach probe 1', () => { const mockPipetteWizardStep = { mount: RIGHT, @@ -96,8 +111,11 @@ describe('getPipetteAnimations', () => { channel: 1, }) ) - screen.getByTestId('Pipette_Attach_Probe_1.webm') + screen.getByTestId( + '/app/src/assets/videos/pipette-wizard-flows/Pipette_Attach_Probe_1.webm' + ) }) + it('should return correct video for attach probe 8', () => { const mockPipetteWizardStep = { mount: RIGHT, @@ -110,8 +128,11 @@ describe('getPipetteAnimations', () => { channel: 8, }) ) - screen.getByTestId('Pipette_Attach_Probe_8.webm') + screen.getByTestId( + '/app/src/assets/videos/pipette-wizard-flows/Pipette_Attach_Probe_8.webm' + ) }) + it('should return correct video for detach probe 1', () => { const mockPipetteWizardStep = { mount: RIGHT, @@ -124,8 +145,11 @@ describe('getPipetteAnimations', () => { channel: 1, }) ) - screen.getByTestId('Pipette_Detach_Probe_1.webm') + screen.getByTestId( + '/app/src/assets/videos/pipette-wizard-flows/Pipette_Detach_Probe_1.webm' + ) }) + it('should return correct video for detach probe 8', () => { const mockPipetteWizardStep = { mount: RIGHT, @@ -138,7 +162,9 @@ describe('getPipetteAnimations', () => { channel: 8, }) ) - screen.getByTestId('Pipette_Detach_Probe_8.webm') + screen.getByTestId( + '/app/src/assets/videos/pipette-wizard-flows/Pipette_Detach_Probe_8.webm' + ) }) it('should return correct video for attach left 1', () => { const mockPipetteWizardStep = { @@ -151,8 +177,11 @@ describe('getPipetteAnimations', () => { pipetteWizardStep: mockPipetteWizardStep, }) ) - screen.getByTestId('Pipette_Attach_1_8_L.webm') + screen.getByTestId( + '/app/src/assets/videos/pipette-wizard-flows/Pipette_Attach_1_8_L.webm' + ) }) + it('should return correct video for attach right 1', () => { const mockPipetteWizardStep = { mount: RIGHT, @@ -164,7 +193,9 @@ describe('getPipetteAnimations', () => { pipetteWizardStep: mockPipetteWizardStep, }) ) - screen.getByTestId('Pipette_Attach_1_8_R.webm') + screen.getByTestId( + '/app/src/assets/videos/pipette-wizard-flows/Pipette_Attach_1_8_R.webm' + ) }) }) @@ -176,8 +207,11 @@ describe('getPipetteAnimations96', () => { flowType: FLOWS.ATTACH, }) ) - screen.getByTestId('Pipette_Attach_96.webm') + screen.getByTestId( + '/app/src/assets/videos/pipette-wizard-flows/Pipette_Attach_96.webm' + ) }) + it('should return correct video for attaching plate attach', () => { render( getPipetteAnimations96({ @@ -185,8 +219,11 @@ describe('getPipetteAnimations96', () => { flowType: FLOWS.ATTACH, }) ) - screen.getByTestId('Pipette_Attach_Plate_96.webm') + screen.getByTestId( + '/app/src/assets/videos/pipette-wizard-flows/Pipette_Attach_Plate_96.webm' + ) }) + it('should return correct video for attaching plate detach', () => { render( getPipetteAnimations96({ @@ -194,8 +231,11 @@ describe('getPipetteAnimations96', () => { flowType: FLOWS.DETACH, }) ) - screen.getByTestId('Pipette_Detach_Plate_96.webm') + screen.getByTestId( + '/app/src/assets/videos/pipette-wizard-flows/Pipette_Detach_Plate_96.webm' + ) }) + it('should return correct video for detach pipette', () => { render( getPipetteAnimations96({ @@ -203,8 +243,11 @@ describe('getPipetteAnimations96', () => { flowType: FLOWS.DETACH, }) ) - screen.getByTestId('Pipette_Detach_96.webm') + screen.getByTestId( + '/app/src/assets/videos/pipette-wizard-flows/Pipette_Detach_96.webm' + ) }) + it('should return correct video for z axis attach', () => { render( getPipetteAnimations96({ @@ -212,8 +255,11 @@ describe('getPipetteAnimations96', () => { flowType: FLOWS.ATTACH, }) ) - screen.getByTestId('Pipette_Zaxis_Attach_96.webm') + screen.getByTestId( + '/app/src/assets/videos/pipette-wizard-flows/Pipette_Zaxis_Attach_96.webm' + ) }) + it('should return correct video for z axis detach', () => { render( getPipetteAnimations96({ @@ -221,6 +267,8 @@ describe('getPipetteAnimations96', () => { flowType: FLOWS.DETACH, }) ) - screen.getByTestId('Pipette_Zaxis_Detach_96.webm') + screen.getByTestId( + '/app/src/assets/videos/pipette-wizard-flows/Pipette_Zaxis_Detach_96.webm' + ) }) }) diff --git a/app/src/organisms/ProtocolAnalysisFailure/__tests__/ProtocolAnalysisFailure.test.tsx b/app/src/organisms/ProtocolAnalysisFailure/__tests__/ProtocolAnalysisFailure.test.tsx index a51b57c7068..77efb2b4543 100644 --- a/app/src/organisms/ProtocolAnalysisFailure/__tests__/ProtocolAnalysisFailure.test.tsx +++ b/app/src/organisms/ProtocolAnalysisFailure/__tests__/ProtocolAnalysisFailure.test.tsx @@ -1,7 +1,9 @@ import * as React from 'react' -import { renderWithProviders } from '@opentrons/components' import { StaticRouter } from 'react-router-dom' -import { fireEvent } from '@testing-library/react' +import { fireEvent, screen } from '@testing-library/react' +import { describe, it, expect } from 'vitest' + +import { renderWithProviders } from '../../../__testing-utils__' import { i18n } from '../../../i18n' import { ProtocolAnalysisFailure } from '..' @@ -28,16 +30,18 @@ const render = ( describe('ProtocolAnalysisFailure', () => { it('renders banner with no modal by default', () => { - const [{ queryByRole }] = render() - expect(queryByRole('button', { name: 'close' })).toBeNull() + render() + expect(screen.queryByRole('button', { name: 'close' })).toBeNull() }) it('renders modal after clicking view details', () => { - const [{ getByRole, queryByRole }] = render() - const viewDetailsButton = getByRole('button', { name: 'error details' }) + render() + const viewDetailsButton = screen.getByRole('button', { + name: 'error details', + }) fireEvent.click(viewDetailsButton) - const closeButton = getByRole('button', { name: 'close' }) + const closeButton = screen.getByRole('button', { name: 'close' }) fireEvent.click(closeButton) - expect(queryByRole('button', { name: 'close' })).toBeNull() + expect(screen.queryByRole('button', { name: 'close' })).toBeNull() }) it('dispatches reanalyze action on click', () => { const [{ getByRole }, store] = render() diff --git a/app/src/organisms/ProtocolDetails/__tests__/ProtocolLabwareDetails.test.tsx b/app/src/organisms/ProtocolDetails/__tests__/ProtocolLabwareDetails.test.tsx index 125c4f9d90a..90d4bd61af2 100644 --- a/app/src/organisms/ProtocolDetails/__tests__/ProtocolLabwareDetails.test.tsx +++ b/app/src/organisms/ProtocolDetails/__tests__/ProtocolLabwareDetails.test.tsx @@ -1,5 +1,7 @@ import * as React from 'react' -import { renderWithProviders } from '@opentrons/components' +import { screen } from '@testing-library/react' +import { describe, it, beforeEach } from 'vitest' +import { renderWithProviders } from '../../../__testing-utils__' import { i18n } from '../../../i18n' import { ProtocolLabwareDetails } from '../ProtocolLabwareDetails' @@ -128,10 +130,10 @@ describe('ProtocolLabwareDetails', () => { completedAt: '2022-04-18T19:16:57.403198+00:00', } as LoadLabwareRunTimeCommand) - const { getByText } = render(props) - getByText('Labware name') - getByText('NEST 96 Well Plate 100 µL PCR Full Skirt') - getByText('Quantity') - getByText('2') + render(props) + screen.getByText('Labware name') + screen.getByText('NEST 96 Well Plate 100 µL PCR Full Skirt') + screen.getByText('Quantity') + screen.getByText('2') }) }) diff --git a/app/src/organisms/ProtocolDetails/__tests__/ProtocolLiquidsDetails.test.tsx b/app/src/organisms/ProtocolDetails/__tests__/ProtocolLiquidsDetails.test.tsx index 48a227b8367..ef6d8a838db 100644 --- a/app/src/organisms/ProtocolDetails/__tests__/ProtocolLiquidsDetails.test.tsx +++ b/app/src/organisms/ProtocolDetails/__tests__/ProtocolLiquidsDetails.test.tsx @@ -1,27 +1,18 @@ import * as React from 'react' -import { renderWithProviders } from '@opentrons/components' +import { screen } from '@testing-library/react' +import { describe, it, beforeEach, vi } from 'vitest' import { parseLiquidsInLoadOrder, parseLabwareInfoByLiquidId, } from '@opentrons/api-client' + +import { renderWithProviders } from '../../../__testing-utils__' import { i18n } from '../../../i18n' import { ProtocolLiquidsDetails } from '../ProtocolLiquidsDetails' import { LiquidsListItemDetails } from '../../Devices/ProtocolRun/SetupLiquids/SetupLiquidsList' -jest.mock('../../Devices/ProtocolRun/SetupLiquids/SetupLiquidsList') -jest.mock('@opentrons/api-client') - -const mockLiquidsListItemDetails = LiquidsListItemDetails as jest.MockedFunction< - typeof LiquidsListItemDetails -> - -const mockParseLiquidsInLoadOrder = parseLiquidsInLoadOrder as jest.MockedFunction< - typeof parseLiquidsInLoadOrder -> - -const mockParseLabwareInfoByLiquidId = parseLabwareInfoByLiquidId as jest.MockedFunction< - typeof parseLabwareInfoByLiquidId -> +vi.mock('../../Devices/ProtocolRun/SetupLiquids/SetupLiquidsList') +vi.mock('@opentrons/api-client') const render = (props: React.ComponentProps) => { return renderWithProviders(, { @@ -42,10 +33,10 @@ describe('ProtocolLiquidsDetails', () => { }, ], } - mockLiquidsListItemDetails.mockReturnValue( + vi.mocked(LiquidsListItemDetails).mockReturnValue(
mock liquids list item
) - mockParseLiquidsInLoadOrder.mockReturnValue([ + vi.mocked(parseLiquidsInLoadOrder).mockReturnValue([ { id: '1', displayName: 'mock liquid', @@ -53,19 +44,19 @@ describe('ProtocolLiquidsDetails', () => { displayColor: '#FFFFFF', }, ]) - mockParseLabwareInfoByLiquidId.mockReturnValue({ + vi.mocked(parseLabwareInfoByLiquidId).mockReturnValue({ '1': [{ labwareId: '123', volumeByWell: { A1: 30 } }], }) }) it('renders the display name, description and total volume', () => { - const [{ getAllByText }] = render(props) - getAllByText('mock liquids list item') + render(props) + screen.getAllByText('mock liquids list item') }) it('renders the correct info for no liquids in the protocol', () => { props.liquids = [] - mockParseLiquidsInLoadOrder.mockReturnValue([]) - const [{ getByText, getByLabelText }] = render(props) - getByText('No liquids are specified for this protocol') - getByLabelText('ProtocolLIquidsDetails_noLiquidsIcon') + vi.mocked(parseLiquidsInLoadOrder).mockReturnValue([]) + render(props) + screen.getByText('No liquids are specified for this protocol') + screen.getByLabelText('ProtocolLIquidsDetails_noLiquidsIcon') }) }) diff --git a/app/src/organisms/ProtocolDetails/__tests__/RobotConfigurationDetails.test.tsx b/app/src/organisms/ProtocolDetails/__tests__/RobotConfigurationDetails.test.tsx index d97cef203c3..1e3955ae89a 100644 --- a/app/src/organisms/ProtocolDetails/__tests__/RobotConfigurationDetails.test.tsx +++ b/app/src/organisms/ProtocolDetails/__tests__/RobotConfigurationDetails.test.tsx @@ -1,6 +1,10 @@ import * as React from 'react' -import { renderWithProviders } from '@opentrons/components' +import { describe, it, expect, afterEach, vi } from 'vitest' +import { screen } from '@testing-library/react' + import { OT2_STANDARD_MODEL, FLEX_STANDARD_MODEL } from '@opentrons/shared-data' + +import { renderWithProviders } from '../../../__testing-utils__' import { i18n } from '../../../i18n' import { RobotConfigurationDetails } from '../RobotConfigurationDetails' import type { LoadModuleRunTimeCommand } from '@opentrons/shared-data' @@ -65,7 +69,7 @@ describe('RobotConfigurationDetails', () => { let props: React.ComponentProps afterEach(() => { - jest.clearAllMocks() + vi.clearAllMocks() }) it('renders a robot section showing the intended robot model for an OT-2 protocol', () => { @@ -78,9 +82,9 @@ describe('RobotConfigurationDetails', () => { isLoading: false, robotType: OT2_STANDARD_MODEL, } - const { getByText } = render(props) - getByText('robot') - getByText('OT-2') + render(props) + screen.getByText('robot') + screen.getByText('OT-2') }) it('renders a robot section showing the intended robot model for a Flex protocol', () => { @@ -93,9 +97,9 @@ describe('RobotConfigurationDetails', () => { isLoading: false, robotType: FLEX_STANDARD_MODEL, } - const { getByText } = render(props) - getByText('robot') - getByText('Opentrons Flex') + render(props) + screen.getByText('robot') + screen.getByText('Opentrons Flex') }) it('renders left mount pipette when there is a pipette only in the left mount', () => { @@ -108,11 +112,11 @@ describe('RobotConfigurationDetails', () => { isLoading: false, robotType: OT2_STANDARD_MODEL, } - const { getByText } = render(props) - getByText('left mount') - getByText('P10 Single-Channel GEN1') - getByText('right mount') - getByText('empty') + render(props) + screen.getByText('left mount') + screen.getByText('P10 Single-Channel GEN1') + screen.getByText('right mount') + screen.getByText('empty') }) it('renders right mount pipette when there is a pipette only in the right mount', () => { @@ -125,11 +129,11 @@ describe('RobotConfigurationDetails', () => { isLoading: false, robotType: OT2_STANDARD_MODEL, } - const { getByText } = render(props) - getByText('left mount') - getByText('P10 Single-Channel GEN1') - getByText('right mount') - getByText('empty') + render(props) + screen.getByText('left mount') + screen.getByText('P10 Single-Channel GEN1') + screen.getByText('right mount') + screen.getByText('empty') }) it('renders extension mount section when extended hardware feature flag is on', () => { @@ -142,8 +146,8 @@ describe('RobotConfigurationDetails', () => { isLoading: false, robotType: FLEX_STANDARD_MODEL, } - const { getByText } = render(props) - getByText('extension mount') + render(props) + screen.getByText('extension mount') }) it('should not render extension mount section when robotType is OT-2', () => { @@ -171,9 +175,9 @@ describe('RobotConfigurationDetails', () => { robotType: OT2_STANDARD_MODEL, } - const { getByText } = render(props) - getByText('1') - getByText('Magnetic Module GEN2') + render(props) + screen.getByText('1') + screen.getByText('Magnetic Module GEN2') }) it('renders loading for both pipettes when it is in a loading state', () => { @@ -186,8 +190,8 @@ describe('RobotConfigurationDetails', () => { isLoading: true, robotType: OT2_STANDARD_MODEL, } - const { getAllByText, getByText } = render(props) - getByText('right mount') - getAllByText('Loading...') + render(props) + screen.getByText('right mount') + screen.getAllByText('Loading...') }) }) diff --git a/app/src/organisms/ProtocolDetails/__tests__/utils.test.ts b/app/src/organisms/ProtocolDetails/__tests__/utils.test.ts index 00548b0b649..7e5d6328062 100644 --- a/app/src/organisms/ProtocolDetails/__tests__/utils.test.ts +++ b/app/src/organisms/ProtocolDetails/__tests__/utils.test.ts @@ -1,3 +1,4 @@ +import { describe, it, expect } from 'vitest' import { TC_MODULE_LOCATION_OT2, TC_MODULE_LOCATION_OT3, diff --git a/app/src/organisms/ProtocolSetupLabware/__tests__/LabwareMapViewModal.test.tsx b/app/src/organisms/ProtocolSetupLabware/__tests__/LabwareMapViewModal.test.tsx index 9678f78c4cc..27eaff0a6eb 100644 --- a/app/src/organisms/ProtocolSetupLabware/__tests__/LabwareMapViewModal.test.tsx +++ b/app/src/organisms/ProtocolSetupLabware/__tests__/LabwareMapViewModal.test.tsx @@ -1,20 +1,20 @@ import * as React from 'react' import { StaticRouter } from 'react-router-dom' -import { when, resetAllWhenMocks } from 'jest-when' -import { fireEvent } from '@testing-library/react' +import { when } from 'vitest-when' +import { fireEvent, screen } from '@testing-library/react' +import { describe, it, vi, beforeEach, afterEach, expect } from 'vitest' -import { - renderWithProviders, - BaseDeck, - EXTENDED_DECK_CONFIG_FIXTURE, -} from '@opentrons/components' +import { BaseDeck, EXTENDED_DECK_CONFIG_FIXTURE } from '@opentrons/components' import { FLEX_ROBOT_TYPE, getSimplestDeckConfigForProtocol, } from '@opentrons/shared-data' -import deckDefFixture from '@opentrons/shared-data/deck/fixtures/3/deckExample.json' -import fixture_tiprack_300_ul from '@opentrons/shared-data/labware/fixtures/2/fixture_tiprack_300_ul.json' +import { + deckExample as deckDefFixture, + fixtureTiprack300ul, +} from '@opentrons/shared-data' +import { renderWithProviders } from '../../../__testing-utils__' import { i18n } from '../../../i18n' import { getLabwareRenderInfo } from '../../Devices/ProtocolRun/utils/getLabwareRenderInfo' import { getStandardDeckViewLayerBlockList } from '../../Devices/ProtocolRun/utils/getStandardDeckViewLayerBlockList' @@ -28,21 +28,13 @@ import type { ModuleModel, } from '@opentrons/shared-data' -jest.mock('../../Devices/ProtocolRun/utils/getLabwareRenderInfo') -jest.mock('@opentrons/components/src/hardware-sim/Labware/LabwareRender') -jest.mock('@opentrons/components/src/hardware-sim/BaseDeck') -jest.mock('@opentrons/shared-data/js/helpers/getSimplestFlexDeckConfig') -jest.mock('../../../resources/deck_configuration/utils') -jest.mock('../../../redux/config') - -const mockGetLabwareRenderInfo = getLabwareRenderInfo as jest.MockedFunction< - typeof getLabwareRenderInfo -> -const mockGetSimplestDeckConfigForProtocol = getSimplestDeckConfigForProtocol as jest.MockedFunction< - typeof getSimplestDeckConfigForProtocol -> +vi.mock('../../Devices/ProtocolRun/utils/getLabwareRenderInfo') +vi.mock('@opentrons/components/src/hardware-sim/Labware/LabwareRender') +vi.mock('@opentrons/components/src/hardware-sim/BaseDeck') +vi.mock('@opentrons/shared-data/js/helpers/getSimplestFlexDeckConfig') +vi.mock('../../../resources/deck_configuration/utils') +vi.mock('../../../redux/config') -const mockBaseDeck = BaseDeck as jest.MockedFunction const MOCK_300_UL_TIPRACK_COORDS = [30, 40, 0] const render = (props: React.ComponentProps) => { @@ -58,19 +50,20 @@ const render = (props: React.ComponentProps) => { describe('LabwareMapViewModal', () => { beforeEach(() => { - mockGetLabwareRenderInfo.mockReturnValue({}) - mockGetSimplestDeckConfigForProtocol.mockReturnValue([]) + vi.mocked(getLabwareRenderInfo).mockReturnValue({}) + vi.mocked(getSimplestDeckConfigForProtocol).mockReturnValue([]) }) afterEach(() => { - resetAllWhenMocks() + vi.resetAllMocks() }) + it('should render nothing on the deck and calls exit button', () => { - mockBaseDeck.mockReturnValue(
mock base deck
) + vi.mocked(BaseDeck).mockReturnValue(
mock base deck
) const props = { - handleLabwareClick: jest.fn(), - onCloseClick: jest.fn(), + handleLabwareClick: vi.fn(), + onCloseClick: vi.fn(), deckDef: (deckDefFixture as unknown) as DeckDefinition, mostRecentAnalysis: ({ commands: [], @@ -80,10 +73,10 @@ describe('LabwareMapViewModal', () => { attachedProtocolModuleMatches: [], } - const { getByText, getByLabelText } = render(props) - getByText('Map View') - getByText('mock base deck') - fireEvent.click(getByLabelText('closeIcon')) + render(props) + screen.getByText('Map View') + screen.getByText('mock base deck') + fireEvent.click(screen.getByLabelText('closeIcon')) expect(props.onCloseClick).toHaveBeenCalled() }) @@ -91,7 +84,7 @@ describe('LabwareMapViewModal', () => { const mockLabwareOnDeck = [ { labwareLocation: { slotName: 'C1' }, - definition: fixture_tiprack_300_ul as LabwareDefinition2, + definition: fixtureTiprack300ul as LabwareDefinition2, topLabwareId: '300_ul_tiprack_id', onLabwareClick: expect.any(Function), labwareChildren: null, @@ -108,7 +101,7 @@ describe('LabwareMapViewModal', () => { innerProps: {}, }, ] - when(mockBaseDeck) + when(vi.mocked(BaseDeck)) .calledWith({ robotType: FLEX_ROBOT_TYPE, deckLayerBlocklist: getStandardDeckViewLayerBlockList(FLEX_ROBOT_TYPE), @@ -116,10 +109,10 @@ describe('LabwareMapViewModal', () => { labwareOnDeck: mockLabwareOnDeck, modulesOnDeck: mockModulesOnDeck, }) - .mockReturnValue(
mock base deck
) - mockGetLabwareRenderInfo.mockReturnValue({ + .thenReturn(
mock base deck
) + vi.mocked(getLabwareRenderInfo).mockReturnValue({ '300_ul_tiprack_id': { - labwareDef: fixture_tiprack_300_ul as LabwareDefinition2, + labwareDef: fixtureTiprack300ul as LabwareDefinition2, displayName: 'fresh tips', x: MOCK_300_UL_TIPRACK_COORDS[0], y: MOCK_300_UL_TIPRACK_COORDS[1], @@ -139,6 +132,6 @@ describe('LabwareMapViewModal', () => { }, ], }) - expect(mockBaseDeck).toHaveBeenCalled() + expect(vi.mocked(BaseDeck)).toHaveBeenCalled() }) }) diff --git a/app/src/organisms/ProtocolSetupLabware/__tests__/ProtocolSetupLabware.test.tsx b/app/src/organisms/ProtocolSetupLabware/__tests__/ProtocolSetupLabware.test.tsx index 59b0e6e8454..60aced4dcfb 100644 --- a/app/src/organisms/ProtocolSetupLabware/__tests__/ProtocolSetupLabware.test.tsx +++ b/app/src/organisms/ProtocolSetupLabware/__tests__/ProtocolSetupLabware.test.tsx @@ -1,15 +1,16 @@ import * as React from 'react' import { fireEvent, screen } from '@testing-library/react' -import { when, resetAllWhenMocks } from 'jest-when' +import { when } from 'vitest-when' import { MemoryRouter } from 'react-router-dom' +import { describe, it, vi, beforeEach, afterEach, expect } from 'vitest' import { useCreateLiveCommandMutation, useModulesQuery, } from '@opentrons/react-api-client' -import { renderWithProviders } from '@opentrons/components' -import ot3StandardDeckDef from '@opentrons/shared-data/deck/definitions/4/ot3_standard.json' +import { ot3StandardDeckV4 as ot3StandardDeckDef } from '@opentrons/shared-data' +import { renderWithProviders } from '../../../__testing-utils__' import { i18n } from '../../../i18n' import { useMostRecentCompletedAnalysis } from '../../../organisms/LabwarePositionCheck/useMostRecentCompletedAnalysis' import { getProtocolModulesInfo } from '../../Devices/ProtocolRun/utils/getProtocolModulesInfo' @@ -24,29 +25,16 @@ import { mockUseModulesQueryUnknown, } from '../__fixtures__' -jest.mock('@opentrons/react-api-client') -jest.mock( +vi.mock('@opentrons/react-api-client') +vi.mock( '../../../organisms/LabwarePositionCheck/useMostRecentCompletedAnalysis' ) -jest.mock('../../Devices/ProtocolRun/utils/getProtocolModulesInfo') - -const mockUseCreateLiveCommandMutation = useCreateLiveCommandMutation as jest.MockedFunction< - typeof useCreateLiveCommandMutation -> -const mockUseModulesQuery = useModulesQuery as jest.MockedFunction< - typeof useModulesQuery -> -const mockUseMostRecentCompletedAnalysis = useMostRecentCompletedAnalysis as jest.MockedFunction< - typeof useMostRecentCompletedAnalysis -> -const mockGetProtocolModulesInfo = getProtocolModulesInfo as jest.MockedFunction< - typeof getProtocolModulesInfo -> +vi.mock('../../Devices/ProtocolRun/utils/getProtocolModulesInfo') const RUN_ID = "otie's run" -const mockSetSetupScreen = jest.fn() -const mockRefetch = jest.fn() -const mockCreateLiveCommand = jest.fn() +const mockSetSetupScreen = vi.fn() +const mockRefetch = vi.fn() +const mockCreateLiveCommand = vi.fn() const render = () => { return renderWithProviders( @@ -65,23 +53,22 @@ const render = () => { describe('ProtocolSetupLabware', () => { beforeEach(() => { mockCreateLiveCommand.mockResolvedValue(null) - when(mockUseMostRecentCompletedAnalysis) + when(vi.mocked(useMostRecentCompletedAnalysis)) .calledWith(RUN_ID) - .mockReturnValue(mockRecentAnalysis) - when(mockGetProtocolModulesInfo) + .thenReturn(mockRecentAnalysis) + when(vi.mocked(getProtocolModulesInfo)) .calledWith(mockRecentAnalysis, ot3StandardDeckDef as any) - .mockReturnValue(mockProtocolModuleInfo) - mockUseModulesQuery.mockReturnValue({ + .thenReturn(mockProtocolModuleInfo) + vi.mocked(useModulesQuery).mockReturnValue({ ...mockUseModulesQueryOpen, refetch: mockRefetch, } as any) - mockUseCreateLiveCommandMutation.mockReturnValue({ + vi.mocked(useCreateLiveCommandMutation).mockReturnValue({ createLiveCommand: mockCreateLiveCommand, } as any) }) afterEach(() => { - jest.resetAllMocks() - resetAllWhenMocks() + vi.resetAllMocks() }) it('renders the Labware Setup page', () => { @@ -120,7 +107,7 @@ describe('ProtocolSetupLabware', () => { }) it('sends a latch-open command when the labware latch is closed and the button is clicked', () => { - mockUseModulesQuery.mockReturnValue({ + vi.mocked(useModulesQuery).mockReturnValue({ ...mockUseModulesQueryClosed, refetch: mockRefetch, } as any) @@ -138,21 +125,27 @@ describe('ProtocolSetupLabware', () => { }) it('shows opening transition states of the labware latch button', () => { - mockUseModulesQuery.mockReturnValue(mockUseModulesQueryOpening as any) + vi.mocked(useModulesQuery).mockReturnValue( + mockUseModulesQueryOpening as any + ) render() screen.getByText('Opening...') }) it('shows closing transition state of the labware latch button', () => { - mockUseModulesQuery.mockReturnValue(mockUseModulesQueryClosing as any) + vi.mocked(useModulesQuery).mockReturnValue( + mockUseModulesQueryClosing as any + ) render() screen.getByText('Closing...') }) it('defaults to open when latch status is unknown', () => { - mockUseModulesQuery.mockReturnValue(mockUseModulesQueryUnknown as any) + vi.mocked(useModulesQuery).mockReturnValue( + mockUseModulesQueryUnknown as any + ) render() screen.getByText('Open') diff --git a/app/src/organisms/ProtocolSetupLiquids/__tests__/LiquidDetails.test.tsx b/app/src/organisms/ProtocolSetupLiquids/__tests__/LiquidDetails.test.tsx index 3eb21d211bf..1953dd7d5df 100644 --- a/app/src/organisms/ProtocolSetupLiquids/__tests__/LiquidDetails.test.tsx +++ b/app/src/organisms/ProtocolSetupLiquids/__tests__/LiquidDetails.test.tsx @@ -1,6 +1,8 @@ import * as React from 'react' import { screen, fireEvent } from '@testing-library/react' -import { renderWithProviders } from '@opentrons/components' +import { describe, it, beforeEach, vi } from 'vitest' + +import { renderWithProviders } from '../../../__testing-utils__' import { i18n } from '../../../i18n' import { RUN_ID_1 } from '../../RunTimeControl/__fixtures__' import { getLocationInfoNames } from '../../Devices/ProtocolRun/utils/getLocationInfoNames' @@ -13,19 +15,10 @@ import { } from '../fixtures' import type { CompletedProtocolAnalysis } from '@opentrons/shared-data' -jest.mock('../../Devices/ProtocolRun/SetupLiquids/utils') -jest.mock('../../Devices/ProtocolRun/utils/getLocationInfoNames') -jest.mock('../../Devices/ProtocolRun/SetupLiquids/LiquidsLabwareDetailsModal') +vi.mock('../../Devices/ProtocolRun/SetupLiquids/utils') +vi.mock('../../Devices/ProtocolRun/utils/getLocationInfoNames') +vi.mock('../../Devices/ProtocolRun/SetupLiquids/LiquidsLabwareDetailsModal') -const mockGetLocationInfoNames = getLocationInfoNames as jest.MockedFunction< - typeof getLocationInfoNames -> -const mockgetTotalVolumePerLiquidId = getTotalVolumePerLiquidId as jest.MockedFunction< - typeof getTotalVolumePerLiquidId -> -const mockLiquidsLabwareDetailsModal = LiquidsLabwareDetailsModal as jest.MockedFunction< - typeof LiquidsLabwareDetailsModal -> const render = (props: React.ComponentProps) => { return renderWithProviders(, { i18nInstance: i18n, @@ -46,12 +39,12 @@ describe('LiquidDetails', () => { displayColor: '#ff4888', }, } - mockgetTotalVolumePerLiquidId.mockReturnValue(50) - mockGetLocationInfoNames.mockReturnValue({ + vi.mocked(getTotalVolumePerLiquidId).mockReturnValue(50) + vi.mocked(getLocationInfoNames).mockReturnValue({ slotName: '4', labwareName: 'mock labware name', }) - mockLiquidsLabwareDetailsModal.mockReturnValue(
mock modal
) + vi.mocked(LiquidsLabwareDetailsModal).mockReturnValue(
mock modal
) }) it('renders the total volume of the liquid, sample display name, clicking on arrow renders the modal', () => { diff --git a/app/src/organisms/ProtocolSetupLiquids/__tests__/ProtocolSetupLiquids.test.tsx b/app/src/organisms/ProtocolSetupLiquids/__tests__/ProtocolSetupLiquids.test.tsx index 35e9970b8b5..f423051ed6f 100644 --- a/app/src/organisms/ProtocolSetupLiquids/__tests__/ProtocolSetupLiquids.test.tsx +++ b/app/src/organisms/ProtocolSetupLiquids/__tests__/ProtocolSetupLiquids.test.tsx @@ -1,9 +1,10 @@ import * as React from 'react' -import { renderWithProviders } from '@opentrons/components' +import { describe, it, beforeEach, vi } from 'vitest' import { parseLiquidsInLoadOrder, parseLabwareInfoByLiquidId, } from '@opentrons/api-client' +import { renderWithProviders } from '../../../__testing-utils__' import { i18n } from '../../../i18n' import { RUN_ID_1 } from '../../RunTimeControl/__fixtures__' import { getTotalVolumePerLiquidId } from '../../Devices/ProtocolRun/SetupLiquids/utils' @@ -18,27 +19,12 @@ import { ProtocolSetupLiquids } from '..' import type { CompletedProtocolAnalysis } from '@opentrons/shared-data' import { screen, fireEvent } from '@testing-library/react' -jest.mock('../../Devices/ProtocolRun/SetupLiquids/utils') -jest.mock('../../../atoms/buttons') -jest.mock('../LiquidDetails') -jest.mock('../../LabwarePositionCheck/useMostRecentCompletedAnalysis') -jest.mock('@opentrons/api-client') +vi.mock('../../Devices/ProtocolRun/SetupLiquids/utils') +vi.mock('../../../atoms/buttons') +vi.mock('../LiquidDetails') +vi.mock('../../LabwarePositionCheck/useMostRecentCompletedAnalysis') +vi.mock('@opentrons/api-client') -const mockUseMostRecentCompletedAnalysis = useMostRecentCompletedAnalysis as jest.MockedFunction< - typeof useMostRecentCompletedAnalysis -> -const mockParseLiquidsInLoadOrder = parseLiquidsInLoadOrder as jest.MockedFunction< - typeof parseLiquidsInLoadOrder -> -const mockParseLabwareInfoByLiquidId = parseLabwareInfoByLiquidId as jest.MockedFunction< - typeof parseLabwareInfoByLiquidId -> -const mockLiquidDetails = LiquidDetails as jest.MockedFunction< - typeof LiquidDetails -> -const mockgetTotalVolumePerLiquidId = getTotalVolumePerLiquidId as jest.MockedFunction< - typeof getTotalVolumePerLiquidId -> const render = (props: React.ComponentProps) => { return renderWithProviders(, { i18nInstance: i18n, @@ -48,16 +34,18 @@ const render = (props: React.ComponentProps) => { describe('ProtocolSetupLiquids', () => { let props: React.ComponentProps beforeEach(() => { - props = { runId: RUN_ID_1, setSetupScreen: jest.fn() } - mockParseLiquidsInLoadOrder.mockReturnValue(MOCK_LIQUIDS_IN_LOAD_ORDER) - mockParseLabwareInfoByLiquidId.mockReturnValue( + props = { runId: RUN_ID_1, setSetupScreen: vi.fn() } + vi.mocked(parseLiquidsInLoadOrder).mockReturnValue( + MOCK_LIQUIDS_IN_LOAD_ORDER + ) + vi.mocked(parseLabwareInfoByLiquidId).mockReturnValue( MOCK_LABWARE_INFO_BY_LIQUID_ID as any ) - mockUseMostRecentCompletedAnalysis.mockReturnValue( + vi.mocked(useMostRecentCompletedAnalysis).mockReturnValue( MOCK_PROTOCOL_ANALYSIS as CompletedProtocolAnalysis ) - mockLiquidDetails.mockReturnValue(
mock liquid details
) - mockgetTotalVolumePerLiquidId.mockReturnValue(50) + vi.mocked(LiquidDetails).mockReturnValue(
mock liquid details
) + vi.mocked(getTotalVolumePerLiquidId).mockReturnValue(50) }) it('renders the total volume of the liquid, sample display name, clicking on arrow renders the modal', () => { diff --git a/app/src/organisms/ProtocolSetupModulesAndDeck/__tests__/FixtureTable.test.tsx b/app/src/organisms/ProtocolSetupModulesAndDeck/__tests__/FixtureTable.test.tsx index b85b592a66b..cdddc232154 100644 --- a/app/src/organisms/ProtocolSetupModulesAndDeck/__tests__/FixtureTable.test.tsx +++ b/app/src/organisms/ProtocolSetupModulesAndDeck/__tests__/FixtureTable.test.tsx @@ -1,7 +1,7 @@ import * as React from 'react' import { fireEvent, screen } from '@testing-library/react' +import { describe, it, beforeEach, afterEach, vi, expect } from 'vitest' -import { renderWithProviders } from '@opentrons/components' import { FLEX_ROBOT_TYPE, MOVABLE_TRASH_D3_ADDRESSABLE_AREA, @@ -10,26 +10,20 @@ import { TRASH_BIN_ADAPTER_FIXTURE, } from '@opentrons/shared-data' +import { renderWithProviders } from '../../../__testing-utils__' import { i18n } from '../../../i18n' import { LocationConflictModal } from '../../../organisms/Devices/ProtocolRun/SetupModuleAndDeck/LocationConflictModal' import { useDeckConfigurationCompatibility } from '../../../resources/deck_configuration/hooks' import { FixtureTable } from '../FixtureTable' -jest.mock('../../../resources/deck_configuration/hooks') -jest.mock( +vi.mock('../../../resources/deck_configuration/hooks') +vi.mock( '../../../organisms/Devices/ProtocolRun/SetupModuleAndDeck/LocationConflictModal' ) -const mockLocationConflictModal = LocationConflictModal as jest.MockedFunction< - typeof LocationConflictModal -> -const mockUseDeckConfigurationCompatibility = useDeckConfigurationCompatibility as jest.MockedFunction< - typeof useDeckConfigurationCompatibility -> - -const mockSetSetupScreen = jest.fn() -const mockSetCutoutId = jest.fn() -const mockSetProvidedFixtureOptions = jest.fn() +const mockSetSetupScreen = vi.fn() +const mockSetCutoutId = vi.fn() +const mockSetProvidedFixtureOptions = vi.fn() const render = (props: React.ComponentProps) => { return renderWithProviders(, { @@ -47,10 +41,10 @@ describe('FixtureTable', () => { setCutoutId: mockSetCutoutId, setProvidedFixtureOptions: mockSetProvidedFixtureOptions, } - mockLocationConflictModal.mockReturnValue( + vi.mocked(LocationConflictModal).mockReturnValue(
mock location conflict modal
) - mockUseDeckConfigurationCompatibility.mockReturnValue([ + vi.mocked(useDeckConfigurationCompatibility).mockReturnValue([ { cutoutId: 'cutoutD3', cutoutFixtureId: STAGING_AREA_SLOT_WITH_WASTE_CHUTE_RIGHT_ADAPTER_NO_COVER_FIXTURE, @@ -63,7 +57,7 @@ describe('FixtureTable', () => { ]) }) afterEach(() => { - jest.clearAllMocks() + vi.clearAllMocks() }) it('should render table header and contents', () => { @@ -79,7 +73,7 @@ describe('FixtureTable', () => { }) it('should render the current status - not configured', () => { - mockUseDeckConfigurationCompatibility.mockReturnValue([ + vi.mocked(useDeckConfigurationCompatibility).mockReturnValue([ { cutoutId: 'cutoutD3', cutoutFixtureId: SINGLE_RIGHT_SLOT_FIXTURE, @@ -101,7 +95,7 @@ describe('FixtureTable', () => { }) it('should render the current status - conflicting', () => { - mockUseDeckConfigurationCompatibility.mockReturnValue([ + vi.mocked(useDeckConfigurationCompatibility).mockReturnValue([ { cutoutId: 'cutoutD3', cutoutFixtureId: STAGING_AREA_SLOT_WITH_WASTE_CHUTE_RIGHT_ADAPTER_NO_COVER_FIXTURE, diff --git a/app/src/organisms/ProtocolSetupModulesAndDeck/__tests__/SetupInstructionsModal.test.tsx b/app/src/organisms/ProtocolSetupModulesAndDeck/__tests__/SetupInstructionsModal.test.tsx index 2789abf66b1..06db135f3f6 100644 --- a/app/src/organisms/ProtocolSetupModulesAndDeck/__tests__/SetupInstructionsModal.test.tsx +++ b/app/src/organisms/ProtocolSetupModulesAndDeck/__tests__/SetupInstructionsModal.test.tsx @@ -1,14 +1,15 @@ import * as React from 'react' -import { fireEvent } from '@testing-library/react' - -import { renderWithProviders } from '@opentrons/components' +import { fireEvent, screen } from '@testing-library/react' +import { describe, it, expect, beforeEach, vi } from 'vitest' +import { renderWithProviders } from '../../../__testing-utils__' import { i18n } from '../../../i18n' import { SetupInstructionsModal } from '../SetupInstructionsModal' -const mockSetShowSetupInstructionsModal = jest.fn() -const QR_CODE_IMAGE_FILE = 'setup_instructions_qr_code.png' +const mockSetShowSetupInstructionsModal = vi.fn() +const QR_CODE_IMAGE_FILE = + '/app/src/assets/images/on-device-display/setup_instructions_qr_code.png' const render = (props: React.ComponentProps) => { return renderWithProviders(, { @@ -26,18 +27,20 @@ describe('SetupInstructionsModal', () => { }) it('should render text and image', () => { - const [{ getByText, getByRole }] = render(props) - getByText('Setup instructions') - getByText( + render(props) + screen.getByText('Setup instructions') + screen.getByText( 'For step-by-step instructions on setting up your module, consult the Quickstart Guide that came in its box or scan the QR code to visit the modules section of the Opentrons Help Center.' ) - getByText('support.opentrons.com/s/modules') - expect(getByRole('img').getAttribute('src')).toEqual(QR_CODE_IMAGE_FILE) + screen.getByText('support.opentrons.com/s/modules') + expect(screen.getByRole('img').getAttribute('src')).toEqual( + QR_CODE_IMAGE_FILE + ) }) it('should call mock function when tapping close icon', () => { - const [{ getByLabelText }] = render(props) - fireEvent.click(getByLabelText('closeIcon')) + render(props) + fireEvent.click(screen.getByLabelText('closeIcon')) expect(mockSetShowSetupInstructionsModal).toHaveBeenCalled() }) }) diff --git a/app/src/organisms/ProtocolSetupModulesAndDeck/__tests__/utils.test.tsx b/app/src/organisms/ProtocolSetupModulesAndDeck/__tests__/utils.test.tsx index 69ae0167d00..97c76148799 100644 --- a/app/src/organisms/ProtocolSetupModulesAndDeck/__tests__/utils.test.tsx +++ b/app/src/organisms/ProtocolSetupModulesAndDeck/__tests__/utils.test.tsx @@ -1,3 +1,4 @@ +import { describe, it, expect } from 'vitest' import { getModuleDef2 } from '@opentrons/shared-data' import { mockTemperatureModule } from '../../../redux/modules/__fixtures__' diff --git a/app/src/organisms/ProtocolsLanding/__tests__/ConfirmDeleteProtocolModal.test.tsx b/app/src/organisms/ProtocolsLanding/__tests__/ConfirmDeleteProtocolModal.test.tsx index e2fa10523e4..ed2f816ded0 100644 --- a/app/src/organisms/ProtocolsLanding/__tests__/ConfirmDeleteProtocolModal.test.tsx +++ b/app/src/organisms/ProtocolsLanding/__tests__/ConfirmDeleteProtocolModal.test.tsx @@ -1,6 +1,7 @@ import * as React from 'react' -import { renderWithProviders } from '@opentrons/components' -import { fireEvent } from '@testing-library/react' +import { fireEvent, screen } from '@testing-library/react' +import { describe, it, vi, expect, beforeEach, afterEach } from 'vitest' +import { renderWithProviders } from '../../../__testing-utils__' import { i18n } from '../../../i18n' import { ConfirmDeleteProtocolModal } from '../ConfirmDeleteProtocolModal' @@ -17,32 +18,32 @@ describe('ConfirmDeleteProtocolModal', () => { beforeEach(() => { props = { - cancelDeleteProtocol: jest.fn(), - handleClickDelete: jest.fn(), + cancelDeleteProtocol: vi.fn(), + handleClickDelete: vi.fn(), } }) afterEach(() => { - jest.restoreAllMocks() + vi.restoreAllMocks() }) it('renders correct text', () => { - const { getByText } = render(props) - getByText('Delete this protocol?') - getByText( + render(props) + screen.getByText('Delete this protocol?') + screen.getByText( 'This protocol will be moved to this computer’s trash and may be unrecoverable.' ) }) it('renders buttons and clicking on them call corresponding props', () => { props = { - cancelDeleteProtocol: jest.fn(), - handleClickDelete: jest.fn(), + cancelDeleteProtocol: vi.fn(), + handleClickDelete: vi.fn(), } - const { getByText, getByRole } = render(props) - const cancel = getByText('cancel') + render(props) + const cancel = screen.getByText('cancel') fireEvent.click(cancel) expect(props.cancelDeleteProtocol).toHaveBeenCalled() - const confirm = getByRole('button', { name: 'Yes, delete protocol' }) + const confirm = screen.getByRole('button', { name: 'Yes, delete protocol' }) fireEvent.click(confirm) expect(props.handleClickDelete).toHaveBeenCalled() }) diff --git a/app/src/organisms/ProtocolsLanding/__tests__/EmptyStateLinks.test.tsx b/app/src/organisms/ProtocolsLanding/__tests__/EmptyStateLinks.test.tsx index 582634b197c..06b11ec4b17 100644 --- a/app/src/organisms/ProtocolsLanding/__tests__/EmptyStateLinks.test.tsx +++ b/app/src/organisms/ProtocolsLanding/__tests__/EmptyStateLinks.test.tsx @@ -1,7 +1,9 @@ import * as React from 'react' import { screen } from '@testing-library/react' import { BrowserRouter } from 'react-router-dom' -import { renderWithProviders } from '@opentrons/components' +import { describe, it, expect, afterEach, vi } from 'vitest' + +import { renderWithProviders } from '../../../__testing-utils__' import { i18n } from '../../../i18n' import { EmptyStateLinks } from '../EmptyStateLinks' @@ -18,7 +20,7 @@ describe('EmptyStateLinks', () => { } afterEach(() => { - jest.resetAllMocks() + vi.resetAllMocks() }) it('renders correct contents for empty state', () => { diff --git a/components/src/__tests__/utils.test.ts b/components/src/__tests__/utils.test.ts index 5de98480f8a..bc1321a502e 100644 --- a/components/src/__tests__/utils.test.ts +++ b/components/src/__tests__/utils.test.ts @@ -1,3 +1,4 @@ +import { describe, it, expect } from 'vitest' import { truncateString } from '../utils' describe('truncateString', () => { diff --git a/components/src/atoms/CheckboxField/__tests__/CheckboxField.test.tsx b/components/src/atoms/CheckboxField/__tests__/CheckboxField.test.tsx index e6328eea822..4be1b73bbf0 100644 --- a/components/src/atoms/CheckboxField/__tests__/CheckboxField.test.tsx +++ b/components/src/atoms/CheckboxField/__tests__/CheckboxField.test.tsx @@ -1,5 +1,5 @@ import * as React from 'react' -import { describe, beforeEach, afterEach, vi, expect } from 'vitest' +import { describe, beforeEach, afterEach, vi, expect, it } from 'vitest' import { fireEvent, screen } from '@testing-library/react' import '@testing-library/jest-dom/vitest' import { ALIGN_CENTER, JUSTIFY_CENTER } from '../../../styles' @@ -41,39 +41,13 @@ describe('CheckboxField', () => { // INNER_STYLE_NO_VALUE expect(checkBoxIcon).toHaveStyle(`width: 1.25rem`) expect(checkBoxIcon).toHaveStyle(`min-width: 1.25rem`) - expect(checkBoxIcon).toHaveStyle(`color: ${String(COLORS.grey50)}`) + expect(checkBoxIcon).toHaveStyle(`color: ${String(COLORS.grey60)}`) expect(checkBoxIcon).toHaveStyle(`display: flex`) expect(checkBoxIcon).toHaveStyle(`border-radius: 1px`) expect(checkBoxIcon).toHaveStyle( `justify-content: ${String(JUSTIFY_CENTER)}` ) expect(checkBoxIcon).toHaveStyle(`align-items: ${String(ALIGN_CENTER)}`) - expect(checkBoxIcon).toHaveStyleRule('cursor', 'pointer', { - modifier: ':hover', - }) - expect(checkBoxIcon).toHaveStyleRule('color', `${String(COLORS.grey60)}`, { - modifier: ':hover', - }) - expect(checkBoxIcon).toHaveStyleRule('color', `${String(COLORS.grey60)}`, { - modifier: ':active', - }) - expect(checkBoxIcon).toHaveStyleRule( - 'box-shadow', - `0 0 0 3px ${String(COLORS.blue50)}`, - { modifier: ':focus' } - ) - expect(checkBoxIcon).toHaveStyleRule('color', `${String(COLORS.grey60)}`, { - modifier: ':disabled', - }) - - // TODO: kj 09/15/2022 This part will be update later OUTER_STYLE - // const checkBoxLabel = getByTestId('CheckboxField_label') - // expect(checkBoxLabel).toHaveStyle('font-size: 0.75rem') - // expect(checkBoxLabel).toHaveStyle('font-weight: 400') - // expect(checkBoxLabel).toHaveStyle(`color: ${COLORS.black90}`) - // expect(checkBoxLabel).toHaveStyle('display: flex') - // expect(checkBoxLabel).toHaveStyle(`align-items: ${ALIGN_CENTER}`) - // expect(checkBoxLabel).toHaveStyle('line-height: 1') // INPUT_STYLE expect(checkBoxInput).toHaveStyle(`position: absolute`) @@ -98,10 +72,6 @@ describe('CheckboxField', () => { expect(checkBoxFieldBox).toHaveStyle( `padding: ${SPACING.spacing8} ${SPACING.spacing8}` ) - expect(checkBoxFieldBox).toHaveStyleRule('padding', '0', { - modifier: ':empty', - }) - expect(checkBoxFieldBox).toHaveAttribute('tabindex', '0') }) it('render icon with correct style - value true', () => { @@ -110,7 +80,7 @@ describe('CheckboxField', () => { const checkBoxIcon = screen.getByTestId('CheckboxField_icon') expect(checkBoxIcon).toHaveStyle(`width: 1.25rem`) expect(checkBoxIcon).toHaveStyle(`min-width: 1.25rem`) - expect(checkBoxIcon).toHaveStyle(`color: ${String(COLORS.blue50)}`) + expect(checkBoxIcon).toHaveStyle(`color: ${String(COLORS.blue60)}`) expect(checkBoxIcon).toHaveStyle(`display: flex`) expect(checkBoxIcon).toHaveStyle(`border-radius: 1px`) expect(checkBoxIcon).toHaveStyle( @@ -119,13 +89,13 @@ describe('CheckboxField', () => { expect(checkBoxIcon).toHaveStyle(`align-items: ${String(ALIGN_CENTER)}`) }) - it('renders label with correct style - value undefine', () => { + it('renders label with correct style - value undefined', () => { props.value = undefined render(props) const checkBoxIcon = screen.getByTestId('CheckboxField_icon') expect(checkBoxIcon).toHaveStyle(`width: 1.25rem`) expect(checkBoxIcon).toHaveStyle(`min-width: 1.25rem`) - expect(checkBoxIcon).toHaveStyle(`color: ${String(COLORS.grey50)}`) + expect(checkBoxIcon).toHaveStyle(`color: ${String(COLORS.grey60)}`) expect(checkBoxIcon).toHaveStyle(`display: flex`) expect(checkBoxIcon).toHaveStyle(`border-radius: 1px`) expect(checkBoxIcon).toHaveStyle( diff --git a/components/src/atoms/buttons/__tests__/PrimaryButton.test.tsx b/components/src/atoms/buttons/__tests__/PrimaryButton.test.tsx index 457fc8f2637..fa77e47b101 100644 --- a/components/src/atoms/buttons/__tests__/PrimaryButton.test.tsx +++ b/components/src/atoms/buttons/__tests__/PrimaryButton.test.tsx @@ -47,32 +47,18 @@ describe('PrimaryButton', () => { expect(button).toHaveStyle(`color: ${COLORS.grey50}`) }) - it('applies the correct states to the button - focus', () => { - render(props) - const button = screen.getByText('primary button') - fireEvent.focus(button) - expect(button).toHaveStyle(`background-color: ${COLORS.blue55}`) - }) - it('applies the correct states to the button - hover', () => { render(props) const button = screen.getByText('primary button') fireEvent.mouseOver(button) - expect(button).toHaveStyle(`background-color: ${COLORS.blue55}`) - }) - - it('applies the correct states to the button - default', () => { - render(props) - const button = screen.getByText('primary button') - fireEvent.mouseLeave(button) - expect(button).toHaveStyle(`background-color: ${COLORS.blue50}`) + expect(button).toHaveStyle(`background-color: ${COLORS.blue60}`) }) it('renders primary button with text and different background color', () => { props.backgroundColor = COLORS.red50 render(props) const button = screen.getByText('primary button') - expect(button).toHaveStyle(`background-color: ${COLORS.red50}`) + expect(button).toHaveStyle(`background-color: ${COLORS.blue60}`) expect(button).toHaveStyle(`color: ${COLORS.white}`) }) }) diff --git a/components/src/atoms/buttons/__tests__/SecondaryButton.test.tsx b/components/src/atoms/buttons/__tests__/SecondaryButton.test.tsx index a5f2b29ed1a..9d8bbaf35d1 100644 --- a/components/src/atoms/buttons/__tests__/SecondaryButton.test.tsx +++ b/components/src/atoms/buttons/__tests__/SecondaryButton.test.tsx @@ -49,6 +49,6 @@ describe('SecondaryButton', () => { props.color = COLORS.red50 render(props) const button = screen.getByText('secondary button') - expect(button).toHaveStyle(`color: ${COLORS.red50}`) + expect(button).toHaveStyle(`color: ${COLORS.blue55}`) }) }) diff --git a/components/src/hardware-sim/Labware/__tests__/LabwareRender.test.tsx b/components/src/hardware-sim/Labware/__tests__/LabwareRender.test.tsx index 089565dc2dd..fac32984419 100644 --- a/components/src/hardware-sim/Labware/__tests__/LabwareRender.test.tsx +++ b/components/src/hardware-sim/Labware/__tests__/LabwareRender.test.tsx @@ -2,9 +2,7 @@ import * as React from 'react' import { describe, it, vi, beforeEach } from 'vitest' import { render, screen } from '@testing-library/react' import '@testing-library/jest-dom/vitest' -import { when } from 'vitest-when' import { fixture12Trough } from '@opentrons/shared-data' -import { componentPropsMatcher } from '../../../testing/utils' import { StaticLabwareComponent as StaticLabware, WellLabelsComponent as WellLabels, @@ -19,9 +17,7 @@ const troughFixture12 = fixture12Trough as LabwareDefinition2 describe('LabwareRender', () => { beforeEach(() => { - when(StaticLabware) - .calledWith(componentPropsMatcher({ definition: troughFixture12 })) - .thenReturn(
mock static labware
) + vi.mocked(StaticLabware).mockReturnValue(
mock static labware
) }) it('should render a static labware component', () => { @@ -35,14 +31,7 @@ describe('LabwareRender', () => { }) it('should render stroked wells', () => { const props = { definition: troughFixture12, wellStroke: { A1: 'blue' } } - when(StrokedWells) - .calledWith( - componentPropsMatcher({ - definition: troughFixture12, - strokeByWell: { A1: 'blue' }, - }) - ) - .thenReturn(
mock stroked wells
) + vi.mocked(StrokedWells).mockReturnValue(
mock stroked wells
) render( @@ -55,14 +44,7 @@ describe('LabwareRender', () => { definition: troughFixture12, wellLabelOption: WELL_LABEL_OPTIONS.SHOW_LABEL_INSIDE, } - when(WellLabels) - .calledWith( - componentPropsMatcher({ - definition: troughFixture12, - wellLabelOption: WELL_LABEL_OPTIONS.SHOW_LABEL_INSIDE, - }) - ) - .thenReturn(
mock well labels
) + vi.mocked(WellLabels).mockReturnValue(
mock well labels
) render( diff --git a/components/src/hardware-sim/Pipette/__tests__/PipetteRender.test.tsx b/components/src/hardware-sim/Pipette/__tests__/PipetteRender.test.tsx index dc3a4969912..c06e40b347e 100644 --- a/components/src/hardware-sim/Pipette/__tests__/PipetteRender.test.tsx +++ b/components/src/hardware-sim/Pipette/__tests__/PipetteRender.test.tsx @@ -3,7 +3,7 @@ import { describe, it, expect, vi, beforeEach } from 'vitest' import { when } from 'vitest-when' import { screen } from '@testing-library/react' import { fixtureTiprack300ul as _fixtureTiprack300ul } from '@opentrons/shared-data' -import { anyProps, renderWithProviders } from '../../../testing/utils' +import { renderWithProviders } from '../../../testing/utils' import { RobotCoordsForeignDiv } from '../../Deck/RobotCoordsForeignDiv' import { PipetteRender } from '../PipetteRender' import { EmanatingNozzle } from '../EmanatingNozzle' @@ -46,9 +46,8 @@ describe('PipetteRender', () => { )) - when(EmanatingNozzle) - .calledWith(anyProps()) - .thenReturn(
mock emanating nozzle
) + vi.mocked(EmanatingNozzle) + .mockReturnValue(
mock emanating nozzle
) }) it('should render a rectangle with the correct dimensions', () => { diff --git a/components/src/instrument/__tests__/PipetteSelect.test.tsx b/components/src/instrument/__tests__/PipetteSelect.test.tsx index d6bf72e00a6..5ca7d2bd2d8 100644 --- a/components/src/instrument/__tests__/PipetteSelect.test.tsx +++ b/components/src/instrument/__tests__/PipetteSelect.test.tsx @@ -1,3 +1,4 @@ +import { describe, it } from 'vitest' describe('PipetteSelect', () => { it.todo('replace deprecated enzyme test') }) diff --git a/components/src/interaction-enhancers/__tests__/useHover.test.tsx b/components/src/interaction-enhancers/__tests__/useHover.test.tsx index 7d485af6b3c..a847c2a683b 100644 --- a/components/src/interaction-enhancers/__tests__/useHover.test.tsx +++ b/components/src/interaction-enhancers/__tests__/useHover.test.tsx @@ -1,3 +1,4 @@ +import { describe, it } from 'vitest' describe('useHover hook', () => { it.todo('replace deprecated enzyme test') }) diff --git a/components/src/modals/__tests__/BaseModal.test.tsx b/components/src/modals/__tests__/BaseModal.test.tsx index a18dd46683f..449c71325a9 100644 --- a/components/src/modals/__tests__/BaseModal.test.tsx +++ b/components/src/modals/__tests__/BaseModal.test.tsx @@ -1,3 +1,4 @@ +import { describe, it } from 'vitest' describe('BaseModal', () => { it.todo('replace deprecated enzyme test') }) diff --git a/components/src/molecules/LocationIcon/__tests__/LocationIcon.test.tsx b/components/src/molecules/LocationIcon/__tests__/LocationIcon.test.tsx index 62ad919e747..960a21f61ea 100644 --- a/components/src/molecules/LocationIcon/__tests__/LocationIcon.test.tsx +++ b/components/src/molecules/LocationIcon/__tests__/LocationIcon.test.tsx @@ -1,6 +1,7 @@ import * as React from 'react' - +import { describe, it, beforeEach, expect } from 'vitest' import { renderWithProviders } from '../../../testing/utils' +import { screen } from '@testing-library/react' import { BORDERS, SPACING } from '../../../ui-style-constants' import { COLORS } from '../../../helix-design-system' @@ -20,8 +21,8 @@ describe('LocationIcon', () => { }) it('should render the proper styles', () => { - const [{ getByTestId }] = render(props) - const locationIcon = getByTestId('LocationIcon_A1') + render(props) + const locationIcon = screen.getByTestId('LocationIcon_A1') expect(locationIcon).toHaveStyle(`padding: ${SPACING.spacing4} 0.375rem`) expect(locationIcon).toHaveStyle('height: 2rem') expect(locationIcon).toHaveStyle('width: max-content') @@ -32,15 +33,15 @@ describe('LocationIcon', () => { }) it('should render slot name', () => { - const [{ getByText }] = render(props) - getByText('A1') + render(props) + screen.getByText('A1') }) it('should render an icon', () => { props = { iconName: 'ot-temperature-v2', } - const [{ getByLabelText }] = render(props) - getByLabelText(props.iconName as string) + render(props) + screen.getByLabelText(props.iconName as string) }) }) diff --git a/components/src/primitives/__tests__/Box.test.tsx b/components/src/primitives/__tests__/Box.test.tsx index 52274f1d25d..330b24a0005 100644 --- a/components/src/primitives/__tests__/Box.test.tsx +++ b/components/src/primitives/__tests__/Box.test.tsx @@ -1,3 +1,4 @@ +import { describe, it } from 'vitest' describe('Box primitive component', () => { it.todo('replace deprecated enzyme test') }) diff --git a/components/src/primitives/__tests__/Btn.test.tsx b/components/src/primitives/__tests__/Btn.test.tsx index 8d2c71afe3f..4c1f7b88e43 100644 --- a/components/src/primitives/__tests__/Btn.test.tsx +++ b/components/src/primitives/__tests__/Btn.test.tsx @@ -1,3 +1,4 @@ +import { describe, it } from 'vitest' describe('Btn primitive component', () => { it.todo('replace deprecated enzyme test') }) diff --git a/components/src/primitives/__tests__/Flex.test.tsx b/components/src/primitives/__tests__/Flex.test.tsx index 3607957f880..50920489028 100644 --- a/components/src/primitives/__tests__/Flex.test.tsx +++ b/components/src/primitives/__tests__/Flex.test.tsx @@ -1,3 +1,4 @@ +import { describe, it } from 'vitest' describe('Flex primitive component', () => { it.todo('replace deprecated enzyme test') }) diff --git a/components/src/primitives/__tests__/Link.test.tsx b/components/src/primitives/__tests__/Link.test.tsx index 608484a0faa..d23a7b85461 100644 --- a/components/src/primitives/__tests__/Link.test.tsx +++ b/components/src/primitives/__tests__/Link.test.tsx @@ -1,3 +1,4 @@ +import { describe, it } from 'vitest' describe('Link primitive component', () => { it.todo('replace deprecated enzyme test') }) diff --git a/components/src/primitives/__tests__/Svg.test.tsx b/components/src/primitives/__tests__/Svg.test.tsx index e32bde844a8..aa3e23aaa5d 100644 --- a/components/src/primitives/__tests__/Svg.test.tsx +++ b/components/src/primitives/__tests__/Svg.test.tsx @@ -1,3 +1,4 @@ +import { describe, it } from 'vitest' describe('Svg primitive component', () => { it.todo('replace deprecated enzyme test') }) diff --git a/components/src/primitives/__tests__/Text.test.tsx b/components/src/primitives/__tests__/Text.test.tsx index 06aa91ee054..df7acaa4ca5 100644 --- a/components/src/primitives/__tests__/Text.test.tsx +++ b/components/src/primitives/__tests__/Text.test.tsx @@ -1,3 +1,4 @@ +import { describe, it } from 'vitest' describe('Text primitive component', () => { it.todo('replace deprecated enzyme test') }) diff --git a/components/src/primitives/__tests__/primitives.test.tsx b/components/src/primitives/__tests__/primitives.test.tsx index 43ce5b038f1..427fcf9e6ce 100644 --- a/components/src/primitives/__tests__/primitives.test.tsx +++ b/components/src/primitives/__tests__/primitives.test.tsx @@ -1,3 +1,4 @@ +import { describe, it } from 'vitest' describe('primitive components with style props', () => { it.todo('replace deprecated enzyme test') }) diff --git a/components/src/primitives/__tests__/style-props.test.tsx b/components/src/primitives/__tests__/style-props.test.tsx index 3ed51d13aac..501739ec6f3 100644 --- a/components/src/primitives/__tests__/style-props.test.tsx +++ b/components/src/primitives/__tests__/style-props.test.tsx @@ -1,3 +1,4 @@ +import { describe, it } from 'vitest' describe('style props', () => { it.todo('replace deprecated enzyme test') }) diff --git a/components/src/slotmap/__tests__/SlotMap.test.tsx b/components/src/slotmap/__tests__/SlotMap.test.tsx index 4b939110602..48877e7df5a 100644 --- a/components/src/slotmap/__tests__/SlotMap.test.tsx +++ b/components/src/slotmap/__tests__/SlotMap.test.tsx @@ -1,3 +1,4 @@ +import { describe, it } from 'vitest' describe('SlotMap', () => { it.todo('replace deprecated enzyme test') }) diff --git a/components/src/testing/utils/matchers.ts b/components/src/testing/utils/matchers.ts index 3e0b3fea73b..0e142bcb51e 100644 --- a/components/src/testing/utils/matchers.ts +++ b/components/src/testing/utils/matchers.ts @@ -1,13 +1,8 @@ -import { when } from 'jest-when' +import { when } from 'vitest-when' import type { Matcher } from '@testing-library/react' // these are needed because under the hood react calls components with two arguments (props and some second argument nobody seems to know) // https://github.com/timkindberg/jest-when/issues/66 -// use componentPropsMatcher if you want to verify ALL props being passed into a component -export const componentPropsMatcher = (matcher: unknown): any => - // @ts-expect-error(sa, 2021-08-03): when.allArgs not part of type definition yet for jest-when - when.allArgs((args, equals) => equals(args[0], matcher)) - // use partialComponentPropsMatcher to only verify the props you pass into partialComponentPropsMatcher export const partialComponentPropsMatcher = (argsToMatch: unknown): any => // @ts-expect-error(sa, 2021-08-03): when.allArgs not part of type definition yet for jest-when @@ -15,13 +10,6 @@ export const partialComponentPropsMatcher = (argsToMatch: unknown): any => equals(args[0], expect.objectContaining(argsToMatch)) ) -// use argAtIndex to only verify arguments at a specific index -export const argAtIndex = (index: number, matcher: unknown): any => - // @ts-expect-error(sa, 2021-08-03): when.allArgs not part of type definition yet for jest-when - when.allArgs((args, equals) => equals(args[index], matcher)) - -export const anyProps = (): any => partialComponentPropsMatcher({}) - // Match things like

Some nested text

// Use with either string match: getByText(nestedTextMatcher("Some nested text")) // or regexp: getByText(nestedTextMatcher(/Some nested text/)) diff --git a/components/src/testing/utils/renderWithProviders.tsx b/components/src/testing/utils/renderWithProviders.tsx index 1ea0a5c021c..fdf4d4dcc38 100644 --- a/components/src/testing/utils/renderWithProviders.tsx +++ b/components/src/testing/utils/renderWithProviders.tsx @@ -4,6 +4,7 @@ import * as React from 'react' import { QueryClient, QueryClientProvider } from 'react-query' import { I18nextProvider } from 'react-i18next' import { Provider } from 'react-redux' +import { vi } from 'vitest' import { render, RenderResult } from '@testing-library/react' import { createStore } from 'redux' @@ -23,11 +24,11 @@ export function renderWithProviders( const { initialState = {}, i18nInstance = null } = options || {} const store: Store = createStore( - jest.fn(), + vi.fn(), initialState as PreloadedState ) - store.dispatch = jest.fn() - store.getState = jest.fn(() => initialState) as () => State + store.dispatch = vi.fn() + store.getState = vi.fn(() => initialState) as () => State const queryClient = new QueryClient() diff --git a/components/src/tooltips/__tests__/Tooltip.test.tsx b/components/src/tooltips/__tests__/Tooltip.test.tsx index c915b98bcec..257af16d8d2 100644 --- a/components/src/tooltips/__tests__/Tooltip.test.tsx +++ b/components/src/tooltips/__tests__/Tooltip.test.tsx @@ -1,3 +1,4 @@ +import { describe, it } from 'vitest' describe('hook-based Tooltip', () => { it.todo('replace deprecated enzyme test') }) diff --git a/components/src/tooltips/__tests__/useHoverTooltip.test.tsx b/components/src/tooltips/__tests__/useHoverTooltip.test.tsx index 64d4393d315..be1a50c7c62 100644 --- a/components/src/tooltips/__tests__/useHoverTooltip.test.tsx +++ b/components/src/tooltips/__tests__/useHoverTooltip.test.tsx @@ -1,3 +1,4 @@ +import { describe, it } from 'vitest' describe('useHoverTooltip', () => { it.todo('replace deprecated enzyme test') }) diff --git a/components/src/tooltips/__tests__/usePopper.test.tsx b/components/src/tooltips/__tests__/usePopper.test.tsx index addd1c29a00..898f97af4a8 100644 --- a/components/src/tooltips/__tests__/usePopper.test.tsx +++ b/components/src/tooltips/__tests__/usePopper.test.tsx @@ -1,3 +1,4 @@ +import { describe, it } from 'vitest' describe('usePopper hook', () => { it.todo('replace deprecated enzyme test') }) diff --git a/components/src/tooltips/__tests__/useTooltip.test.tsx b/components/src/tooltips/__tests__/useTooltip.test.tsx index 7bb78857da0..05e8df97fc0 100644 --- a/components/src/tooltips/__tests__/useTooltip.test.tsx +++ b/components/src/tooltips/__tests__/useTooltip.test.tsx @@ -1,3 +1,4 @@ +import { describe, it } from 'vitest' describe('useTooltip hook', () => { it.todo('replace deprecated enzyme test') }) diff --git a/shared-data/deck/index.ts b/shared-data/deck/index.ts index c2680e9aaac..e308d7a17ad 100644 --- a/shared-data/deck/index.ts +++ b/shared-data/deck/index.ts @@ -8,6 +8,8 @@ import ot2StandardDeckV4 from './definitions/4/ot2_standard.json' import ot2ShortFixedTrashDeckV4 from './definitions/4/ot2_short_trash.json' import ot3StandardDeckV4 from './definitions/4/ot3_standard.json' +import deckExample from './fixtures/3/deckExample.json' + import type { DeckDefinition } from '../js/types' export * from './types/schemaV4' @@ -19,6 +21,7 @@ export { ot2StandardDeckV4, ot2ShortFixedTrashDeckV4, ot3StandardDeckV4, + deckExample, } const latestDeckDefinitions = {