Skip to content

Commit

Permalink
fixed hashing bug, added test
Browse files Browse the repository at this point in the history
  • Loading branch information
sanni-t committed Apr 26, 2024
1 parent 264883a commit d6f2f9f
Show file tree
Hide file tree
Showing 2 changed files with 120 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -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.PROTOCOL:
if create.intent == CommandIntent.SETUP:
return None
# We avoid Python's built-in hash() function because it's not stable across
# runs of the Python interpreter. (Jira RSS-215.)
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,119 @@
test_name: Test that command keys in analysis and protocol run match for a deterministic protocol running using protocol engine

marks:
- usefixtures:
- ot2_server_base_url

stages:
- name: Upload a protocol
request:
url: '{ot2_server_base_url}/protocols'
method: POST
files:
files: 'tests/integration/protocols/basic_transfer_with_run_time_parameters.py'
response:
save:
json:
protocol_id: data.id
analysis_id: data.analysisSummaries[0].id
strict:
- json:off
status_code: 201

- name: Save command keys from protocol analysis
max_retries: 5
delay_after: 1
request:
url: '{ot2_server_base_url}/protocols/{protocol_id}/analyses/{analysis_id}'
response:
save:
json:
analysis_data: data
home_cmd_key: data.commands[0].key
plate_load_key: data.commands[1].key
pipette_load_key: data.commands[3].key
pick_up_tip_key: data.commands[4].key
drop_tip_key: data.commands[7].key
strict:
- json:off
json:
data:
id: '{analysis_id}'
commands:
- commandType: loadPipette

- name: Create run from protocol
request:
url: '{ot2_server_base_url}/runs'
method: POST
json:
data:
protocolId: '{protocol_id}'
response:
status_code: 201
save:
json:
original_run_data: data
run_id: data.id

- name: Play the run
request:
url: '{ot2_server_base_url}/runs/{run_id}/actions'
method: POST
json:
data:
actionType: play
response:
status_code: 201

- name: Wait for the protocol to complete
max_retries: 5
delay_after: 1
request:
url: '{ot2_server_base_url}/runs/{run_id}'
method: GET
response:
status_code: 200
strict:
- json:off
json:
data:
status: succeeded

- name: Verify commands have keys identical to their counterparts in analysis
request:
url: '{ot2_server_base_url}/runs/{run_id}/commands'
method: GET
response:
strict:
- json:off
status_code: 200
json:
links:
current:
href: !anystr
meta:
runId: !anystr
commandId: !anystr
index: 7
key: !anystr
createdAt: !anystr
meta:
cursor: 0
totalLength: 8
data:
- id: !anystr
key: '{home_cmd_key}'
commandType: home
- id: !anystr
key: '{plate_load_key}'
commandType: loadLabware
- id: !anystr
key: '{pipette_load_key}'
commandType: loadPipette
- id: !anystr
key: '{pick_up_tip_key}'
commandType: pickUpTip
- id: !anystr
key: '{drop_tip_key}'
commandType: dropTip

0 comments on commit d6f2f9f

Please sign in to comment.