From df4764bd4bedb4d62ba9c5f835b6ffa010ba5d3f Mon Sep 17 00:00:00 2001 From: TamarZanzouri Date: Fri, 26 Apr 2024 14:20:02 -0400 Subject: [PATCH] fix(api): disallow hashing we using a fixit command (#15026) --- .../protocol_engine/commands/hash_command_params.py | 2 +- .../protocol_engine/commands/test_hash_command_params.py | 8 +++++--- 2 files changed, 6 insertions(+), 4 deletions(-) diff --git a/api/src/opentrons/protocol_engine/commands/hash_command_params.py b/api/src/opentrons/protocol_engine/commands/hash_command_params.py index c0b7d46cd47..1d124101d4c 100644 --- a/api/src/opentrons/protocol_engine/commands/hash_command_params.py +++ b/api/src/opentrons/protocol_engine/commands/hash_command_params.py @@ -28,7 +28,7 @@ def hash_protocol_command_params( The command hash, if the command is a protocol command. `None` if the command is a setup command. """ - if create.intent == CommandIntent.SETUP: + if create.intent in [CommandIntent.SETUP, CommandIntent.FIXIT]: return None # We avoid Python's built-in hash() function because it's not stable across # runs of the Python interpreter. (Jira RSS-215.) diff --git a/api/tests/opentrons/protocol_engine/commands/test_hash_command_params.py b/api/tests/opentrons/protocol_engine/commands/test_hash_command_params.py index 9988854a9d4..e881a13a9fb 100644 --- a/api/tests/opentrons/protocol_engine/commands/test_hash_command_params.py +++ b/api/tests/opentrons/protocol_engine/commands/test_hash_command_params.py @@ -1,4 +1,5 @@ """Tests for hash_command_params.""" +import pytest from opentrons.protocol_engine import CommandIntent from opentrons.protocol_engine import commands @@ -66,10 +67,11 @@ def test_repeated_commands() -> None: assert a_hash != b_hash -def test_setup_command() -> None: - """Setup commands should always hash to None.""" +@pytest.mark.parametrize("command_intent", [CommandIntent.SETUP, CommandIntent.FIXIT]) +def test_setup_and_fixit_command(command_intent: CommandIntent) -> None: + """Setup and fixit commands should always skip hashing.""" setup_command = commands.WaitForDurationCreate( params=commands.WaitForDurationParams(seconds=123), - intent=CommandIntent.SETUP, + intent=command_intent, ) assert hash_protocol_command_params(setup_command, None) is None