diff --git a/api/src/opentrons/protocol_engine/commands/save_position.py b/api/src/opentrons/protocol_engine/commands/save_position.py index 5e38b902058..a45937a73e8 100644 --- a/api/src/opentrons/protocol_engine/commands/save_position.py +++ b/api/src/opentrons/protocol_engine/commands/save_position.py @@ -26,6 +26,9 @@ class SavePositionParams(BaseModel): description="An optional ID to assign to this command instance. " "Auto-assigned if not defined.", ) + failOnNotHomed: Optional[bool] = Field( + True, descrption="Require all axes to be homed before saving position." + ) class SavePositionResult(BaseModel): @@ -58,8 +61,11 @@ def __init__( async def execute(self, params: SavePositionParams) -> SavePositionResult: """Check the requested pipette's current position.""" position_id = self._model_utils.ensure_id(params.positionId) + fail_on_not_homed = ( + params.failOnNotHomed if params.failOnNotHomed is not None else True + ) x, y, z = await self._gantry_mover.get_position( - pipette_id=params.pipetteId, fail_on_not_homed=True + pipette_id=params.pipetteId, fail_on_not_homed=fail_on_not_homed ) return SavePositionResult( diff --git a/api/tests/opentrons/protocol_engine/commands/test_save_position.py b/api/tests/opentrons/protocol_engine/commands/test_save_position.py index e31f44c779c..99b52a4cd42 100644 --- a/api/tests/opentrons/protocol_engine/commands/test_save_position.py +++ b/api/tests/opentrons/protocol_engine/commands/test_save_position.py @@ -35,10 +35,7 @@ async def test_save_position_implementation( subject = SavePositionImplementation( model_utils=mock_model_utils, gantry_mover=mock_gantry_mover ) - params = SavePositionParams( - pipetteId="abc", - positionId="123", - ) + params = SavePositionParams(pipetteId="abc", positionId="123", failOnNotHomed=True) decoy.when(mock_model_utils.ensure_id("123")).then_return("456") diff --git a/app/src/organisms/DropTipWizard/index.tsx b/app/src/organisms/DropTipWizard/index.tsx index d533c82ea8f..29a9e755a4a 100644 --- a/app/src/organisms/DropTipWizard/index.tsx +++ b/app/src/organisms/DropTipWizard/index.tsx @@ -292,6 +292,7 @@ export const DropTipWizardComponent = ( commandType: 'savePosition' as const, params: { pipetteId: MANAGED_PIPETTE_ID, + failOnNotHomed: false, }, }, ] diff --git a/shared-data/command/types/gantry.ts b/shared-data/command/types/gantry.ts index c119b63dd39..435188d948d 100644 --- a/shared-data/command/types/gantry.ts +++ b/shared-data/command/types/gantry.ts @@ -156,6 +156,7 @@ interface MoveRelativeParams { interface SavePositionParams { pipetteId: string // pipette to use in measurement positionId?: string // position ID, auto-assigned if left blank + failOnNotHomed?: boolean // Defaults to true if blank. Require every possible axis to be homed to save. } interface HomeParams {