From c479d4a607488e82c735ad50a53e0eebbe841536 Mon Sep 17 00:00:00 2001 From: koji Date: Thu, 29 Feb 2024 18:21:14 -0500 Subject: [PATCH] update the rest tests for vitest migration --- .../__tests__/LabwareListItem.test.tsx | 132 +++++++++--------- .../__tests__/OffDeckLabwareList.test.tsx | 21 +-- .../__tests__/SecureLabwareModal.test.tsx | 33 +++-- .../__tests__/SetupLabware.test.tsx | 97 +++++-------- .../ProtocolRun/__tests__/SetupStep.test.tsx | 30 ++-- .../SetupTipLengthCalibration.test.tsx | 81 +++++------ .../SetupTipLengthCalibrationButton.test.tsx | 43 +++--- 7 files changed, 203 insertions(+), 234 deletions(-) diff --git a/app/src/organisms/Devices/ProtocolRun/SetupLabware/__tests__/LabwareListItem.test.tsx b/app/src/organisms/Devices/ProtocolRun/SetupLabware/__tests__/LabwareListItem.test.tsx index 7dc7870b07f..267e27cc20e 100644 --- a/app/src/organisms/Devices/ProtocolRun/SetupLabware/__tests__/LabwareListItem.test.tsx +++ b/app/src/organisms/Devices/ProtocolRun/SetupLabware/__tests__/LabwareListItem.test.tsx @@ -1,9 +1,12 @@ import * as React from 'react' -import { fireEvent } from '@testing-library/react' -import { useCreateLiveCommandMutation } from '@opentrons/react-api-client' +import { fireEvent, screen } from '@testing-library/react' +import { describe, it, beforeEach, vi, expect } from 'vitest' import { StaticRouter } from 'react-router-dom' -import { renderWithProviders } from '@opentrons/components' -import fixture_adapter from '@opentrons/shared-data/labware/definitions/2/opentrons_96_pcr_adapter/1.json' + +import { opentrons96PcrAdapterV1 } from '@opentrons/shared-data' +import { useCreateLiveCommandMutation } from '@opentrons/react-api-client' + +import { renderWithProviders } from '../../../../../__testing-utils__' import { i18n } from '../../../../../i18n' import { mockHeaterShaker, @@ -24,17 +27,10 @@ import type { import type { AttachedModule } from '../../../../../redux/modules/types' import type { ModuleRenderInfoForProtocol } from '../../../hooks' -jest.mock('../SecureLabwareModal') -jest.mock('@opentrons/react-api-client') - -const mockSecureLabwareModal = SecureLabwareModal as jest.MockedFunction< - typeof SecureLabwareModal -> -const mockUseLiveCommandMutation = useCreateLiveCommandMutation as jest.MockedFunction< - typeof useCreateLiveCommandMutation -> +vi.mock('../SecureLabwareModal') +vi.mock('@opentrons/react-api-client') -const mockAdapterDef = fixture_adapter as LabwareDefinition2 +const mockAdapterDef = opentrons96PcrAdapterV1 as LabwareDefinition2 const mockAdapterId = 'mockAdapterId' const mockNestedLabwareDisplayName = 'nested labware display name' const mockLocationInfo = { @@ -82,17 +78,19 @@ const render = (props: React.ComponentProps) => { } describe('LabwareListItem', () => { - const mockCreateLiveCommand = jest.fn() + const mockCreateLiveCommand = vi.fn() beforeEach(() => { mockCreateLiveCommand.mockResolvedValue(null) - mockSecureLabwareModal.mockReturnValue(
mock secure labware modal
) - mockUseLiveCommandMutation.mockReturnValue({ + vi.mocked(SecureLabwareModal).mockReturnValue( +
mock secure labware modal
+ ) + vi.mocked(useCreateLiveCommandMutation).mockReturnValue({ createLiveCommand: mockCreateLiveCommand, } as any) }) it('renders the correct info for a thermocycler (OT2), clicking on secure labware instructions opens the modal', () => { - const { getByText } = render({ + render({ commands: [], nickName: mockNickName, definition: mockLabwareDef, @@ -111,18 +109,18 @@ describe('LabwareListItem', () => { isFlex: false, nestedLabwareInfo: null, }) - getByText('Mock Labware Definition') - getByText('nickName') - getByText('Thermocycler Module GEN1') - getByText('7,8,10,11') - const button = getByText('Secure labware instructions') + screen.getByText('Mock Labware Definition') + screen.getByText('nickName') + screen.getByText('Thermocycler Module GEN1') + screen.getByText('7,8,10,11') + const button = screen.getByText('Secure labware instructions') fireEvent.click(button) - getByText('mock secure labware modal') - getByText('nickName') + screen.getByText('mock secure labware modal') + screen.getByText('nickName') }) it('renders the correct info for a thermocycler (OT3)', () => { - const { getByText } = render({ + render({ commands: [], nickName: mockNickName, definition: mockLabwareDef, @@ -141,13 +139,13 @@ describe('LabwareListItem', () => { isFlex: true, nestedLabwareInfo: null, }) - getByText('Mock Labware Definition') - getByText('A1+B1') - getByText('Thermocycler Module GEN1') + screen.getByText('Mock Labware Definition') + screen.getByText('A1+B1') + screen.getByText('Thermocycler Module GEN1') }) it('renders the correct info for a labware on top of a magnetic module', () => { - const { getByText, getByTestId } = render({ + render({ commands: [], nickName: mockNickName, definition: mockLabwareDef, @@ -172,17 +170,17 @@ describe('LabwareListItem', () => { isFlex: false, nestedLabwareInfo: null, }) - getByText('Mock Labware Definition') - getByTestId('slot_info_7') - getByText('Magnetic Module GEN1') - const button = getByText('Secure labware instructions') + screen.getByText('Mock Labware Definition') + screen.getByTestId('slot_info_7') + screen.getByText('Magnetic Module GEN1') + const button = screen.getByText('Secure labware instructions') fireEvent.click(button) - getByText('mock secure labware modal') - getByText('nickName') + screen.getByText('mock secure labware modal') + screen.getByText('nickName') }) it('renders the correct info for a labware on top of a temperature module', () => { - const { getByText, getByTestId } = render({ + render({ commands: [], nickName: mockNickName, definition: mockLabwareDef, @@ -206,10 +204,10 @@ describe('LabwareListItem', () => { isFlex: false, nestedLabwareInfo: null, }) - getByText('Mock Labware Definition') - getByTestId('slot_info_7') - getByText('Temperature Module GEN1') - getByText('nickName') + screen.getByText('Mock Labware Definition') + screen.getByTestId('slot_info_7') + screen.getByText('Temperature Module GEN1') + screen.getByText('nickName') }) it('renders the correct info for a labware on an adapter on top of a temperature module', () => { @@ -240,7 +238,7 @@ describe('LabwareListItem', () => { }, } as any - const { getByText, getAllByText } = render({ + render({ commands: [mockAdapterLoadCommand, mockModuleLoadCommand], nickName: mockNickName, definition: mockLabwareDef, @@ -269,12 +267,12 @@ describe('LabwareListItem', () => { nestedLabwareDefinition: mockLabwareDef, }, }) - getByText('Mock Labware Definition') - getAllByText('7') - getByText('Temperature Module GEN2') - getByText('mock nested display name') - getByText('nestedLabwareNickName') - getByText('nickName') + screen.getByText('Mock Labware Definition') + screen.getAllByText('7') + screen.getByText('Temperature Module GEN2') + screen.getByText('mock nested display name') + screen.getByText('nestedLabwareNickName') + screen.getByText('nickName') }) it('renders the correct info for a labware on an adapter on the deck', () => { @@ -294,7 +292,7 @@ describe('LabwareListItem', () => { }, } as any - const { getByText } = render({ + render({ commands: [mockAdapterLoadCommand], nickName: mockNickName, definition: mockLabwareDef, @@ -311,16 +309,16 @@ describe('LabwareListItem', () => { nestedLabwareDefinition: mockLabwareDef, }, }) - getByText('Mock Labware Definition') - getByText('A2') - getByText('mock nested display name') - getByText('nestedLabwareNickName') - getByText('nickName') - getByText('On deck') + screen.getByText('Mock Labware Definition') + screen.getByText('A2') + screen.getByText('mock nested display name') + screen.getByText('nestedLabwareNickName') + screen.getByText('nickName') + screen.getByText('On deck') }) it('renders the correct info for a labware on top of a heater shaker', () => { - const { getByText, getByLabelText, getByTestId } = render({ + render({ nickName: mockNickName, commands: [], definition: mockLabwareDef, @@ -344,14 +342,14 @@ describe('LabwareListItem', () => { isFlex: false, nestedLabwareInfo: null, }) - getByText('Mock Labware Definition') - getByTestId('slot_info_7') - getByText('Heater-Shaker Module GEN1') - getByText('nickName') - getByText('To add labware, use the toggle to control the latch') - getByText('Labware Latch') - getByText('Secure') - const button = getByLabelText('heater_shaker_7_latch_toggle') + screen.getByText('Mock Labware Definition') + screen.getByTestId('slot_info_7') + screen.getByText('Heater-Shaker Module GEN1') + screen.getByText('nickName') + screen.getByText('To add labware, use the toggle to control the latch') + screen.getByText('Labware Latch') + screen.getByText('Secure') + const button = screen.getByLabelText('heater_shaker_7_latch_toggle') fireEvent.click(button) expect(mockCreateLiveCommand).toHaveBeenCalledWith({ command: { @@ -364,7 +362,7 @@ describe('LabwareListItem', () => { }) it('renders the correct info for an off deck labware', () => { - const { getByText } = render({ + render({ nickName: null, definition: mockLabwareDef, initialLocation: 'offDeck', @@ -376,7 +374,7 @@ describe('LabwareListItem', () => { isFlex: false, nestedLabwareInfo: null, }) - getByText('Mock Labware Definition') - getByText('Off deck') + screen.getByText('Mock Labware Definition') + screen.getByText('Off deck') }) }) diff --git a/app/src/organisms/Devices/ProtocolRun/SetupLabware/__tests__/OffDeckLabwareList.test.tsx b/app/src/organisms/Devices/ProtocolRun/SetupLabware/__tests__/OffDeckLabwareList.test.tsx index 436472fdcee..4e8d3cb9912 100644 --- a/app/src/organisms/Devices/ProtocolRun/SetupLabware/__tests__/OffDeckLabwareList.test.tsx +++ b/app/src/organisms/Devices/ProtocolRun/SetupLabware/__tests__/OffDeckLabwareList.test.tsx @@ -1,16 +1,15 @@ import * as React from 'react' import { StaticRouter } from 'react-router-dom' -import { renderWithProviders } from '@opentrons/components' +import { screen } from '@testing-library/react' +import { describe, it, beforeEach, vi, expect } from 'vitest' + +import { renderWithProviders } from '../../../../../__testing-utils__' import { i18n } from '../../../../../i18n' import { mockLabwareDef } from '../../../../LabwarePositionCheck/__fixtures__/mockLabwareDef' import { LabwareListItem } from '../LabwareListItem' import { OffDeckLabwareList } from '../OffDeckLabwareList' -jest.mock('../LabwareListItem') - -const mockLabwareListItem = LabwareListItem as jest.MockedFunction< - typeof LabwareListItem -> +vi.mock('../LabwareListItem') const render = (props: React.ComponentProps) => { return renderWithProviders( @@ -25,7 +24,9 @@ const render = (props: React.ComponentProps) => { describe('OffDeckLabwareList', () => { beforeEach(() => { - mockLabwareListItem.mockReturnValue(
mock labware list item
) + vi.mocked(LabwareListItem).mockReturnValue( +
mock labware list item
+ ) }) it('renders null if labware items is null', () => { const { container } = render({ @@ -36,7 +37,7 @@ describe('OffDeckLabwareList', () => { expect(container.firstChild).toBeNull() }) it('renders additional offdeck labware info if there is an offdeck labware', () => { - const { getByText } = render({ + render({ labwareItems: [ { nickName: 'nickName', @@ -49,7 +50,7 @@ describe('OffDeckLabwareList', () => { isFlex: false, commands: [], }) - getByText('Additional Off-Deck Labware') - getByText('mock labware list item') + screen.getByText('Additional Off-Deck Labware') + screen.getByText('mock labware list item') }) }) diff --git a/app/src/organisms/Devices/ProtocolRun/SetupLabware/__tests__/SecureLabwareModal.test.tsx b/app/src/organisms/Devices/ProtocolRun/SetupLabware/__tests__/SecureLabwareModal.test.tsx index 3f51c4702b7..9372114973f 100644 --- a/app/src/organisms/Devices/ProtocolRun/SetupLabware/__tests__/SecureLabwareModal.test.tsx +++ b/app/src/organisms/Devices/ProtocolRun/SetupLabware/__tests__/SecureLabwareModal.test.tsx @@ -1,6 +1,8 @@ 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 { renderWithProviders } from '../../../../../__testing-utils__' import { i18n } from '../../../../../i18n' import { SecureLabwareModal } from '../SecureLabwareModal' @@ -15,15 +17,16 @@ const mockTypeTC = 'thermocyclerModuleType' describe('SecureLabwareModal', () => { let props: React.ComponentProps beforeEach(() => { - props = { type: mockTypeMagDeck, onCloseClick: jest.fn() } + props = { type: mockTypeMagDeck, onCloseClick: vi.fn() } }) + it('should render the correct modal for magnetic module type', () => { - const { getByText } = render(props) - getByText('Securing labware to the Magnetic Module') - getByText( + render(props) + screen.getByText('Securing labware to the Magnetic Module') + screen.getByText( 'Opentrons recommends ensuring your labware locks to the Magnetic Module by adjusting the black plate bracket on top of the module.' ) - getByText( + screen.getByText( 'Please note there are two sizes of plate brackets supplied with your module: standard and deep well. These brackets can be removed and swapped by unscrewing the modules thumb screw (the silver knob on the front).' ) }) @@ -34,19 +37,21 @@ describe('SecureLabwareModal', () => { fireEvent.click(closeButton) expect(props.onCloseClick).toHaveBeenCalled() }) + it('should render the correct modal for thermocycler module type', () => { - props = { type: mockTypeTC, onCloseClick: jest.fn() } - const { getByText } = render(props) - getByText('Securing labware to the Thermocycler') - getByText( + props = { type: mockTypeTC, onCloseClick: vi.fn() } + render(props) + screen.getByText('Securing labware to the Thermocycler') + screen.getByText( 'Opentrons recommends securing your labware to the Thermocycler module by closing its latch. Doing so ensures level and accurate plate placement for optimal results.' ) }) + it('should render tc module type modal and call onCloseClick when button is pressed', () => { - props = { type: mockTypeTC, onCloseClick: jest.fn() } - const { getByRole } = render(props) + props = { type: mockTypeTC, onCloseClick: vi.fn() } + render(props) expect(props.onCloseClick).not.toHaveBeenCalled() - const closeButton = getByRole('button', { name: 'close' }) + const closeButton = screen.getByRole('button', { name: 'close' }) fireEvent.click(closeButton) expect(props.onCloseClick).toHaveBeenCalled() }) diff --git a/app/src/organisms/Devices/ProtocolRun/SetupLabware/__tests__/SetupLabware.test.tsx b/app/src/organisms/Devices/ProtocolRun/SetupLabware/__tests__/SetupLabware.test.tsx index 7e88284a87b..49b824248b6 100644 --- a/app/src/organisms/Devices/ProtocolRun/SetupLabware/__tests__/SetupLabware.test.tsx +++ b/app/src/organisms/Devices/ProtocolRun/SetupLabware/__tests__/SetupLabware.test.tsx @@ -1,9 +1,10 @@ import * as React from 'react' -import { when, resetAllWhenMocks } from 'jest-when' import { StaticRouter } from 'react-router-dom' -import { fireEvent } from '@testing-library/react' +import { fireEvent, screen } from '@testing-library/react' +import { describe, it, beforeEach, vi, afterEach, expect } from 'vitest' +import { when } from 'vitest-when' -import { renderWithProviders } from '@opentrons/components' +import { renderWithProviders } from '../../../../../__testing-utils__' import { i18n } from '../../../../../i18n' import { useLPCSuccessToast } from '../../../hooks/useLPCSuccessToast' import { LabwarePositionCheck } from '../../../../LabwarePositionCheck' @@ -19,45 +20,15 @@ import { SetupLabwareList } from '../SetupLabwareList' import { SetupLabwareMap } from '../SetupLabwareMap' import { SetupLabware } from '..' -jest.mock('../SetupLabwareList') -jest.mock('../SetupLabwareMap') -jest.mock('../../../../LabwarePositionCheck') -jest.mock('../../utils/getModuleTypesThatRequireExtraAttention') -jest.mock('../../../../RunTimeControl/hooks') -jest.mock('../../../../../redux/config') -jest.mock('../../../hooks') -jest.mock('../../../hooks/useLPCSuccessToast') +vi.mock('../SetupLabwareList') +vi.mock('../SetupLabwareMap') +vi.mock('../../../../LabwarePositionCheck') +vi.mock('../../utils/getModuleTypesThatRequireExtraAttention') +vi.mock('../../../../RunTimeControl/hooks') +vi.mock('../../../../../redux/config') +vi.mock('../../../hooks') +vi.mock('../../../hooks/useLPCSuccessToast') -const mockGetModuleTypesThatRequireExtraAttention = getModuleTypesThatRequireExtraAttention as jest.MockedFunction< - typeof getModuleTypesThatRequireExtraAttention -> -const mockLabwarePostionCheck = LabwarePositionCheck as jest.MockedFunction< - typeof LabwarePositionCheck -> -const mockUseRunHasStarted = useRunHasStarted as jest.MockedFunction< - typeof useRunHasStarted -> -const mockUseUnmatchedModulesForProtocol = useUnmatchedModulesForProtocol as jest.MockedFunction< - typeof useUnmatchedModulesForProtocol -> -const mockUseRunCalibrationStatus = useRunCalibrationStatus as jest.MockedFunction< - typeof useRunCalibrationStatus -> -const mockGetIsLabwareOffsetCodeSnippetsOn = getIsLabwareOffsetCodeSnippetsOn as jest.MockedFunction< - typeof getIsLabwareOffsetCodeSnippetsOn -> -const mockUseLPCSuccessToast = useLPCSuccessToast as jest.MockedFunction< - typeof useLPCSuccessToast -> -const mockSetupLabwareList = SetupLabwareList as jest.MockedFunction< - typeof SetupLabwareList -> -const mockSetupLabwareMap = SetupLabwareMap as jest.MockedFunction< - typeof SetupLabwareMap -> -const mockUseLPCDisabledReason = useLPCDisabledReason as jest.MockedFunction< - typeof useLPCDisabledReason -> const ROBOT_NAME = 'otie' const RUN_ID = '1' @@ -68,7 +39,7 @@ const render = () => { robotName={ROBOT_NAME} runId={RUN_ID} protocolRunHeaderRef={null} - expandStep={jest.fn()} + expandStep={vi.fn()} nextStep={'liquid_setup_step'} /> , @@ -80,48 +51,50 @@ const render = () => { describe('SetupLabware', () => { beforeEach(() => { - when(mockGetModuleTypesThatRequireExtraAttention) + when(vi.mocked(getModuleTypesThatRequireExtraAttention)) .calledWith(expect.anything()) - .mockReturnValue([]) + .thenReturn([]) - when(mockLabwarePostionCheck).mockReturnValue( + vi.mocked(LabwarePositionCheck).mockReturnValue(
mock Labware Position Check
) - when(mockUseUnmatchedModulesForProtocol) + when(vi.mocked(useUnmatchedModulesForProtocol)) .calledWith(ROBOT_NAME, RUN_ID) - .mockReturnValue({ + .thenReturn({ missingModuleIds: [], remainingAttachedModules: [], }) - when(mockUseLPCSuccessToast) + when(vi.mocked(useLPCSuccessToast)) .calledWith() - .mockReturnValue({ setIsShowingLPCSuccessToast: jest.fn() }) + .thenReturn({ setIsShowingLPCSuccessToast: vi.fn() }) - when(mockUseRunCalibrationStatus) + when(vi.mocked(useRunCalibrationStatus)) .calledWith(ROBOT_NAME, RUN_ID) - .mockReturnValue({ + .thenReturn({ complete: true, }) - when(mockUseRunHasStarted).calledWith(RUN_ID).mockReturnValue(false) - when(mockGetIsLabwareOffsetCodeSnippetsOn).mockReturnValue(false) - when(mockSetupLabwareMap).mockReturnValue(
mock setup labware map
) - when(mockSetupLabwareList).mockReturnValue( + when(vi.mocked(useRunHasStarted)).calledWith(RUN_ID).thenReturn(false) + vi.mocked(getIsLabwareOffsetCodeSnippetsOn).mockReturnValue(false) + vi.mocked(SetupLabwareMap).mockReturnValue( +
mock setup labware map
+ ) + vi.mocked(SetupLabwareList).mockReturnValue(
mock setup labware list
) - when(mockUseLPCDisabledReason).mockReturnValue(null) + vi.mocked(useLPCDisabledReason).mockReturnValue(null) }) afterEach(() => { - resetAllWhenMocks() + vi.resetAllMocks() }) it('should render the list view, clicking the toggle button will turn to map view', () => { - const { getByText, getByRole } = render() - getByText('mock setup labware list') - getByRole('button', { name: 'List View' }) - const mapView = getByRole('button', { name: 'Map View' }) + render() + screen.getByText('mock setup labware list') + screen.getByRole('button', { name: 'List View' }) + const mapView = screen.getByRole('button', { name: 'Map View' }) fireEvent.click(mapView) - getByText('mock setup labware map') + screen.getByText('mock setup labware map') }) }) diff --git a/app/src/organisms/Devices/ProtocolRun/__tests__/SetupStep.test.tsx b/app/src/organisms/Devices/ProtocolRun/__tests__/SetupStep.test.tsx index eaecc41a8ff..424ad318faa 100644 --- a/app/src/organisms/Devices/ProtocolRun/__tests__/SetupStep.test.tsx +++ b/app/src/organisms/Devices/ProtocolRun/__tests__/SetupStep.test.tsx @@ -1,8 +1,8 @@ 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, afterEach, expect } from 'vitest' +import { renderWithProviders } from '../../../../__testing-utils__' import { i18n } from '../../../../i18n' import { SetupStep } from '../SetupStep' @@ -31,30 +31,30 @@ describe('SetupStep', () => { { i18nInstance: i18n } )[0] } - let toggleExpandedMock: jest.MockedFunction<() => void> + let toggleExpandedMock: vi.MockedFunction<() => void> beforeEach(() => { - toggleExpandedMock = jest.fn() + toggleExpandedMock = vi.fn() }) afterEach(() => { - jest.resetAllMocks() + vi.resetAllMocks() }) it('renders children', () => { - const { getByRole } = render() - getByRole('button', { name: 'stub children' }) + render() + screen.getByRole('button', { name: 'stub children' }) }) it('calls toggle expanded on click', () => { - const { getByText } = render({ expanded: false }) - fireEvent.click(getByText('stub title')) + render({ expanded: false }) + fireEvent.click(screen.getByText('stub title')) expect(toggleExpandedMock).toHaveBeenCalled() }) it('renders text nodes with prop contents', () => { - const { getByText, queryAllByText } = render({ expanded: false }) - getByText('stub label') - getByText('stub title') - queryAllByText('stub description') - queryAllByText('right element') + render({ expanded: false }) + screen.getByText('stub label') + screen.getByText('stub title') + screen.queryAllByText('stub description') + screen.queryAllByText('right element') }) }) diff --git a/app/src/organisms/Devices/ProtocolRun/__tests__/SetupTipLengthCalibration.test.tsx b/app/src/organisms/Devices/ProtocolRun/__tests__/SetupTipLengthCalibration.test.tsx index 522ec25c36b..f0e796dbf67 100644 --- a/app/src/organisms/Devices/ProtocolRun/__tests__/SetupTipLengthCalibration.test.tsx +++ b/app/src/organisms/Devices/ProtocolRun/__tests__/SetupTipLengthCalibration.test.tsx @@ -1,8 +1,9 @@ import * as React from 'react' -import { when, resetAllWhenMocks } from 'jest-when' - -import { renderWithProviders } from '@opentrons/components' +import { when } from 'vitest-when' +import { describe, it, beforeEach, vi, afterEach, expect } from 'vitest' +import { screen } from '@testing-library/react' +import { renderWithProviders } from '../../../../__testing-utils__' import { i18n } from '../../../../i18n' import { mockTipRackDefinition } from '../../../../redux/custom-labware/__fixtures__' import { useRunPipetteInfoByMount } from '../../hooks' @@ -11,20 +12,12 @@ import { SetupTipLengthCalibration } from '../SetupTipLengthCalibration' import type { PipetteInfo } from '../../hooks' -jest.mock('../../../../redux/config') -jest.mock('../../hooks') -jest.mock('../SetupTipLengthCalibrationButton') - -const mockUseRunPipetteInfoByMount = useRunPipetteInfoByMount as jest.MockedFunction< - typeof useRunPipetteInfoByMount -> -const mockSetupTipLengthCalibrationButton = SetupTipLengthCalibrationButton as jest.MockedFunction< - typeof SetupTipLengthCalibrationButton -> +vi.mock('../../../../redux/config') +vi.mock('../../hooks') +vi.mock('../SetupTipLengthCalibrationButton') const ROBOT_NAME = 'otie' const RUN_ID = '1' - const PIPETTE_INFO = { requestedPipetteMatch: 'incompatible', pipetteCalDate: null, @@ -51,52 +44,60 @@ const render = () => { describe('SetupTipLengthCalibration', () => { beforeEach(() => { - when(mockUseRunPipetteInfoByMount).calledWith(RUN_ID).mockReturnValue({ + when(vi.mocked(useRunPipetteInfoByMount)).calledWith(RUN_ID).thenReturn({ left: PIPETTE_INFO, right: null, }) - when(mockSetupTipLengthCalibrationButton).mockReturnValue( + vi.mocked(SetupTipLengthCalibrationButton).mockReturnValue(
Mock SetupTipLengthCalibrationButton
) }) afterEach(() => { - resetAllWhenMocks() + vi.resetAllMocks() }) it('renders required tip length calibrations title', () => { - const { getByText } = render() - getByText('Required Tip Length Calibrations') + render() + screen.getByText('Required Tip Length Calibrations') }) it('renders the pipette and tip rack name', () => { - const { getAllByText, queryByText } = render() + render() - expect(getAllByText('pipette 1')).toHaveLength(1) - expect(getAllByText('Mock TipRack Definition')).toHaveLength(1) - expect(getAllByText('Mock SetupTipLengthCalibrationButton')).toHaveLength(1) + expect(screen.getAllByText('pipette 1')).toHaveLength(1) + expect(screen.getAllByText('Mock TipRack Definition')).toHaveLength(1) expect( - getAllByText('Attach pipette to see tip length calibration information') + screen.getAllByText('Mock SetupTipLengthCalibrationButton') ).toHaveLength(1) - expect(queryByText('Last calibrated:')).toBeFalsy() + expect( + screen.getAllByText( + 'Attach pipette to see tip length calibration information' + ) + ).toHaveLength(1) + expect(screen.queryByText('Last calibrated:')).toBeFalsy() }) it('renders two tip length calibrations when protocol run requires two pipettes', () => { - when(mockUseRunPipetteInfoByMount).calledWith(RUN_ID).mockReturnValue({ + when(vi.mocked(useRunPipetteInfoByMount)).calledWith(RUN_ID).thenReturn({ left: PIPETTE_INFO, right: PIPETTE_INFO, }) - const { getAllByText, queryByText } = render() + render() - expect(getAllByText('pipette 1')).toHaveLength(2) - expect(getAllByText('Mock TipRack Definition')).toHaveLength(2) - expect(getAllByText('Mock SetupTipLengthCalibrationButton')).toHaveLength(2) + expect(screen.getAllByText('pipette 1')).toHaveLength(2) + expect(screen.getAllByText('Mock TipRack Definition')).toHaveLength(2) + expect( + screen.getAllByText('Mock SetupTipLengthCalibrationButton') + ).toHaveLength(2) expect( - getAllByText('Attach pipette to see tip length calibration information') + screen.getAllByText( + 'Attach pipette to see tip length calibration information' + ) ).toHaveLength(2) - expect(queryByText('Last calibrated:')).toBeFalsy() + expect(screen.queryByText('Last calibrated:')).toBeFalsy() }) it('renders last calibrated date when available', () => { - when(mockUseRunPipetteInfoByMount) + when(vi.mocked(useRunPipetteInfoByMount)) .calledWith(RUN_ID) - .mockReturnValue({ + .thenReturn({ left: { ...PIPETTE_INFO, requestedPipetteMatch: 'match', @@ -111,20 +112,20 @@ describe('SetupTipLengthCalibration', () => { right: null, }) - const { getAllByText } = render() - expect(getAllByText('Last calibrated: yesterday')).toHaveLength(1) + render() + expect(screen.getAllByText('Last calibrated: yesterday')).toHaveLength(1) }) it('renders not calibrated yet when not calibrated', () => { - when(mockUseRunPipetteInfoByMount) + when(vi.mocked(useRunPipetteInfoByMount)) .calledWith(RUN_ID) - .mockReturnValue({ + .thenReturn({ left: { ...PIPETTE_INFO, requestedPipetteMatch: 'match', }, right: null, }) - const { getAllByText } = render() - expect(getAllByText('Not calibrated yet')).toHaveLength(1) + render() + expect(screen.getAllByText('Not calibrated yet')).toHaveLength(1) }) }) diff --git a/app/src/organisms/Devices/ProtocolRun/__tests__/SetupTipLengthCalibrationButton.test.tsx b/app/src/organisms/Devices/ProtocolRun/__tests__/SetupTipLengthCalibrationButton.test.tsx index ef61645c0c1..e0951ae689f 100644 --- a/app/src/organisms/Devices/ProtocolRun/__tests__/SetupTipLengthCalibrationButton.test.tsx +++ b/app/src/organisms/Devices/ProtocolRun/__tests__/SetupTipLengthCalibrationButton.test.tsx @@ -1,9 +1,11 @@ import * as React from 'react' -import { when, resetAllWhenMocks } from 'jest-when' +import { when } from 'vitest-when' import { screen, fireEvent } from '@testing-library/react' -import { renderWithProviders } from '@opentrons/components' -import fixture_tiprack_300_ul from '@opentrons/shared-data/labware/fixtures/2/fixture_tiprack_300_ul.json' +import { describe, it, beforeEach, vi, afterEach, expect } from 'vitest' +import { fixtureTiprack300ul } from '@opentrons/shared-data' + +import { renderWithProviders } from '../../../../__testing-utils__' import { i18n } from '../../../../i18n' import { mockDeckCalData } from '../../../../redux/calibration/__fixtures__' import { mockTipLengthCalLauncher } from '../../hooks/__fixtures__/taskListFixtures' @@ -13,24 +15,14 @@ import { SetupTipLengthCalibrationButton } from '../SetupTipLengthCalibrationBut import type { LabwareDefinition2 } from '@opentrons/shared-data' -jest.mock('@opentrons/components/src/hooks') -jest.mock('../../../../organisms/RunTimeControl/hooks') -jest.mock( +vi.mock('@opentrons/components/src/hooks') +vi.mock('../../../../organisms/RunTimeControl/hooks') +vi.mock( '../../../../pages/Devices/CalibrationDashboard/hooks/useDashboardCalibrateTipLength' ) -jest.mock('../../../../redux/config') -jest.mock('../../../../redux/sessions/selectors') -jest.mock('../../hooks') - -const mockUseRunHasStarted = useRunHasStarted as jest.MockedFunction< - typeof useRunHasStarted -> -const mockUseDeckCalibrationData = useDeckCalibrationData as jest.MockedFunction< - typeof useDeckCalibrationData -> -const mockUseDashboardCalibrateTipLength = useDashboardCalibrateTipLength as jest.MockedFunction< - typeof useDashboardCalibrateTipLength -> +vi.mock('../../../../redux/config') +vi.mock('../../../../redux/sessions/selectors') +vi.mock('../../hooks') const ROBOT_NAME = 'otie' const RUN_ID = '1' @@ -42,7 +34,7 @@ describe('SetupTipLengthCalibrationButton', () => { robotName = ROBOT_NAME, runId = RUN_ID, hasCalibrated = false, - tipRackDefinition = fixture_tiprack_300_ul as LabwareDefinition2, + tipRackDefinition = fixtureTiprack300ul as LabwareDefinition2, isExtendedPipOffset = false, }: Partial< React.ComponentProps @@ -64,20 +56,19 @@ describe('SetupTipLengthCalibrationButton', () => { } beforeEach(() => { - when(mockUseRunHasStarted).calledWith(RUN_ID).mockReturnValue(false) - when(mockUseDeckCalibrationData).calledWith(ROBOT_NAME).mockReturnValue({ + when(vi.mocked(useRunHasStarted)).calledWith(RUN_ID).thenReturn(false) + when(vi.mocked(useDeckCalibrationData)).calledWith(ROBOT_NAME).thenReturn({ deckCalibrationData: mockDeckCalData, isDeckCalibrated: true, }) - mockUseDashboardCalibrateTipLength.mockReturnValue([ + vi.mocked(useDashboardCalibrateTipLength).mockReturnValue([ mockTipLengthCalLauncher, null, ]) }) afterEach(() => { - resetAllWhenMocks() - jest.resetAllMocks() + vi.resetAllMocks() }) it('renders the calibrate now button if tip length not calibrated', () => { @@ -105,7 +96,7 @@ describe('SetupTipLengthCalibrationButton', () => { }) it('disables the recalibrate link if tip length calibrated and run started', () => { - when(mockUseRunHasStarted).calledWith(RUN_ID).mockReturnValue(true) + when(vi.mocked(useRunHasStarted)).calledWith(RUN_ID).thenReturn(true) render({ hasCalibrated: true }) const recalibrate = screen.getByText('Recalibrate') fireEvent.click(recalibrate)