From 38215947303b118b7167a03ebbdc0e091921348e Mon Sep 17 00:00:00 2001 From: Jethary Alcid <66035149+jerader@users.noreply.github.com> Date: Tue, 3 Dec 2024 10:28:25 -0500 Subject: [PATCH 01/23] fix(step-generation): fix blowout location from multi-dispense disposal (#17013) closes RESC-356 This PR fixes a bug where the blowout tip position associated with a multi-dispense disposal was not properly wired up. This resulted in the blowout position to always be at the top of the well which caused users issues. --- .../formLevel/stepFormToArgs/moveLiquidFormToArgs.ts | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/protocol-designer/src/steplist/formLevel/stepFormToArgs/moveLiquidFormToArgs.ts b/protocol-designer/src/steplist/formLevel/stepFormToArgs/moveLiquidFormToArgs.ts index b77cd8a8f2e..4ee644679dc 100644 --- a/protocol-designer/src/steplist/formLevel/stepFormToArgs/moveLiquidFormToArgs.ts +++ b/protocol-designer/src/steplist/formLevel/stepFormToArgs/moveLiquidFormToArgs.ts @@ -166,7 +166,13 @@ export const moveLiquidFormToArgs = ( 'dispense_delay_mmFromBottom' ) const blowoutLocation = - (fields.blowout_checkbox && fields.blowout_location) || null + (fields.blowout_checkbox && fields.blowout_location) || + (fields.disposalVolume_checkbox && + path === 'multiDispense' && + fields.disposalVolume_volume && + fields.blowout_location) || + null + const blowoutOffsetFromTopMm = blowoutLocation != null ? blowout_z_offset ?? DEFAULT_MM_BLOWOUT_OFFSET_FROM_TOP From 8b98b5fdfe2bf6e12364a94202078c1c1953f2c7 Mon Sep 17 00:00:00 2001 From: Jethary Alcid <66035149+jerader@users.noreply.github.com> Date: Tue, 3 Dec 2024 15:48:03 -0500 Subject: [PATCH 02/23] =?UTF-8?q?fix(protocol-designer):=20assign=20value?= =?UTF-8?q?=20instead=20of=20name=20from=20wellOrder=20f=E2=80=A6=20(#1701?= =?UTF-8?q?7)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit …ields closes RQA-3737 --- .../ProtocolSteps/BatchEditToolbox/BatchEditMixTools.tsx | 4 ++-- .../BatchEditToolbox/BatchEditMoveLiquidTools.tsx | 4 ++-- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/protocol-designer/src/pages/Designer/ProtocolSteps/BatchEditToolbox/BatchEditMixTools.tsx b/protocol-designer/src/pages/Designer/ProtocolSteps/BatchEditToolbox/BatchEditMixTools.tsx index 6f39f7ff632..1aa64e02057 100644 --- a/protocol-designer/src/pages/Designer/ProtocolSteps/BatchEditToolbox/BatchEditMixTools.tsx +++ b/protocol-designer/src/pages/Designer/ProtocolSteps/BatchEditToolbox/BatchEditMixTools.tsx @@ -92,11 +92,11 @@ export function BatchEditMixTools(props: BatchEditMixToolsProps): JSX.Element { propsForFields.mix_wellOrder_second.updateValue } firstValue={ - (propsForFields.mix_wellOrder_first.name ?? + (propsForFields.mix_wellOrder_first?.value ?? 't2b') as WellOrderOption } secondValue={ - (propsForFields.mix_wellOrder_second.name ?? + (propsForFields.mix_wellOrder_second?.value ?? 'l2r') as WellOrderOption } firstName="mix_wellOrder_first" diff --git a/protocol-designer/src/pages/Designer/ProtocolSteps/BatchEditToolbox/BatchEditMoveLiquidTools.tsx b/protocol-designer/src/pages/Designer/ProtocolSteps/BatchEditToolbox/BatchEditMoveLiquidTools.tsx index 561a926cc8f..12d7f1442e8 100644 --- a/protocol-designer/src/pages/Designer/ProtocolSteps/BatchEditToolbox/BatchEditMoveLiquidTools.tsx +++ b/protocol-designer/src/pages/Designer/ProtocolSteps/BatchEditToolbox/BatchEditMoveLiquidTools.tsx @@ -91,10 +91,10 @@ export function BatchEditMoveLiquidTools( propsForFields[addFieldNamePrefix('wellOrder_second')].updateValue } firstValue={ - (propsForFields.wellOrder_first.name ?? 't2b') as WellOrderOption + (propsForFields.wellOrder_first?.value ?? 't2b') as WellOrderOption } secondValue={ - (propsForFields.wellOrder_second.name ?? 'l2r') as WellOrderOption + (propsForFields.wellOrder_second?.value ?? 'l2r') as WellOrderOption } firstName={addFieldNamePrefix('wellOrder_first')} secondName={addFieldNamePrefix('wellOrder_second')} From 92405c2b5ac4fc66d9d656c08d0165112601f065 Mon Sep 17 00:00:00 2001 From: Nick Diehl <47604184+ncdiehl11@users.noreply.github.com> Date: Tue, 3 Dec 2024 18:15:09 -0500 Subject: [PATCH 03/23] feat(protocol-designer): add protocol recovery to error boundary (#17025) In error boundary fallback modal, I add a new secondary button to allow the user to download the protocol after a whitescreen. No routing is implemented at this time, so impact should be low. --- .../src/assets/localization/en/shared.json | 1 + .../resources/ProtocolDesignerAppFallback.tsx | 22 ++++++++++++++----- 2 files changed, 17 insertions(+), 6 deletions(-) diff --git a/protocol-designer/src/assets/localization/en/shared.json b/protocol-designer/src/assets/localization/en/shared.json index 58579da36ff..0d9342713c4 100644 --- a/protocol-designer/src/assets/localization/en/shared.json +++ b/protocol-designer/src/assets/localization/en/shared.json @@ -19,6 +19,7 @@ "destination_well": "Destination Well", "developer_ff": "Developer Feature Flags", "done": "Done", + "download_protocol": "Download protocol", "edit_existing": "Edit existing protocol", "edit_instruments": "Edit Instruments", "edit_pipette": "Edit Pipette", diff --git a/protocol-designer/src/resources/ProtocolDesignerAppFallback.tsx b/protocol-designer/src/resources/ProtocolDesignerAppFallback.tsx index 32eabb78a30..3791d4b97b3 100644 --- a/protocol-designer/src/resources/ProtocolDesignerAppFallback.tsx +++ b/protocol-designer/src/resources/ProtocolDesignerAppFallback.tsx @@ -4,15 +4,19 @@ import { useTranslation } from 'react-i18next' import type { FallbackProps } from 'react-error-boundary' +import { actions } from '../load-file' import { AlertPrimaryButton, ALIGN_FLEX_END, DIRECTION_COLUMN, Flex, Modal, + SecondaryButton, SPACING, StyledText, } from '@opentrons/components' +import { useDispatch } from 'react-redux' +import type { ThunkDispatch } from '../types' export function ProtocolDesignerAppFallback({ error, @@ -20,9 +24,13 @@ export function ProtocolDesignerAppFallback({ }: FallbackProps): JSX.Element { const { t } = useTranslation('shared') + const dispatch: ThunkDispatch = useDispatch() const handleReloadClick = (): void => { resetErrorBoundary() } + const handleDownloadProtocol = (): void => { + dispatch(actions.saveProtocolFile()) + } return ( @@ -35,12 +43,14 @@ export function ProtocolDesignerAppFallback({ {error.message} - - {t('reload_app')} - + + + {t('download_protocol')} + + + {t('reload_app')} + + ) From 06f9601b6a835944b4bd392b48ec09413cad6b2c Mon Sep 17 00:00:00 2001 From: Jethary Alcid <66035149+jerader@users.noreply.github.com> Date: Wed, 4 Dec 2024 08:22:39 -0500 Subject: [PATCH 04/23] fix(protocol-designer): add duplicate tipracks off deck (#17026) closes RQA-3744 --- .../src/pages/Designer/DeckSetup/DeckSetupTools.tsx | 13 +++++++------ 1 file changed, 7 insertions(+), 6 deletions(-) diff --git a/protocol-designer/src/pages/Designer/DeckSetup/DeckSetupTools.tsx b/protocol-designer/src/pages/Designer/DeckSetup/DeckSetupTools.tsx index 44732c1e0ed..48b0ef87bba 100644 --- a/protocol-designer/src/pages/Designer/DeckSetup/DeckSetupTools.tsx +++ b/protocol-designer/src/pages/Designer/DeckSetup/DeckSetupTools.tsx @@ -318,12 +318,13 @@ export function DeckSetupTools(props: DeckSetupToolsProps): JSX.Element | null { ) } if ( - selectedModuleModel == null && - selectedLabwareDefUri != null && - (createdLabwareForSlot?.labwareDefURI !== selectedLabwareDefUri || - (selectedNestedLabwareDefUri != null && - selectedNestedLabwareDefUri !== - createdNestedLabwareForSlot?.labwareDefURI)) + (slot === 'offDeck' && selectedLabwareDefUri != null) || + (selectedModuleModel == null && + selectedLabwareDefUri != null && + (createdLabwareForSlot?.labwareDefURI !== selectedLabwareDefUri || + (selectedNestedLabwareDefUri != null && + selectedNestedLabwareDefUri !== + createdNestedLabwareForSlot?.labwareDefURI))) ) { // create adapter + labware on deck dispatch( From 2e81f2949484fd7be6e009851ed720a4de7a876b Mon Sep 17 00:00:00 2001 From: Jethary Alcid <66035149+jerader@users.noreply.github.com> Date: Wed, 4 Dec 2024 10:05:09 -0500 Subject: [PATCH 05/23] =?UTF-8?q?fix(protocol-designer):=20if=20no=20space?= =?UTF-8?q?=20for=20trashBin,=20auto-generate=20waste=E2=80=A6=20(#17028)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit …Chute closes RQA-3747 --- .../src/step-forms/reducers/index.ts | 52 ++-- .../src/step-forms/test/utils.test.ts | 233 +++++++++++++++++- .../src/step-forms/utils/index.ts | 11 +- 3 files changed, 272 insertions(+), 24 deletions(-) diff --git a/protocol-designer/src/step-forms/reducers/index.ts b/protocol-designer/src/step-forms/reducers/index.ts index 2dec7cb6639..501ff4f2955 100644 --- a/protocol-designer/src/step-forms/reducers/index.ts +++ b/protocol-designer/src/step-forms/reducers/index.ts @@ -16,6 +16,7 @@ import { THERMOCYCLER_MODULE_TYPE, WASTE_CHUTE_ADDRESSABLE_AREAS, MOVABLE_TRASH_ADDRESSABLE_AREAS, + WASTE_CHUTE_CUTOUT, } from '@opentrons/shared-data' import { rootReducer as labwareDefsRootReducer } from '../../labware-defs' import { getCutoutIdByAddressableArea, uuid } from '../../utils' @@ -45,7 +46,7 @@ import { createPresavedStepForm, getDeckItemIdInSlot, getIdsInRange, - getUnoccupiedSlotForMoveableTrash, + getUnoccupiedSlotForTrash, } from '../utils' import type { Reducer } from 'redux' @@ -1414,9 +1415,9 @@ export const additionalEquipmentInvariantProperties = handleActions { @@ -31,7 +32,7 @@ describe('getIdsInRange', () => { expect(getIdsInRange(orderedIds, 'T', 'T')).toEqual(['T']) }) }) -describe('getUnoccupiedSlotForMoveableTrash', () => { +describe('getUnoccupiedSlotForTrash', () => { it('returns slot C1 when all other slots are occupied by modules, labware, moveLabware, and staging areas', () => { const mockPDFile: any = { commands: [ @@ -146,11 +147,237 @@ describe('getUnoccupiedSlotForMoveableTrash', () => { const mockHasWasteChuteCommands = false expect( - getUnoccupiedSlotForMoveableTrash( + getUnoccupiedSlotForTrash( mockPDFile, mockHasWasteChuteCommands, mockStagingAreaSlotNames ) ).toStrictEqual('C3') }) + it('returns cutoutD3 for waste chute when every slot is occupied except for D3 on a staging area', () => { + const mockPDFile: any = { + commands: [ + { + key: '159e778d-0fc5-4d24-a662-b1e59a7babda', + commandType: 'loadModule', + params: { + model: 'thermocyclerModuleV2', + location: { slotName: 'B1' }, + moduleId: + '8932e104-7d57-42cf-88e4-ade334c84a76:thermocyclerModuleType', + }, + }, + { + key: '7d1fdcce-fa27-4520-8f97-a901751a4396', + commandType: 'loadModule', + params: { + model: 'temperatureModuleV2', + location: { slotName: 'C1' }, + moduleId: + '2944a6a5-45f7-4d96-a4a2-d2853206a9f0:temperatureModuleType', + }, + }, + { + key: '1c223945-bfa3-4174-9923-5ed84afd1820', + commandType: 'loadModule', + params: { + model: 'heaterShakerModuleV1', + location: { slotName: 'D1' }, + moduleId: + '528620a6-6eb9-4000-bce3-a58809e16d4c:heaterShakerModuleType', + }, + }, + { + key: 'e06d0fd5-2ca8-4d0a-bcfd-4121849604da', + commandType: 'loadModule', + params: { + model: 'magneticBlockV1', + location: { slotName: 'D2' }, + moduleId: 'c8f8c89f-06df-468c-895d-33006db69beb:magneticBlockType', + }, + }, + { + key: 'f49ebdff-9780-4ca0-994c-2d2dd7c04b1d', + commandType: 'loadLabware', + params: { + displayName: 'Opentrons 96 Well Aluminum Block', + labwareId: + 'a69bcf2e-9461-4d43-be63-f3b8db66e5e7:opentrons/opentrons_96_well_aluminum_block/1', + loadName: 'opentrons_96_well_aluminum_block', + namespace: 'opentrons', + version: 1, + location: { + moduleId: + '2944a6a5-45f7-4d96-a4a2-d2853206a9f0:temperatureModuleType', + }, + }, + }, + { + key: 'dda244f9-ff80-4ede-a585-1a546a88ee77', + commandType: 'loadLabware', + params: { + displayName: 'Opentrons 96 PCR Heater-Shaker Adapter', + labwareId: + '723a9551-ebba-4b4a-a92e-8d1fa0e813df:opentrons/opentrons_96_pcr_adapter/1', + loadName: 'opentrons_96_pcr_adapter', + namespace: 'opentrons', + version: 1, + location: { + moduleId: + '528620a6-6eb9-4000-bce3-a58809e16d4c:heaterShakerModuleType', + }, + }, + }, + { + key: '8c28ac95-c8d0-4481-8204-26b1babb54bf', + commandType: 'loadLabware', + params: { + displayName: 'Opentrons Flex 96 Tip Rack 50 µL', + labwareId: + 'c80cffe7-d89d-430e-ba96-3c12f879e993:opentrons/opentrons_flex_96_tiprack_50ul/1', + loadName: 'opentrons_flex_96_tiprack_50ul', + namespace: 'opentrons', + version: 1, + location: { slotName: 'C3' }, + }, + }, + { + key: 'f0357fde-125a-464c-98ed-b1b9492daab8', + commandType: 'loadLabware', + params: { + displayName: 'Opentrons Flex 96 Filter Tip Rack 200 µL (1)', + labwareId: + '0a2d4b6f-a43d-428a-98f2-284809596776:opentrons/opentrons_flex_96_filtertiprack_200ul/1', + loadName: 'opentrons_flex_96_filtertiprack_200ul', + namespace: 'opentrons', + version: 1, + location: { slotName: 'A3' }, + }, + }, + { + key: 'e27ba758-8d28-486f-a443-6e2276842ad0', + commandType: 'loadLabware', + params: { + displayName: 'Opentrons Flex 96 Filter Tip Rack 200 µL (2)', + labwareId: + '417a6bb2-8831-4b4d-840b-7d9329606865:opentrons/opentrons_flex_96_filtertiprack_200ul/1', + loadName: 'opentrons_flex_96_filtertiprack_200ul', + namespace: 'opentrons', + version: 1, + location: { slotName: 'B3' }, + }, + }, + { + key: '37848c2a-4a1b-44f0-851a-d264368c47f8', + commandType: 'loadLabware', + params: { + displayName: 'Opentrons Flex 96 Filter Tip Rack 200 µL (3)', + labwareId: + 'ebb13651-0a60-4f42-ab85-f7084aeb0c08:opentrons/opentrons_flex_96_filtertiprack_200ul/1', + loadName: 'opentrons_flex_96_filtertiprack_200ul', + namespace: 'opentrons', + version: 1, + location: { slotName: 'A2' }, + }, + }, + { + key: '768626df-b249-4d68-8f95-193b03113457', + commandType: 'loadLabware', + params: { + displayName: 'Opentrons Flex 96 Filter Tip Rack 200 µL (4)', + labwareId: + 'b17e8c1b-a308-4eaa-a852-10ad300ddea8:opentrons/opentrons_flex_96_filtertiprack_200ul/1', + loadName: 'opentrons_flex_96_filtertiprack_200ul', + namespace: 'opentrons', + version: 1, + location: { slotName: 'B2' }, + }, + }, + { + key: 'b12a4e6e-7ffc-421f-a2b6-44ae49d6f7bf', + commandType: 'loadLabware', + params: { + displayName: 'Reagent Plate', + labwareId: + 'aab3280f-6e7b-4e60-8326-c1d38999e08f:opentrons/opentrons_96_wellplate_200ul_pcr_full_skirt/2', + loadName: 'opentrons_96_wellplate_200ul_pcr_full_skirt', + namespace: 'opentrons', + version: 2, + location: { + labwareId: + 'a69bcf2e-9461-4d43-be63-f3b8db66e5e7:opentrons/opentrons_96_well_aluminum_block/1', + }, + }, + }, + { + key: 'e6863a1e-8aa0-4484-9aff-74ea9195a815', + commandType: 'loadLabware', + params: { + displayName: 'Sample Plate 1', + labwareId: + '8e755287-33cb-483f-b525-fff876893754:opentrons/opentrons_96_wellplate_200ul_pcr_full_skirt/2', + loadName: 'opentrons_96_wellplate_200ul_pcr_full_skirt', + namespace: 'opentrons', + version: 2, + location: { + labwareId: + '723a9551-ebba-4b4a-a92e-8d1fa0e813df:opentrons/opentrons_96_pcr_adapter/1', + }, + }, + }, + { + key: 'b29f48ef-3b20-457e-8499-df709818c47f', + commandType: 'loadLabware', + params: { + displayName: 'NEST 96 Deep Well Plate 2mL', + labwareId: + 'f0d30267-b0f6-493a-b0ea-70303428fa83:opentrons/nest_96_wellplate_2ml_deep/2', + loadName: 'nest_96_wellplate_2ml_deep', + namespace: 'opentrons', + version: 2, + location: { + moduleId: + 'c8f8c89f-06df-468c-895d-33006db69beb:magneticBlockType', + }, + }, + }, + { + key: '50be2f72-c7bc-4fd4-b10c-2054b90f922d', + commandType: 'loadLabware', + params: { + displayName: 'NEST 12 Well Reservoir 15 mL', + labwareId: + 'b60bbc39-cd82-4ede-b744-e88777a32b62:opentrons/nest_12_reservoir_15ml/1', + loadName: 'nest_12_reservoir_15ml', + namespace: 'opentrons', + version: 1, + location: { slotName: 'C2' }, + }, + }, + { + key: 'a2f0c011-9983-46d9-a3ae-763a04856651', + commandType: 'loadLabware', + params: { + displayName: 'Opentrons Flex 96 Tip Rack 50 µL (1)', + labwareId: + '0d3d02a6-6501-4f28-81b9-12b2fe66998b:opentrons/opentrons_flex_96_tiprack_50ul/1', + loadName: 'opentrons_flex_96_tiprack_50ul', + namespace: 'opentrons', + version: 1, + location: { addressableAreaName: 'D4' }, + }, + }, + ], + } + const mockStagingAreaSlotNames: AddressableAreaName[] = ['D4'] + const mockHasWasteChuteCommands = false + + expect( + getUnoccupiedSlotForTrash( + mockPDFile, + mockHasWasteChuteCommands, + mockStagingAreaSlotNames + ) + ).toStrictEqual(WASTE_CHUTE_CUTOUT) + }) }) diff --git a/protocol-designer/src/step-forms/utils/index.ts b/protocol-designer/src/step-forms/utils/index.ts index aa880038bbe..042a6edfbd4 100644 --- a/protocol-designer/src/step-forms/utils/index.ts +++ b/protocol-designer/src/step-forms/utils/index.ts @@ -316,7 +316,7 @@ export function getHydratedForm( return hydratedForm } -export const getUnoccupiedSlotForMoveableTrash = ( +export const getUnoccupiedSlotForTrash = ( file: PDProtocolFile, hasWasteChuteCommands: boolean, stagingAreaSlotNames: AddressableAreaName[] @@ -385,6 +385,15 @@ export const getUnoccupiedSlotForMoveableTrash = ( !wasteChuteSlot.includes(cutout.value as typeof WASTE_CHUTE_CUTOUT) && !stagingAreaCutoutIds.includes(cutout.value as CutoutId) ) + // if all slots are occupied except for D3 on a staging area, then auto-generate the waste chute + if ( + unoccupiedSlot == null && + !allLoadLabwareSlotNames.includes('D3') && + stagingAreaCutoutIds.includes(WASTE_CHUTE_CUTOUT) + ) { + return WASTE_CHUTE_CUTOUT + } + if (unoccupiedSlot == null) { console.error( 'Expected to find an unoccupied slot for auto-generating a trash bin but could not' From 1208454ce00d54f2d8b61edf539be71581726b41 Mon Sep 17 00:00:00 2001 From: Nick Diehl <47604184+ncdiehl11@users.noreply.github.com> Date: Wed, 4 Dec 2024 16:15:51 -0500 Subject: [PATCH 06/23] fix(protocol-designer): fix logic for showing AutoAddPauseUntilTempStepModal (#17039) The logic for `isPristineSetTempForm` passed to `StepForm` was performing a brittle check on the state of the temperature module form. Here, I change the logic to check for the presence of a non-null targetTemperature for safety, more closely mirroring the functioning logic of `isPristineSetHeaterShakerTempForm`. This fix correctly presents the modal to add a pause step after setting temperature for temperature modules. Closes RQA-3763 --- protocol-designer/src/step-forms/selectors/index.ts | 4 ++-- protocol-designer/src/step-forms/test/selectors.test.ts | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/protocol-designer/src/step-forms/selectors/index.ts b/protocol-designer/src/step-forms/selectors/index.ts index 75c47774fca..115a02170c8 100644 --- a/protocol-designer/src/step-forms/selectors/index.ts +++ b/protocol-designer/src/step-forms/selectors/index.ts @@ -722,7 +722,7 @@ export const getUnsavedFormIsPristineSetTempForm: Selector< (unsavedForm, isPresaved) => { const isSetTempForm = unsavedForm?.stepType === 'temperature' && - unsavedForm?.setTemperature === 'true' + unsavedForm?.targetTemperature != null return isPresaved && isSetTempForm } ) @@ -736,7 +736,7 @@ export const getUnsavedFormIsPristineHeaterShakerForm: Selector< (unsavedForm, isPresaved) => { const isSetHsTempForm = unsavedForm?.stepType === 'heaterShaker' && - unsavedForm?.targetHeaterShakerTemperature !== null + unsavedForm?.targetHeaterShakerTemperature != null return isPresaved && isSetHsTempForm } diff --git a/protocol-designer/src/step-forms/test/selectors.test.ts b/protocol-designer/src/step-forms/test/selectors.test.ts index 64525e1fd53..55c2539fa1c 100644 --- a/protocol-designer/src/step-forms/test/selectors.test.ts +++ b/protocol-designer/src/step-forms/test/selectors.test.ts @@ -160,7 +160,7 @@ describe('getUnsavedFormIsPristineSetTempForm', () => { // @ts-expect-error(jr, 4/8/22): missing module id const formData: FormData = { stepType: 'temperature', - setTemperature: 'true', + targetTemperature: 33, } const expected = true // @ts-expect-error(jr, 4/8/22): resultFunc (from reselect) is not part of their Selector interface From 1a730ad8332877316f0b8dd87169fd4c55ab97d1 Mon Sep 17 00:00:00 2001 From: Jethary Alcid <66035149+jerader@users.noreply.github.com> Date: Wed, 4 Dec 2024 17:23:57 -0500 Subject: [PATCH 07/23] fix(protocol-designer): properly update moduleState for temperature form (#17041) closes RQA-3765 fix updating module state for temperature form and heater-shaker form. The error was because for some reason setTemperature/setHeaterShakerTimer type is `true` and `false` as strings instead of the boolean! --- .../ToggleExpandStepFormField/index.tsx | 25 ++++++++++++++----- .../StepTools/HeaterShakerTools/index.tsx | 2 +- .../StepTools/TemperatureTools/index.tsx | 2 +- 3 files changed, 21 insertions(+), 8 deletions(-) diff --git a/protocol-designer/src/molecules/ToggleExpandStepFormField/index.tsx b/protocol-designer/src/molecules/ToggleExpandStepFormField/index.tsx index 5c34b465647..7412afb3c2a 100644 --- a/protocol-designer/src/molecules/ToggleExpandStepFormField/index.tsx +++ b/protocol-designer/src/molecules/ToggleExpandStepFormField/index.tsx @@ -42,6 +42,7 @@ export function ToggleExpandStepFormField( toggleValue, caption, toggleElement = 'toggle', + name, ...restProps } = props @@ -49,17 +50,28 @@ export function ToggleExpandStepFormField( restProps.updateValue(null) } + // TODO: refactor this, it is messy const onToggleUpdateValue = (): void => { - if (typeof toggleValue === 'boolean') { + if (toggleValue === 'engage' || toggleValue === 'disengage') { + const newValue = toggleValue === 'engage' ? 'disengage' : 'engage' + toggleUpdateValue(newValue) + } else if (toggleValue === 'true' || toggleValue === 'false') { + const newValue = toggleValue === 'true' ? 'false' : 'true' + toggleUpdateValue(newValue) + if (newValue === 'true') { + resetFieldValue() + } + } else if (toggleValue == null) { + toggleUpdateValue( + name === 'targetTemperature' || name === 'heaterShakerTimer' + ? 'true' + : true + ) + } else { toggleUpdateValue(!toggleValue) if (toggleValue) { resetFieldValue() } - } else if (toggleValue === 'engage' || toggleValue === 'disengage') { - const newToggleValue = toggleValue === 'engage' ? 'disengage' : 'engage' - toggleUpdateValue(newToggleValue) - } else if (toggleValue == null) { - toggleUpdateValue(true) } } @@ -99,6 +111,7 @@ export function ToggleExpandStepFormField( {isSelected ? ( Date: Thu, 5 Dec 2024 13:26:50 -0500 Subject: [PATCH 08/23] =?UTF-8?q?fix(protocol-designer):=20well=20selectio?= =?UTF-8?q?n=20tooltip=20for=20single=20and=20multi-c=E2=80=A6=20(#17044)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit …hannel closes RQA-3768 --- .../src/components/steplist/SubstepRow.tsx | 94 ++++++++++++------- 1 file changed, 62 insertions(+), 32 deletions(-) diff --git a/protocol-designer/src/components/steplist/SubstepRow.tsx b/protocol-designer/src/components/steplist/SubstepRow.tsx index f00c23c64e8..3d76462b845 100644 --- a/protocol-designer/src/components/steplist/SubstepRow.tsx +++ b/protocol-designer/src/components/steplist/SubstepRow.tsx @@ -35,56 +35,86 @@ interface PillTooltipContentsProps { ingredNames: WellIngredientNames well: string } + export const PillTooltipContents = ( props: PillTooltipContentsProps ): JSX.Element => { + const { ingreds, ingredNames, well } = props const liquidDisplayColors = useSelector(selectors.getLiquidDisplayColors) + const isSingleChannel = (ingred: any): ingred is { volume: number } => + typeof ingred === 'object' && 'volume' in ingred + + const isMultiChannel = ( + ingred: any + ): ingred is { [ingredId: string]: { volume: number } } => + typeof ingred === 'object' && !('volume' in ingred) + const totalLiquidVolume = reduce( - props.ingreds, - // @ts-expect-error(sa, 2021-6-20): TODO IMMEDIATELY, this could either be single channel OR multi channel volume data - // we have to differentiate, because the structure of the interface is different - (acc, ingred) => acc + ingred.volume, + ingreds, + (acc, ingred) => { + if (isSingleChannel(ingred)) { + return acc + (ingred.volume ?? 0) + } else if (isMultiChannel(ingred)) { + return ( + acc + + reduce( + Object.values(ingred ?? {}), + (subAcc, channelData) => subAcc + (channelData?.volume ?? 0), + 0 + ) + ) + } + return acc + }, 0 ) - const hasMultipleIngreds = Object.keys(props.ingreds).length > 1 + + const hasMultipleIngreds = Object.keys(ingreds).length > 1 + return (
- {map(props.ingreds, (ingred, groupId) => ( - - - - {hasMultipleIngreds && ( - + + + {hasMultipleIngreds && ( + + )} + - )} - - - ))} + + ) + })}
-
-
- {props.ingredNames[groupId]} - - {/* @ts-expect-error(sa, 2021-6-20): TODO IMMEDIATELY, this could either be single channel OR multi channel volume data */} - {formatPercentage(ingred.volume, totalLiquidVolume)} + {map(ingreds, (ingred, groupId) => { + const volume = isSingleChannel(ingred) + ? ingred.volume + : reduce( + Object.values(ingred ?? {}), + (acc, channelData) => acc + (channelData?.volume ?? 0), + 0 + ) + + return ( +
+
+
{ingredNames[groupId]} + {formatPercentage(volume, totalLiquidVolume)} + + {formatVolume(volume, 2)}µl - {/* @ts-expect-error(sa, 2021-6-20): TODO IMMEDIATELY, this could either be single channel OR multi channel volume data */} - {formatVolume(ingred.volume, 2)}µl -
{hasMultipleIngreds && (
- {`${props.well} Total Volume`} + {`${well} Total Volume`} {formatVolume(totalLiquidVolume, 2)}µl
From fd2bab7e79332980d0925775d3669dbaaacaeb1f Mon Sep 17 00:00:00 2001 From: koji Date: Thu, 5 Dec 2024 20:52:24 -0500 Subject: [PATCH 09/23] fix(protocol-designer): fix time format in load file (#17053) * fix(protocol-designer): fix time format in load file --- .../fixtures/protocol/8/doItAllV3MigratedToV8.json | 2 +- .../fixtures/protocol/8/doItAllV4MigratedToV8.json | 2 +- .../fixtures/protocol/8/doItAllV7MigratedToV8.json | 2 +- .../fixtures/protocol/8/example_1_1_0MigratedToV8.json | 2 +- protocol-designer/src/load-file/migration/8_2_0.ts | 7 +++++-- .../formLevel/stepFormToArgs/test/pauseFormToArgs.test.ts | 2 +- 6 files changed, 10 insertions(+), 7 deletions(-) diff --git a/protocol-designer/fixtures/protocol/8/doItAllV3MigratedToV8.json b/protocol-designer/fixtures/protocol/8/doItAllV3MigratedToV8.json index 4b8ebc3b4db..0a88ef75afc 100644 --- a/protocol-designer/fixtures/protocol/8/doItAllV3MigratedToV8.json +++ b/protocol-designer/fixtures/protocol/8/doItAllV3MigratedToV8.json @@ -143,7 +143,7 @@ "pauseAction": "untilTime", "pauseMessage": "", "pauseTemperature": null, - "pauseTime": "0:1:2", + "pauseTime": "00:01:02", "id": "5db07ad0-75c7-11ea-b42f-4b64e50f43e5", "stepType": "pause", "stepName": "pause", diff --git a/protocol-designer/fixtures/protocol/8/doItAllV4MigratedToV8.json b/protocol-designer/fixtures/protocol/8/doItAllV4MigratedToV8.json index 441100a7352..bf503ff3219 100644 --- a/protocol-designer/fixtures/protocol/8/doItAllV4MigratedToV8.json +++ b/protocol-designer/fixtures/protocol/8/doItAllV4MigratedToV8.json @@ -184,7 +184,7 @@ "pauseAction": "untilTime", "pauseMessage": "", "pauseTemperature": null, - "pauseTime": "0:1:2", + "pauseTime": "00:01:02", "id": "5db07ad0-75c7-11ea-b42f-4b64e50f43e5", "stepType": "pause", "stepName": "pause", diff --git a/protocol-designer/fixtures/protocol/8/doItAllV7MigratedToV8.json b/protocol-designer/fixtures/protocol/8/doItAllV7MigratedToV8.json index d89eb64b25d..4ba403c4590 100644 --- a/protocol-designer/fixtures/protocol/8/doItAllV7MigratedToV8.json +++ b/protocol-designer/fixtures/protocol/8/doItAllV7MigratedToV8.json @@ -251,7 +251,7 @@ "pauseAction": "untilTime", "pauseMessage": "", "pauseTemperature": null, - "pauseTime": "0:1:0", + "pauseTime": "00:01:00", "id": "e3989707-210d-457f-a9bb-a85b3ef9b59c", "stepType": "pause", "stepName": "pause", diff --git a/protocol-designer/fixtures/protocol/8/example_1_1_0MigratedToV8.json b/protocol-designer/fixtures/protocol/8/example_1_1_0MigratedToV8.json index 985ddf3e2ee..ca6c9b8f9fc 100644 --- a/protocol-designer/fixtures/protocol/8/example_1_1_0MigratedToV8.json +++ b/protocol-designer/fixtures/protocol/8/example_1_1_0MigratedToV8.json @@ -176,7 +176,7 @@ "pauseAction": "untilTime", "pauseMessage": "Delay plz", "pauseTemperature": null, - "pauseTime": "1:2:3", + "pauseTime": "01:02:03", "id": "2e622080-92a6-11e9-ac62-1b173f839d9e", "stepType": "pause", "stepName": "pause", diff --git a/protocol-designer/src/load-file/migration/8_2_0.ts b/protocol-designer/src/load-file/migration/8_2_0.ts index 6bb79ac10d9..24ab1428f09 100644 --- a/protocol-designer/src/load-file/migration/8_2_0.ts +++ b/protocol-designer/src/load-file/migration/8_2_0.ts @@ -10,8 +10,11 @@ const getTimeFromIndividualUnits = ( minutes: any, hours?: any ): string => { - const hoursString = hours !== undefined ? `${hours ?? 0}:` : '' - return `${hoursString}${minutes ?? 0}:${seconds ?? 0}` + const pad = (num: number): string => String(num).padStart(2, '0') + const hoursString = hours !== undefined ? `${pad(Number(hours) ?? 0)}:` : '' + return `${hoursString}${pad(Number(minutes) ?? 0)}:${pad( + Number(seconds) ?? 0 + )}` } export const migrateFile = ( diff --git a/protocol-designer/src/steplist/formLevel/stepFormToArgs/test/pauseFormToArgs.test.ts b/protocol-designer/src/steplist/formLevel/stepFormToArgs/test/pauseFormToArgs.test.ts index ab466604a82..4cbb01e6272 100644 --- a/protocol-designer/src/steplist/formLevel/stepFormToArgs/test/pauseFormToArgs.test.ts +++ b/protocol-designer/src/steplist/formLevel/stepFormToArgs/test/pauseFormToArgs.test.ts @@ -56,7 +56,7 @@ describe('pauseFormToArgs', () => { pauseAction: PAUSE_UNTIL_TIME, description: 'some description', pauseMessage: 'some message', - pauseTime: '1:20:5', + pauseTime: '01:20:05', } const expected = { commandCreatorFnName: 'delay', From 5c411b6eb03e3102ae196e3c4225c61ca62398d9 Mon Sep 17 00:00:00 2001 From: koji Date: Fri, 6 Dec 2024 13:52:47 -0500 Subject: [PATCH 10/23] fix(components): fix dropdownmenu expand direction (#17055) * fix(components): fix dropdownmenu expand direction --- .../src/molecules/DropdownMenu/index.tsx | 56 +++++++++---------- 1 file changed, 25 insertions(+), 31 deletions(-) diff --git a/components/src/molecules/DropdownMenu/index.tsx b/components/src/molecules/DropdownMenu/index.tsx index acfba246dc2..29dfe03988d 100644 --- a/components/src/molecules/DropdownMenu/index.tsx +++ b/components/src/molecules/DropdownMenu/index.tsx @@ -25,12 +25,6 @@ import { Tooltip } from '../../atoms/Tooltip' import { StyledText } from '../../atoms/StyledText' import { LiquidIcon } from '../LiquidIcon' -/** this is the max height to display 10 items */ -const MAX_HEIGHT = 316 - -/** this is for adjustment variable for the case that the space of the bottom and the space of the top are very close */ -const HEIGHT_ADJUSTMENT = 100 - export interface DropdownOption { name: string value: string @@ -115,34 +109,34 @@ export function DropdownMenu(props: DropdownMenuProps): JSX.Element { const handlePositionCalculation = (): void => { const dropdownRect = dropDownMenuWrapperRef.current?.getBoundingClientRect() - if (dropdownRect != null) { - const parentElement = dropDownMenuWrapperRef?.current?.parentElement - const grandParentElement = parentElement?.parentElement?.parentElement - let availableHeight = window.innerHeight - let scrollOffset = 0 + if (!dropdownRect) return + + const parentElement = dropDownMenuWrapperRef.current?.parentElement + const grandParentElement = parentElement?.parentElement?.parentElement + + let availableHeight = window.innerHeight + let scrollOffset = 0 + + if (grandParentElement) { + const grandParentRect = grandParentElement.getBoundingClientRect() + availableHeight = grandParentRect.bottom - grandParentRect.top + scrollOffset = grandParentRect.top + } else if (parentElement) { + const parentRect = parentElement.getBoundingClientRect() + availableHeight = parentRect.bottom - parentRect.top + scrollOffset = parentRect.top + } - if (grandParentElement != null) { - const grandParentRect = grandParentElement.getBoundingClientRect() - availableHeight = grandParentRect.bottom - grandParentRect.top - scrollOffset = grandParentRect.top - } else if (parentElement != null) { - const parentRect = parentElement.getBoundingClientRect() - availableHeight = parentRect.bottom - parentRect.top - scrollOffset = parentRect.top - } + const dropdownHeight = filterOptions.length * 34 + 10 // note (kk:2024/12/06) need to modify the value since design uses different height in desktop and pd + const dropdownBottom = dropdownRect.bottom + dropdownHeight - scrollOffset - const downSpace = - filterOptions.length + 1 > 10 - ? MAX_HEIGHT - : (filterOptions.length + 1) * 34 - const dropdownBottom = dropdownRect.bottom + downSpace - scrollOffset + const fitsBelow = dropdownBottom <= availableHeight + const fitsAbove = dropdownRect.top - dropdownHeight >= scrollOffset - setDropdownPosition( - dropdownBottom > availableHeight && - Math.abs(dropdownBottom - availableHeight) > HEIGHT_ADJUSTMENT - ? 'top' - : 'bottom' - ) + if (menuPlacement === 'auto') { + setDropdownPosition(fitsBelow ? 'bottom' : fitsAbove ? 'top' : 'bottom') + } else { + setDropdownPosition(menuPlacement) } } From 258e13314c7f31869d0b763833e25ae80ef3f4aa Mon Sep 17 00:00:00 2001 From: Caila Marashaj <98041399+caila-marashaj@users.noreply.github.com> Date: Tue, 10 Dec 2024 17:27:22 -0500 Subject: [PATCH 11/23] fix(protocols): fix get_all_labware_defs (#17081) --- api/src/opentrons/protocols/labware.py | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/api/src/opentrons/protocols/labware.py b/api/src/opentrons/protocols/labware.py index 1fb47d55092..2fcffaaf2d4 100644 --- a/api/src/opentrons/protocols/labware.py +++ b/api/src/opentrons/protocols/labware.py @@ -63,7 +63,7 @@ def get_labware_definition( return _get_standard_labware_definition(load_name, namespace, version) -def get_all_labware_definitions() -> List[str]: +def get_all_labware_definitions(schema_version: str = "2") -> List[str]: """ Return a list of standard and custom labware definitions with load_name + name_space + version existing on the robot @@ -77,7 +77,9 @@ def _check_for_subdirectories(path: Union[str, Path, os.DirEntry[str]]) -> None: labware_list.append(sub_dir.name) # check for standard labware - _check_for_subdirectories(get_shared_data_root() / STANDARD_DEFS_PATH) + _check_for_subdirectories( + get_shared_data_root() / STANDARD_DEFS_PATH / schema_version + ) # check for custom labware for namespace in os.scandir(USER_DEFS_PATH): _check_for_subdirectories(namespace) From 61495972a2f772e02aced415560450b6f022abb2 Mon Sep 17 00:00:00 2001 From: koji Date: Tue, 10 Dec 2024 23:40:38 -0500 Subject: [PATCH 12/23] feat(protocol-designer, app): testing a new feature flag for react-scan (#17060) * feat(protocol-designer, app): testing a new feature flag for react-scan --- app/src/App/DesktopApp.tsx | 12 +- app/src/App/__tests__/DesktopApp.test.tsx | 1 + .../assets/localization/en/app_settings.json | 1 + app/src/redux/config/constants.ts | 1 + app/src/redux/config/schema-types.ts | 1 + package.json | 1 + protocol-designer/src/ProtocolEditor.tsx | 12 + .../assets/localization/en/feature_flags.json | 4 + .../src/feature-flags/reducers.ts | 1 + .../src/feature-flags/selectors.ts | 4 + protocol-designer/src/feature-flags/types.ts | 2 + yarn.lock | 473 +++++++++++++++++- 12 files changed, 511 insertions(+), 2 deletions(-) diff --git a/app/src/App/DesktopApp.tsx b/app/src/App/DesktopApp.tsx index df2105007b3..7004acf9723 100644 --- a/app/src/App/DesktopApp.tsx +++ b/app/src/App/DesktopApp.tsx @@ -1,7 +1,7 @@ +import { scan } from 'react-scan' import { useState, Fragment } from 'react' import { Navigate, Route, Routes, useMatch } from 'react-router-dom' import { ErrorBoundary } from 'react-error-boundary' - import { Box, COLORS, @@ -39,6 +39,7 @@ import { ProtocolTimeline } from '/app/pages/Desktop/Protocols/ProtocolDetails/P import { PortalRoot as ModalPortalRoot } from './portal' import { DesktopAppFallback } from './DesktopAppFallback' import { ReactQueryDevtools } from './tools' +import { useFeatureFlag } from '../redux/config' import type { RouteProps } from './types' @@ -49,6 +50,15 @@ export const DesktopApp = (): JSX.Element => { setIsEmergencyStopModalDismissed, ] = useState(false) + // note for react-scan + const enableReactScan = useFeatureFlag('reactScan') + if (typeof window !== 'undefined') { + scan({ + enabled: enableReactScan, + log: true, + }) + } + const desktopRoutes: RouteProps[] = [ { Component: ProtocolsLanding, diff --git a/app/src/App/__tests__/DesktopApp.test.tsx b/app/src/App/__tests__/DesktopApp.test.tsx index 085ff9ef7ba..0bd31ff4aaa 100644 --- a/app/src/App/__tests__/DesktopApp.test.tsx +++ b/app/src/App/__tests__/DesktopApp.test.tsx @@ -81,6 +81,7 @@ describe('DesktopApp', () => { ).mockImplementation((props: LocalizationProviderProps) => ( <>{props.children} )) + when(vi.mocked(useFeatureFlag)).calledWith('reactScan').thenReturn(false) }) afterEach(() => { vi.resetAllMocks() diff --git a/app/src/assets/localization/en/app_settings.json b/app/src/assets/localization/en/app_settings.json index 1cdc29feab0..b4d5f654291 100644 --- a/app/src/assets/localization/en/app_settings.json +++ b/app/src/assets/localization/en/app_settings.json @@ -6,6 +6,7 @@ "__dev_internal__protocolStats": "Protocol Stats", "__dev_internal__protocolTimeline": "Protocol Timeline", "__dev_internal__reactQueryDevtools": "Enable React Query Devtools", + "__dev_internal__reactScan": "Enable React Scan", "add_folder_button": "Add labware source folder", "add_ip_button": "Add", "add_ip_error": "Enter an IP Address or Hostname", diff --git a/app/src/redux/config/constants.ts b/app/src/redux/config/constants.ts index 1af99bc3733..683f3613980 100644 --- a/app/src/redux/config/constants.ts +++ b/app/src/redux/config/constants.ts @@ -8,6 +8,7 @@ export const DEV_INTERNAL_FLAGS: DevInternalFlag[] = [ 'protocolTimeline', 'enableLabwareCreator', 'reactQueryDevtools', + 'reactScan', ] // action type constants diff --git a/app/src/redux/config/schema-types.ts b/app/src/redux/config/schema-types.ts index 8084ef14198..e50a01d78ef 100644 --- a/app/src/redux/config/schema-types.ts +++ b/app/src/redux/config/schema-types.ts @@ -16,6 +16,7 @@ export type DevInternalFlag = | 'protocolTimeline' | 'enableLabwareCreator' | 'reactQueryDevtools' + | 'reactScan' export type FeatureFlags = Partial> diff --git a/package.json b/package.json index cde33247dd4..17ee30cc3e4 100755 --- a/package.json +++ b/package.json @@ -128,6 +128,7 @@ "react-dom": "18.2.0", "react-i18next": "14.0.0", "react-query": "3.35.0", + "react-scan": "^0.0.38", "react-snap": "^1.23.0", "redux-mock-store": "^1.5.3", "rehype": "^9.0.0", diff --git a/protocol-designer/src/ProtocolEditor.tsx b/protocol-designer/src/ProtocolEditor.tsx index 040a094c987..d322bd9fb09 100644 --- a/protocol-designer/src/ProtocolEditor.tsx +++ b/protocol-designer/src/ProtocolEditor.tsx @@ -1,6 +1,8 @@ +import { scan } from 'react-scan' import { DndProvider } from 'react-dnd' import { HashRouter } from 'react-router-dom' import { HTML5Backend } from 'react-dnd-html5-backend' +import { useSelector } from 'react-redux' import { Box, DIRECTION_COLUMN, @@ -9,8 +11,18 @@ import { } from '@opentrons/components' import { ProtocolRoutes } from './ProtocolRoutes' import { PortalRoot } from './organisms' +import { getEnableReactScan } from './feature-flags/selectors' export function ProtocolEditor(): JSX.Element { + // note for react-scan + const enableReactScan = useSelector(getEnableReactScan) + if (typeof window !== 'undefined') { + scan({ + enabled: enableReactScan, + log: true, + }) + } + return ( = createSelector( getFeatureFlagData, flags => flags.OT_PD_ENABLE_HOT_KEYS_DISPLAY ?? false ) +export const getEnableReactScan: Selector = createSelector( + getFeatureFlagData, + flags => flags.OT_PD_ENABLE_REACT_SCAN ?? false +) diff --git a/protocol-designer/src/feature-flags/types.ts b/protocol-designer/src/feature-flags/types.ts index d3db8c563d7..84bab18e474 100644 --- a/protocol-designer/src/feature-flags/types.ts +++ b/protocol-designer/src/feature-flags/types.ts @@ -35,6 +35,7 @@ export type FlagTypes = | 'OT_PD_ENABLE_COMMENT' | 'OT_PD_ENABLE_RETURN_TIP' | 'OT_PD_ENABLE_HOT_KEYS_DISPLAY' + | 'OT_PD_ENABLE_REACT_SCAN' // flags that are not in this list only show in prerelease mode export const userFacingFlags: FlagTypes[] = [ 'OT_PD_DISABLE_MODULE_RESTRICTIONS', @@ -47,5 +48,6 @@ export const allFlags: FlagTypes[] = [ 'OT_PD_ENABLE_ABSORBANCE_READER', 'OT_PD_ENABLE_COMMENT', 'OT_PD_ENABLE_RETURN_TIP', + 'OT_PD_ENABLE_REACT_SCAN', ] export type Flags = Partial> diff --git a/yarn.lock b/yarn.lock index c52814a8c13..d788db962fd 100644 --- a/yarn.lock +++ b/yarn.lock @@ -785,11 +785,25 @@ "@babel/highlight" "^7.24.2" picocolors "^1.0.0" +"@babel/code-frame@^7.25.9", "@babel/code-frame@^7.26.0", "@babel/code-frame@^7.26.2": + version "7.26.2" + resolved "https://registry.yarnpkg.com/@babel/code-frame/-/code-frame-7.26.2.tgz#4b5fab97d33338eff916235055f0ebc21e573a85" + integrity sha512-RJlIHRueQgwWitWgF8OdFYGZX328Ax5BCemNGlqHfplnRT9ESi8JkFlvaVYbS+UubVY6dpv87Fs2u5M29iNFVQ== + dependencies: + "@babel/helper-validator-identifier" "^7.25.9" + js-tokens "^4.0.0" + picocolors "^1.0.0" + "@babel/compat-data@^7.22.6", "@babel/compat-data@^7.23.5", "@babel/compat-data@^7.24.4": version "7.24.4" resolved "https://registry.yarnpkg.com/@babel/compat-data/-/compat-data-7.24.4.tgz#6f102372e9094f25d908ca0d34fc74c74606059a" integrity sha512-vg8Gih2MLK+kOkHJp4gBEIkyaIi00jgWot2D9QOmmfLC8jINSOzmCLta6Bvz/JSBCqnegV0L80jhxkol5GWNfQ== +"@babel/compat-data@^7.25.9": + version "7.26.3" + resolved "https://registry.yarnpkg.com/@babel/compat-data/-/compat-data-7.26.3.tgz#99488264a56b2aded63983abd6a417f03b92ed02" + integrity sha512-nHIxvKPniQXpmQLb0vhY3VaFb3S0YrTAwpOWJZh1wn3oJPjJk9Asva204PsBdmAE8vpzfHudT8DB0scYvy9q0g== + "@babel/core@>=7.2.2", "@babel/core@^7.11.6", "@babel/core@^7.12.3", "@babel/core@^7.18.9", "@babel/core@^7.20.12", "@babel/core@^7.23.0", "@babel/core@^7.23.2", "@babel/core@^7.23.3", "@babel/core@^7.23.5": version "7.24.4" resolved "https://registry.yarnpkg.com/@babel/core/-/core-7.24.4.tgz#1f758428e88e0d8c563874741bc4ffc4f71a4717" @@ -811,6 +825,27 @@ json5 "^2.2.3" semver "^6.3.1" +"@babel/core@^7.26.0": + version "7.26.0" + resolved "https://registry.yarnpkg.com/@babel/core/-/core-7.26.0.tgz#d78b6023cc8f3114ccf049eb219613f74a747b40" + integrity sha512-i1SLeK+DzNnQ3LL/CswPCa/E5u4lh1k6IAEphON8F+cXt0t9euTshDru0q7/IqMa1PMPz5RnHuHscF8/ZJsStg== + dependencies: + "@ampproject/remapping" "^2.2.0" + "@babel/code-frame" "^7.26.0" + "@babel/generator" "^7.26.0" + "@babel/helper-compilation-targets" "^7.25.9" + "@babel/helper-module-transforms" "^7.26.0" + "@babel/helpers" "^7.26.0" + "@babel/parser" "^7.26.0" + "@babel/template" "^7.25.9" + "@babel/traverse" "^7.25.9" + "@babel/types" "^7.26.0" + convert-source-map "^2.0.0" + debug "^4.1.0" + gensync "^1.0.0-beta.2" + json5 "^2.2.3" + semver "^6.3.1" + "@babel/generator@^7.23.0", "@babel/generator@^7.24.1", "@babel/generator@^7.24.4": version "7.24.4" resolved "https://registry.yarnpkg.com/@babel/generator/-/generator-7.24.4.tgz#1fc55532b88adf952025d5d2d1e71f946cb1c498" @@ -821,6 +856,17 @@ "@jridgewell/trace-mapping" "^0.3.25" jsesc "^2.5.1" +"@babel/generator@^7.26.0", "@babel/generator@^7.26.2", "@babel/generator@^7.26.3": + version "7.26.3" + resolved "https://registry.yarnpkg.com/@babel/generator/-/generator-7.26.3.tgz#ab8d4360544a425c90c248df7059881f4b2ce019" + integrity sha512-6FF/urZvD0sTeO7k6/B15pMLC4CHUv1426lzr3N01aHJTl046uCAh9LXW/fzeXXjPNCJ6iABW5XaWOsIZB93aQ== + dependencies: + "@babel/parser" "^7.26.3" + "@babel/types" "^7.26.3" + "@jridgewell/gen-mapping" "^0.3.5" + "@jridgewell/trace-mapping" "^0.3.25" + jsesc "^3.0.2" + "@babel/helper-annotate-as-pure@^7.16.0", "@babel/helper-annotate-as-pure@^7.22.5": version "7.22.5" resolved "https://registry.yarnpkg.com/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.22.5.tgz#e7f06737b197d580a01edf75d97e2c8be99d3882" @@ -846,6 +892,17 @@ lru-cache "^5.1.1" semver "^6.3.1" +"@babel/helper-compilation-targets@^7.25.9": + version "7.25.9" + resolved "https://registry.yarnpkg.com/@babel/helper-compilation-targets/-/helper-compilation-targets-7.25.9.tgz#55af025ce365be3cdc0c1c1e56c6af617ce88875" + integrity sha512-j9Db8Suy6yV/VHa4qzrj9yZfZxhLWQdVnRlXxmKLYlhWUVB1sB2G5sxuWYXk/whHD9iW76PmNzxZ4UCnTQTVEQ== + dependencies: + "@babel/compat-data" "^7.25.9" + "@babel/helper-validator-option" "^7.25.9" + browserslist "^4.24.0" + lru-cache "^5.1.1" + semver "^6.3.1" + "@babel/helper-create-class-features-plugin@^7.24.1", "@babel/helper-create-class-features-plugin@^7.24.4": version "7.24.4" resolved "https://registry.yarnpkg.com/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.24.4.tgz#c806f73788a6800a5cfbbc04d2df7ee4d927cce3" @@ -915,6 +972,14 @@ dependencies: "@babel/types" "^7.24.0" +"@babel/helper-module-imports@^7.25.9": + version "7.25.9" + resolved "https://registry.yarnpkg.com/@babel/helper-module-imports/-/helper-module-imports-7.25.9.tgz#e7f8d20602ebdbf9ebbea0a0751fb0f2a4141715" + integrity sha512-tnUA4RsrmflIM6W6RFTLFSXITtl0wKjgpnLgXyowocVPrbYrLUXSBXDgTs8BlbmIzIdlBySRQjINYs2BAkiLtw== + dependencies: + "@babel/traverse" "^7.25.9" + "@babel/types" "^7.25.9" + "@babel/helper-module-transforms@^7.23.3": version "7.23.3" resolved "https://registry.yarnpkg.com/@babel/helper-module-transforms/-/helper-module-transforms-7.23.3.tgz#d7d12c3c5d30af5b3c0fcab2a6d5217773e2d0f1" @@ -926,6 +991,15 @@ "@babel/helper-split-export-declaration" "^7.22.6" "@babel/helper-validator-identifier" "^7.22.20" +"@babel/helper-module-transforms@^7.26.0": + version "7.26.0" + resolved "https://registry.yarnpkg.com/@babel/helper-module-transforms/-/helper-module-transforms-7.26.0.tgz#8ce54ec9d592695e58d84cd884b7b5c6a2fdeeae" + integrity sha512-xO+xu6B5K2czEnQye6BHA7DolFFmS3LB7stHZFaOLb1pAwO1HWLS8fXA+eh0A2yIvltPVmx3eNNDBJA2SLHXFw== + dependencies: + "@babel/helper-module-imports" "^7.25.9" + "@babel/helper-validator-identifier" "^7.25.9" + "@babel/traverse" "^7.25.9" + "@babel/helper-optimise-call-expression@^7.22.5": version "7.22.5" resolved "https://registry.yarnpkg.com/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.22.5.tgz#f21531a9ccbff644fdd156b4077c16ff0c3f609e" @@ -982,16 +1056,31 @@ resolved "https://registry.yarnpkg.com/@babel/helper-string-parser/-/helper-string-parser-7.24.1.tgz#f99c36d3593db9540705d0739a1f10b5e20c696e" integrity sha512-2ofRCjnnA9y+wk8b9IAREroeUP02KHp431N2mhKniy2yKIDKpbrHv9eXwm8cBeWQYcJmzv5qKCu65P47eCF7CQ== +"@babel/helper-string-parser@^7.25.9": + version "7.25.9" + resolved "https://registry.yarnpkg.com/@babel/helper-string-parser/-/helper-string-parser-7.25.9.tgz#1aabb72ee72ed35789b4bbcad3ca2862ce614e8c" + integrity sha512-4A/SCr/2KLd5jrtOMFzaKjVtAei3+2r/NChoBNoZ3EyP/+GlhoaEGoWOZUmFmoITP7zOJyHIMm+DYRd8o3PvHA== + "@babel/helper-validator-identifier@^7.22.20": version "7.22.20" resolved "https://registry.yarnpkg.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.22.20.tgz#c4ae002c61d2879e724581d96665583dbc1dc0e0" integrity sha512-Y4OZ+ytlatR8AI+8KZfKuL5urKp7qey08ha31L8b3BwewJAoJamTzyvxPR/5D+KkdJCGPq/+8TukHBlY10FX9A== +"@babel/helper-validator-identifier@^7.25.9": + version "7.25.9" + resolved "https://registry.yarnpkg.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.25.9.tgz#24b64e2c3ec7cd3b3c547729b8d16871f22cbdc7" + integrity sha512-Ed61U6XJc3CVRfkERJWDz4dJwKe7iLmmJsbOGu9wSloNSFttHV0I8g6UAgb7qnK5ly5bGLPd4oXZlxCdANBOWQ== + "@babel/helper-validator-option@^7.23.5": version "7.23.5" resolved "https://registry.yarnpkg.com/@babel/helper-validator-option/-/helper-validator-option-7.23.5.tgz#907a3fbd4523426285365d1206c423c4c5520307" integrity sha512-85ttAOMLsr53VgXkTbkx8oA6YTfT4q7/HzXSLEYmjcSTJPMPQtvq1BD79Byep5xMUYbGRzEpDsjUf3dyp54IKw== +"@babel/helper-validator-option@^7.25.9": + version "7.25.9" + resolved "https://registry.yarnpkg.com/@babel/helper-validator-option/-/helper-validator-option-7.25.9.tgz#86e45bd8a49ab7e03f276577f96179653d41da72" + integrity sha512-e/zv1co8pp55dNdEcCynfj9X7nyUKUXoUEwfXqaZt0omVOmDe9oOTdKStH4GmAw6zxMFs50ZayuMfHDKlO7Tfw== + "@babel/helper-wrap-function@^7.22.20": version "7.22.20" resolved "https://registry.yarnpkg.com/@babel/helper-wrap-function/-/helper-wrap-function-7.22.20.tgz#15352b0b9bfb10fc9c76f79f6342c00e3411a569" @@ -1010,6 +1099,14 @@ "@babel/traverse" "^7.24.1" "@babel/types" "^7.24.0" +"@babel/helpers@^7.26.0": + version "7.26.0" + resolved "https://registry.yarnpkg.com/@babel/helpers/-/helpers-7.26.0.tgz#30e621f1eba5aa45fe6f4868d2e9154d884119a4" + integrity sha512-tbhNuIxNcVb21pInl3ZSjksLCvgdZy9KwJ8brv993QtIVKJBBkYXz4q4ZbAv31GdnC+R90np23L5FbEBlthAEw== + dependencies: + "@babel/template" "^7.25.9" + "@babel/types" "^7.26.0" + "@babel/highlight@^7.24.2": version "7.24.2" resolved "https://registry.yarnpkg.com/@babel/highlight/-/highlight-7.24.2.tgz#3f539503efc83d3c59080a10e6634306e0370d26" @@ -1025,6 +1122,13 @@ resolved "https://registry.yarnpkg.com/@babel/parser/-/parser-7.24.4.tgz#234487a110d89ad5a3ed4a8a566c36b9453e8c88" integrity sha512-zTvEBcghmeBma9QIGunWevvBAp4/Qu9Bdq+2k0Ot4fVMD6v3dsC9WOcRSKk7tRRyBM/53yKMJko9xOatGQAwSg== +"@babel/parser@^7.25.9", "@babel/parser@^7.26.0", "@babel/parser@^7.26.3": + version "7.26.3" + resolved "https://registry.yarnpkg.com/@babel/parser/-/parser-7.26.3.tgz#8c51c5db6ddf08134af1ddbacf16aaab48bac234" + integrity sha512-WJ/CvmY8Mea8iDXo6a7RK2wbmJITT5fN3BEkRuFlxVyNx8jOKIIhmC4fSkTcPcf8JyavbBwIe6OpiCOBXt/IcA== + dependencies: + "@babel/types" "^7.26.3" + "@babel/plugin-bugfix-firefox-class-in-computed-class-key@^7.24.4": version "7.24.4" resolved "https://registry.yarnpkg.com/@babel/plugin-bugfix-firefox-class-in-computed-class-key/-/plugin-bugfix-firefox-class-in-computed-class-key-7.24.4.tgz#6125f0158543fb4edf1c22f322f3db67f21cb3e1" @@ -1785,6 +1889,15 @@ "@babel/parser" "^7.24.0" "@babel/types" "^7.24.0" +"@babel/template@^7.25.9": + version "7.25.9" + resolved "https://registry.yarnpkg.com/@babel/template/-/template-7.25.9.tgz#ecb62d81a8a6f5dc5fe8abfc3901fc52ddf15016" + integrity sha512-9DGttpmPvIxBb/2uwpVo3dqJ+O6RooAFOS+lB+xDqoE2PVCE8nfoHMdZLpfCQRLwvohzXISPZcgxt80xLfsuwg== + dependencies: + "@babel/code-frame" "^7.25.9" + "@babel/parser" "^7.25.9" + "@babel/types" "^7.25.9" + "@babel/traverse@^7.18.9", "@babel/traverse@^7.23.2", "@babel/traverse@^7.24.1", "@babel/traverse@^7.4.5", "@babel/traverse@^7.8.3": version "7.24.1" resolved "https://registry.yarnpkg.com/@babel/traverse/-/traverse-7.24.1.tgz#d65c36ac9dd17282175d1e4a3c49d5b7988f530c" @@ -1801,6 +1914,19 @@ debug "^4.3.1" globals "^11.1.0" +"@babel/traverse@^7.25.9": + version "7.26.4" + resolved "https://registry.yarnpkg.com/@babel/traverse/-/traverse-7.26.4.tgz#ac3a2a84b908dde6d463c3bfa2c5fdc1653574bd" + integrity sha512-fH+b7Y4p3yqvApJALCPJcwb0/XaOSgtK4pzV6WVjPR5GLFQBRI7pfoX2V2iM48NXvX07NUxxm1Vw98YjqTcU5w== + dependencies: + "@babel/code-frame" "^7.26.2" + "@babel/generator" "^7.26.3" + "@babel/parser" "^7.26.3" + "@babel/template" "^7.25.9" + "@babel/types" "^7.26.3" + debug "^4.3.1" + globals "^11.1.0" + "@babel/types@^7.0.0", "@babel/types@^7.18.9", "@babel/types@^7.20.7", "@babel/types@^7.22.15", "@babel/types@^7.22.19", "@babel/types@^7.22.5", "@babel/types@^7.23.0", "@babel/types@^7.24.0", "@babel/types@^7.4.4": version "7.24.0" resolved "https://registry.yarnpkg.com/@babel/types/-/types-7.24.0.tgz#3b951f435a92e7333eba05b7566fd297960ea1bf" @@ -1810,6 +1936,14 @@ "@babel/helper-validator-identifier" "^7.22.20" to-fast-properties "^2.0.0" +"@babel/types@^7.25.9", "@babel/types@^7.26.0", "@babel/types@^7.26.3": + version "7.26.3" + resolved "https://registry.yarnpkg.com/@babel/types/-/types-7.26.3.tgz#37e79830f04c2b5687acc77db97fbc75fb81f3c0" + integrity sha512-vN5p+1kl59GVKMvTHt55NzzmYVxprfJD+ql7U9NFIfKCBkYE55LYtS+WtPlaYOyzydrKI8Nezd+aZextrd+FMA== + dependencies: + "@babel/helper-string-parser" "^7.25.9" + "@babel/helper-validator-identifier" "^7.25.9" + "@base2/pretty-print-object@1.0.1": version "1.0.1" resolved "https://registry.yarnpkg.com/@base2/pretty-print-object/-/pretty-print-object-1.0.1.tgz#371ba8be66d556812dc7fb169ebc3c08378f69d4" @@ -1820,6 +1954,23 @@ resolved "https://registry.yarnpkg.com/@bcoe/v8-coverage/-/v8-coverage-0.2.3.tgz#75a2e8b51cb758a7553d6804a5932d7aace75c39" integrity sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw== +"@clack/core@0.3.5", "@clack/core@^0.3.5": + version "0.3.5" + resolved "https://registry.yarnpkg.com/@clack/core/-/core-0.3.5.tgz#3e1454c83a329353cc3a6ff8491e4284d49565bb" + integrity sha512-5cfhQNH+1VQ2xLQlmzXMqUoiaH0lRBq9/CLW9lTyMbuKLC3+xEK01tHVvyut++mLOn5urSHmkm6I0Lg9MaJSTQ== + dependencies: + picocolors "^1.0.0" + sisteransi "^1.0.5" + +"@clack/prompts@^0.8.2": + version "0.8.2" + resolved "https://registry.yarnpkg.com/@clack/prompts/-/prompts-0.8.2.tgz#86287d2690dffb3e598d208737451865930d37ba" + integrity sha512-6b9Ab2UiZwJYA9iMyboYyW9yJvAO9V753ZhS+DHKEjZRKAxPPOb7MXXu84lsPFG+vZt6FRFniZ8rXi+zCIw4yQ== + dependencies: + "@clack/core" "0.3.5" + picocolors "^1.0.0" + sisteransi "^1.0.5" + "@colors/colors@1.5.0": version "1.5.0" resolved "https://registry.yarnpkg.com/@colors/colors/-/colors-1.5.0.tgz#bb504579c1cae923e6576a4f5da43d25f97bdbd9" @@ -2420,6 +2571,11 @@ resolved "https://registry.yarnpkg.com/@esbuild/aix-ppc64/-/aix-ppc64-0.21.5.tgz#c7184a326533fcdf1b8ee0733e21c713b975575f" integrity sha512-1SDgH6ZSPTlggy1yI6+Dbkiz8xzpHJEVAlF/AM1tHPLsf5STom9rwtjE4hKAF20FfXXNTFqEYXyJNWh1GiZedQ== +"@esbuild/aix-ppc64@0.23.1": + version "0.23.1" + resolved "https://registry.yarnpkg.com/@esbuild/aix-ppc64/-/aix-ppc64-0.23.1.tgz#51299374de171dbd80bb7d838e1cfce9af36f353" + integrity sha512-6VhYk1diRqrhBAqpJEdjASR/+WVRtfjpqKuNw11cLiaWpAT/Uu+nokB+UJnevzy/P9C/ty6AOe0dwueMrGh/iQ== + "@esbuild/android-arm64@0.18.20": version "0.18.20" resolved "https://registry.yarnpkg.com/@esbuild/android-arm64/-/android-arm64-0.18.20.tgz#984b4f9c8d0377443cc2dfcef266d02244593622" @@ -2440,6 +2596,11 @@ resolved "https://registry.yarnpkg.com/@esbuild/android-arm64/-/android-arm64-0.21.5.tgz#09d9b4357780da9ea3a7dfb833a1f1ff439b4052" integrity sha512-c0uX9VAUBQ7dTDCjq+wdyGLowMdtR/GoC2U5IYk/7D1H1JYC0qseD7+11iMP2mRLN9RcCMRcjC4YMclCzGwS/A== +"@esbuild/android-arm64@0.23.1": + version "0.23.1" + resolved "https://registry.yarnpkg.com/@esbuild/android-arm64/-/android-arm64-0.23.1.tgz#58565291a1fe548638adb9c584237449e5e14018" + integrity sha512-xw50ipykXcLstLeWH7WRdQuysJqejuAGPd30vd1i5zSyKK3WE+ijzHmLKxdiCMtH1pHz78rOg0BKSYOSB/2Khw== + "@esbuild/android-arm@0.18.20": version "0.18.20" resolved "https://registry.yarnpkg.com/@esbuild/android-arm/-/android-arm-0.18.20.tgz#fedb265bc3a589c84cc11f810804f234947c3682" @@ -2460,6 +2621,11 @@ resolved "https://registry.yarnpkg.com/@esbuild/android-arm/-/android-arm-0.21.5.tgz#9b04384fb771926dfa6d7ad04324ecb2ab9b2e28" integrity sha512-vCPvzSjpPHEi1siZdlvAlsPxXl7WbOVUBBAowWug4rJHb68Ox8KualB+1ocNvT5fjv6wpkX6o/iEpbDrf68zcg== +"@esbuild/android-arm@0.23.1": + version "0.23.1" + resolved "https://registry.yarnpkg.com/@esbuild/android-arm/-/android-arm-0.23.1.tgz#5eb8c652d4c82a2421e3395b808e6d9c42c862ee" + integrity sha512-uz6/tEy2IFm9RYOyvKl88zdzZfwEfKZmnX9Cj1BHjeSGNuGLuMD1kR8y5bteYmwqKm1tj8m4cb/aKEorr6fHWQ== + "@esbuild/android-x64@0.18.20": version "0.18.20" resolved "https://registry.yarnpkg.com/@esbuild/android-x64/-/android-x64-0.18.20.tgz#35cf419c4cfc8babe8893d296cd990e9e9f756f2" @@ -2480,6 +2646,11 @@ resolved "https://registry.yarnpkg.com/@esbuild/android-x64/-/android-x64-0.21.5.tgz#29918ec2db754cedcb6c1b04de8cd6547af6461e" integrity sha512-D7aPRUUNHRBwHxzxRvp856rjUHRFW1SdQATKXH2hqA0kAZb1hKmi02OpYRacl0TxIGz/ZmXWlbZgjwWYaCakTA== +"@esbuild/android-x64@0.23.1": + version "0.23.1" + resolved "https://registry.yarnpkg.com/@esbuild/android-x64/-/android-x64-0.23.1.tgz#ae19d665d2f06f0f48a6ac9a224b3f672e65d517" + integrity sha512-nlN9B69St9BwUoB+jkyU090bru8L0NA3yFvAd7k8dNsVH8bi9a8cUAUSEcEEgTp2z3dbEDGJGfP6VUnkQnlReg== + "@esbuild/darwin-arm64@0.18.20": version "0.18.20" resolved "https://registry.yarnpkg.com/@esbuild/darwin-arm64/-/darwin-arm64-0.18.20.tgz#08172cbeccf95fbc383399a7f39cfbddaeb0d7c1" @@ -2500,6 +2671,11 @@ resolved "https://registry.yarnpkg.com/@esbuild/darwin-arm64/-/darwin-arm64-0.21.5.tgz#e495b539660e51690f3928af50a76fb0a6ccff2a" integrity sha512-DwqXqZyuk5AiWWf3UfLiRDJ5EDd49zg6O9wclZ7kUMv2WRFr4HKjXp/5t8JZ11QbQfUS6/cRCKGwYhtNAY88kQ== +"@esbuild/darwin-arm64@0.23.1": + version "0.23.1" + resolved "https://registry.yarnpkg.com/@esbuild/darwin-arm64/-/darwin-arm64-0.23.1.tgz#05b17f91a87e557b468a9c75e9d85ab10c121b16" + integrity sha512-YsS2e3Wtgnw7Wq53XXBLcV6JhRsEq8hkfg91ESVadIrzr9wO6jJDMZnCQbHm1Guc5t/CdDiFSSfWP58FNuvT3Q== + "@esbuild/darwin-x64@0.18.20": version "0.18.20" resolved "https://registry.yarnpkg.com/@esbuild/darwin-x64/-/darwin-x64-0.18.20.tgz#d70d5790d8bf475556b67d0f8b7c5bdff053d85d" @@ -2520,6 +2696,11 @@ resolved "https://registry.yarnpkg.com/@esbuild/darwin-x64/-/darwin-x64-0.21.5.tgz#c13838fa57372839abdddc91d71542ceea2e1e22" integrity sha512-se/JjF8NlmKVG4kNIuyWMV/22ZaerB+qaSi5MdrXtd6R08kvs2qCN4C09miupktDitvh8jRFflwGFBQcxZRjbw== +"@esbuild/darwin-x64@0.23.1": + version "0.23.1" + resolved "https://registry.yarnpkg.com/@esbuild/darwin-x64/-/darwin-x64-0.23.1.tgz#c58353b982f4e04f0d022284b8ba2733f5ff0931" + integrity sha512-aClqdgTDVPSEGgoCS8QDG37Gu8yc9lTHNAQlsztQ6ENetKEO//b8y31MMu2ZaPbn4kVsIABzVLXYLhCGekGDqw== + "@esbuild/freebsd-arm64@0.18.20": version "0.18.20" resolved "https://registry.yarnpkg.com/@esbuild/freebsd-arm64/-/freebsd-arm64-0.18.20.tgz#98755cd12707f93f210e2494d6a4b51b96977f54" @@ -2540,6 +2721,11 @@ resolved "https://registry.yarnpkg.com/@esbuild/freebsd-arm64/-/freebsd-arm64-0.21.5.tgz#646b989aa20bf89fd071dd5dbfad69a3542e550e" integrity sha512-5JcRxxRDUJLX8JXp/wcBCy3pENnCgBR9bN6JsY4OmhfUtIHe3ZW0mawA7+RDAcMLrMIZaf03NlQiX9DGyB8h4g== +"@esbuild/freebsd-arm64@0.23.1": + version "0.23.1" + resolved "https://registry.yarnpkg.com/@esbuild/freebsd-arm64/-/freebsd-arm64-0.23.1.tgz#f9220dc65f80f03635e1ef96cfad5da1f446f3bc" + integrity sha512-h1k6yS8/pN/NHlMl5+v4XPfikhJulk4G+tKGFIOwURBSFzE8bixw1ebjluLOjfwtLqY0kewfjLSrO6tN2MgIhA== + "@esbuild/freebsd-x64@0.18.20": version "0.18.20" resolved "https://registry.yarnpkg.com/@esbuild/freebsd-x64/-/freebsd-x64-0.18.20.tgz#c1eb2bff03915f87c29cece4c1a7fa1f423b066e" @@ -2560,6 +2746,11 @@ resolved "https://registry.yarnpkg.com/@esbuild/freebsd-x64/-/freebsd-x64-0.21.5.tgz#aa615cfc80af954d3458906e38ca22c18cf5c261" integrity sha512-J95kNBj1zkbMXtHVH29bBriQygMXqoVQOQYA+ISs0/2l3T9/kj42ow2mpqerRBxDJnmkUDCaQT/dfNXWX/ZZCQ== +"@esbuild/freebsd-x64@0.23.1": + version "0.23.1" + resolved "https://registry.yarnpkg.com/@esbuild/freebsd-x64/-/freebsd-x64-0.23.1.tgz#69bd8511fa013b59f0226d1609ac43f7ce489730" + integrity sha512-lK1eJeyk1ZX8UklqFd/3A60UuZ/6UVfGT2LuGo3Wp4/z7eRTRYY+0xOu2kpClP+vMTi9wKOfXi2vjUpO1Ro76g== + "@esbuild/linux-arm64@0.18.20": version "0.18.20" resolved "https://registry.yarnpkg.com/@esbuild/linux-arm64/-/linux-arm64-0.18.20.tgz#bad4238bd8f4fc25b5a021280c770ab5fc3a02a0" @@ -2580,6 +2771,11 @@ resolved "https://registry.yarnpkg.com/@esbuild/linux-arm64/-/linux-arm64-0.21.5.tgz#70ac6fa14f5cb7e1f7f887bcffb680ad09922b5b" integrity sha512-ibKvmyYzKsBeX8d8I7MH/TMfWDXBF3db4qM6sy+7re0YXya+K1cem3on9XgdT2EQGMu4hQyZhan7TeQ8XkGp4Q== +"@esbuild/linux-arm64@0.23.1": + version "0.23.1" + resolved "https://registry.yarnpkg.com/@esbuild/linux-arm64/-/linux-arm64-0.23.1.tgz#8050af6d51ddb388c75653ef9871f5ccd8f12383" + integrity sha512-/93bf2yxencYDnItMYV/v116zff6UyTjo4EtEQjUBeGiVpMmffDNUyD9UN2zV+V3LRV3/on4xdZ26NKzn6754g== + "@esbuild/linux-arm@0.18.20": version "0.18.20" resolved "https://registry.yarnpkg.com/@esbuild/linux-arm/-/linux-arm-0.18.20.tgz#3e617c61f33508a27150ee417543c8ab5acc73b0" @@ -2600,6 +2796,11 @@ resolved "https://registry.yarnpkg.com/@esbuild/linux-arm/-/linux-arm-0.21.5.tgz#fc6fd11a8aca56c1f6f3894f2bea0479f8f626b9" integrity sha512-bPb5AHZtbeNGjCKVZ9UGqGwo8EUu4cLq68E95A53KlxAPRmUyYv2D6F0uUI65XisGOL1hBP5mTronbgo+0bFcA== +"@esbuild/linux-arm@0.23.1": + version "0.23.1" + resolved "https://registry.yarnpkg.com/@esbuild/linux-arm/-/linux-arm-0.23.1.tgz#ecaabd1c23b701070484990db9a82f382f99e771" + integrity sha512-CXXkzgn+dXAPs3WBwE+Kvnrf4WECwBdfjfeYHpMeVxWE0EceB6vhWGShs6wi0IYEqMSIzdOF1XjQ/Mkm5d7ZdQ== + "@esbuild/linux-ia32@0.18.20": version "0.18.20" resolved "https://registry.yarnpkg.com/@esbuild/linux-ia32/-/linux-ia32-0.18.20.tgz#699391cccba9aee6019b7f9892eb99219f1570a7" @@ -2620,6 +2821,11 @@ resolved "https://registry.yarnpkg.com/@esbuild/linux-ia32/-/linux-ia32-0.21.5.tgz#3271f53b3f93e3d093d518d1649d6d68d346ede2" integrity sha512-YvjXDqLRqPDl2dvRODYmmhz4rPeVKYvppfGYKSNGdyZkA01046pLWyRKKI3ax8fbJoK5QbxblURkwK/MWY18Tg== +"@esbuild/linux-ia32@0.23.1": + version "0.23.1" + resolved "https://registry.yarnpkg.com/@esbuild/linux-ia32/-/linux-ia32-0.23.1.tgz#3ed2273214178109741c09bd0687098a0243b333" + integrity sha512-VTN4EuOHwXEkXzX5nTvVY4s7E/Krz7COC8xkftbbKRYAl96vPiUssGkeMELQMOnLOJ8k3BY1+ZY52tttZnHcXQ== + "@esbuild/linux-loong64@0.18.20": version "0.18.20" resolved "https://registry.yarnpkg.com/@esbuild/linux-loong64/-/linux-loong64-0.18.20.tgz#e6fccb7aac178dd2ffb9860465ac89d7f23b977d" @@ -2640,6 +2846,11 @@ resolved "https://registry.yarnpkg.com/@esbuild/linux-loong64/-/linux-loong64-0.21.5.tgz#ed62e04238c57026aea831c5a130b73c0f9f26df" integrity sha512-uHf1BmMG8qEvzdrzAqg2SIG/02+4/DHB6a9Kbya0XDvwDEKCoC8ZRWI5JJvNdUjtciBGFQ5PuBlpEOXQj+JQSg== +"@esbuild/linux-loong64@0.23.1": + version "0.23.1" + resolved "https://registry.yarnpkg.com/@esbuild/linux-loong64/-/linux-loong64-0.23.1.tgz#a0fdf440b5485c81b0fbb316b08933d217f5d3ac" + integrity sha512-Vx09LzEoBa5zDnieH8LSMRToj7ir/Jeq0Gu6qJ/1GcBq9GkfoEAoXvLiW1U9J1qE/Y/Oyaq33w5p2ZWrNNHNEw== + "@esbuild/linux-mips64el@0.18.20": version "0.18.20" resolved "https://registry.yarnpkg.com/@esbuild/linux-mips64el/-/linux-mips64el-0.18.20.tgz#eeff3a937de9c2310de30622a957ad1bd9183231" @@ -2660,6 +2871,11 @@ resolved "https://registry.yarnpkg.com/@esbuild/linux-mips64el/-/linux-mips64el-0.21.5.tgz#e79b8eb48bf3b106fadec1ac8240fb97b4e64cbe" integrity sha512-IajOmO+KJK23bj52dFSNCMsz1QP1DqM6cwLUv3W1QwyxkyIWecfafnI555fvSGqEKwjMXVLokcV5ygHW5b3Jbg== +"@esbuild/linux-mips64el@0.23.1": + version "0.23.1" + resolved "https://registry.yarnpkg.com/@esbuild/linux-mips64el/-/linux-mips64el-0.23.1.tgz#e11a2806346db8375b18f5e104c5a9d4e81807f6" + integrity sha512-nrFzzMQ7W4WRLNUOU5dlWAqa6yVeI0P78WKGUo7lg2HShq/yx+UYkeNSE0SSfSure0SqgnsxPvmAUu/vu0E+3Q== + "@esbuild/linux-ppc64@0.18.20": version "0.18.20" resolved "https://registry.yarnpkg.com/@esbuild/linux-ppc64/-/linux-ppc64-0.18.20.tgz#2f7156bde20b01527993e6881435ad79ba9599fb" @@ -2680,6 +2896,11 @@ resolved "https://registry.yarnpkg.com/@esbuild/linux-ppc64/-/linux-ppc64-0.21.5.tgz#5f2203860a143b9919d383ef7573521fb154c3e4" integrity sha512-1hHV/Z4OEfMwpLO8rp7CvlhBDnjsC3CttJXIhBi+5Aj5r+MBvy4egg7wCbe//hSsT+RvDAG7s81tAvpL2XAE4w== +"@esbuild/linux-ppc64@0.23.1": + version "0.23.1" + resolved "https://registry.yarnpkg.com/@esbuild/linux-ppc64/-/linux-ppc64-0.23.1.tgz#06a2744c5eaf562b1a90937855b4d6cf7c75ec96" + integrity sha512-dKN8fgVqd0vUIjxuJI6P/9SSSe/mB9rvA98CSH2sJnlZ/OCZWO1DJvxj8jvKTfYUdGfcq2dDxoKaC6bHuTlgcw== + "@esbuild/linux-riscv64@0.18.20": version "0.18.20" resolved "https://registry.yarnpkg.com/@esbuild/linux-riscv64/-/linux-riscv64-0.18.20.tgz#6628389f210123d8b4743045af8caa7d4ddfc7a6" @@ -2700,6 +2921,11 @@ resolved "https://registry.yarnpkg.com/@esbuild/linux-riscv64/-/linux-riscv64-0.21.5.tgz#07bcafd99322d5af62f618cb9e6a9b7f4bb825dc" integrity sha512-2HdXDMd9GMgTGrPWnJzP2ALSokE/0O5HhTUvWIbD3YdjME8JwvSCnNGBnTThKGEB91OZhzrJ4qIIxk/SBmyDDA== +"@esbuild/linux-riscv64@0.23.1": + version "0.23.1" + resolved "https://registry.yarnpkg.com/@esbuild/linux-riscv64/-/linux-riscv64-0.23.1.tgz#65b46a2892fc0d1af4ba342af3fe0fa4a8fe08e7" + integrity sha512-5AV4Pzp80fhHL83JM6LoA6pTQVWgB1HovMBsLQ9OZWLDqVY8MVobBXNSmAJi//Csh6tcY7e7Lny2Hg1tElMjIA== + "@esbuild/linux-s390x@0.18.20": version "0.18.20" resolved "https://registry.yarnpkg.com/@esbuild/linux-s390x/-/linux-s390x-0.18.20.tgz#255e81fb289b101026131858ab99fba63dcf0071" @@ -2720,6 +2946,11 @@ resolved "https://registry.yarnpkg.com/@esbuild/linux-s390x/-/linux-s390x-0.21.5.tgz#b7ccf686751d6a3e44b8627ababc8be3ef62d8de" integrity sha512-zus5sxzqBJD3eXxwvjN1yQkRepANgxE9lgOW2qLnmr8ikMTphkjgXu1HR01K4FJg8h1kEEDAqDcZQtbrRnB41A== +"@esbuild/linux-s390x@0.23.1": + version "0.23.1" + resolved "https://registry.yarnpkg.com/@esbuild/linux-s390x/-/linux-s390x-0.23.1.tgz#e71ea18c70c3f604e241d16e4e5ab193a9785d6f" + integrity sha512-9ygs73tuFCe6f6m/Tb+9LtYxWR4c9yg7zjt2cYkjDbDpV/xVn+68cQxMXCjUpYwEkze2RcU/rMnfIXNRFmSoDw== + "@esbuild/linux-x64@0.18.20": version "0.18.20" resolved "https://registry.yarnpkg.com/@esbuild/linux-x64/-/linux-x64-0.18.20.tgz#c7690b3417af318a9b6f96df3031a8865176d338" @@ -2740,6 +2971,11 @@ resolved "https://registry.yarnpkg.com/@esbuild/linux-x64/-/linux-x64-0.21.5.tgz#6d8f0c768e070e64309af8004bb94e68ab2bb3b0" integrity sha512-1rYdTpyv03iycF1+BhzrzQJCdOuAOtaqHTWJZCWvijKD2N5Xu0TtVC8/+1faWqcP9iBCWOmjmhoH94dH82BxPQ== +"@esbuild/linux-x64@0.23.1": + version "0.23.1" + resolved "https://registry.yarnpkg.com/@esbuild/linux-x64/-/linux-x64-0.23.1.tgz#d47f97391e80690d4dfe811a2e7d6927ad9eed24" + integrity sha512-EV6+ovTsEXCPAp58g2dD68LxoP/wK5pRvgy0J/HxPGB009omFPv3Yet0HiaqvrIrgPTBuC6wCH1LTOY91EO5hQ== + "@esbuild/netbsd-x64@0.18.20": version "0.18.20" resolved "https://registry.yarnpkg.com/@esbuild/netbsd-x64/-/netbsd-x64-0.18.20.tgz#30e8cd8a3dded63975e2df2438ca109601ebe0d1" @@ -2760,6 +2996,16 @@ resolved "https://registry.yarnpkg.com/@esbuild/netbsd-x64/-/netbsd-x64-0.21.5.tgz#bbe430f60d378ecb88decb219c602667387a6047" integrity sha512-Woi2MXzXjMULccIwMnLciyZH4nCIMpWQAs049KEeMvOcNADVxo0UBIQPfSmxB3CWKedngg7sWZdLvLczpe0tLg== +"@esbuild/netbsd-x64@0.23.1": + version "0.23.1" + resolved "https://registry.yarnpkg.com/@esbuild/netbsd-x64/-/netbsd-x64-0.23.1.tgz#44e743c9778d57a8ace4b72f3c6b839a3b74a653" + integrity sha512-aevEkCNu7KlPRpYLjwmdcuNz6bDFiE7Z8XC4CPqExjTvrHugh28QzUXVOZtiYghciKUacNktqxdpymplil1beA== + +"@esbuild/openbsd-arm64@0.23.1": + version "0.23.1" + resolved "https://registry.yarnpkg.com/@esbuild/openbsd-arm64/-/openbsd-arm64-0.23.1.tgz#05c5a1faf67b9881834758c69f3e51b7dee015d7" + integrity sha512-3x37szhLexNA4bXhLrCC/LImN/YtWis6WXr1VESlfVtVeoFJBRINPJ3f0a/6LV8zpikqoUg4hyXw0sFBt5Cr+Q== + "@esbuild/openbsd-x64@0.18.20": version "0.18.20" resolved "https://registry.yarnpkg.com/@esbuild/openbsd-x64/-/openbsd-x64-0.18.20.tgz#7812af31b205055874c8082ea9cf9ab0da6217ae" @@ -2780,6 +3026,11 @@ resolved "https://registry.yarnpkg.com/@esbuild/openbsd-x64/-/openbsd-x64-0.21.5.tgz#99d1cf2937279560d2104821f5ccce220cb2af70" integrity sha512-HLNNw99xsvx12lFBUwoT8EVCsSvRNDVxNpjZ7bPn947b8gJPzeHWyNVhFsaerc0n3TsbOINvRP2byTZ5LKezow== +"@esbuild/openbsd-x64@0.23.1": + version "0.23.1" + resolved "https://registry.yarnpkg.com/@esbuild/openbsd-x64/-/openbsd-x64-0.23.1.tgz#2e58ae511bacf67d19f9f2dcd9e8c5a93f00c273" + integrity sha512-aY2gMmKmPhxfU+0EdnN+XNtGbjfQgwZj43k8G3fyrDM/UdZww6xrWxmDkuz2eCZchqVeABjV5BpildOrUbBTqA== + "@esbuild/sunos-x64@0.18.20": version "0.18.20" resolved "https://registry.yarnpkg.com/@esbuild/sunos-x64/-/sunos-x64-0.18.20.tgz#d5c275c3b4e73c9b0ecd38d1ca62c020f887ab9d" @@ -2800,6 +3051,11 @@ resolved "https://registry.yarnpkg.com/@esbuild/sunos-x64/-/sunos-x64-0.21.5.tgz#08741512c10d529566baba837b4fe052c8f3487b" integrity sha512-6+gjmFpfy0BHU5Tpptkuh8+uw3mnrvgs+dSPQXQOv3ekbordwnzTVEb4qnIvQcYXq6gzkyTnoZ9dZG+D4garKg== +"@esbuild/sunos-x64@0.23.1": + version "0.23.1" + resolved "https://registry.yarnpkg.com/@esbuild/sunos-x64/-/sunos-x64-0.23.1.tgz#adb022b959d18d3389ac70769cef5a03d3abd403" + integrity sha512-RBRT2gqEl0IKQABT4XTj78tpk9v7ehp+mazn2HbUeZl1YMdaGAQqhapjGTCe7uw7y0frDi4gS0uHzhvpFuI1sA== + "@esbuild/win32-arm64@0.18.20": version "0.18.20" resolved "https://registry.yarnpkg.com/@esbuild/win32-arm64/-/win32-arm64-0.18.20.tgz#73bc7f5a9f8a77805f357fab97f290d0e4820ac9" @@ -2820,6 +3076,11 @@ resolved "https://registry.yarnpkg.com/@esbuild/win32-arm64/-/win32-arm64-0.21.5.tgz#675b7385398411240735016144ab2e99a60fc75d" integrity sha512-Z0gOTd75VvXqyq7nsl93zwahcTROgqvuAcYDUr+vOv8uHhNSKROyU961kgtCD1e95IqPKSQKH7tBTslnS3tA8A== +"@esbuild/win32-arm64@0.23.1": + version "0.23.1" + resolved "https://registry.yarnpkg.com/@esbuild/win32-arm64/-/win32-arm64-0.23.1.tgz#84906f50c212b72ec360f48461d43202f4c8b9a2" + integrity sha512-4O+gPR5rEBe2FpKOVyiJ7wNDPA8nGzDuJ6gN4okSA1gEOYZ67N8JPk58tkWtdtPeLz7lBnY6I5L3jdsr3S+A6A== + "@esbuild/win32-ia32@0.18.20": version "0.18.20" resolved "https://registry.yarnpkg.com/@esbuild/win32-ia32/-/win32-ia32-0.18.20.tgz#ec93cbf0ef1085cc12e71e0d661d20569ff42102" @@ -2840,6 +3101,11 @@ resolved "https://registry.yarnpkg.com/@esbuild/win32-ia32/-/win32-ia32-0.21.5.tgz#1bfc3ce98aa6ca9a0969e4d2af72144c59c1193b" integrity sha512-SWXFF1CL2RVNMaVs+BBClwtfZSvDgtL//G/smwAc5oVK/UPu2Gu9tIaRgFmYFFKrmg3SyAjSrElf0TiJ1v8fYA== +"@esbuild/win32-ia32@0.23.1": + version "0.23.1" + resolved "https://registry.yarnpkg.com/@esbuild/win32-ia32/-/win32-ia32-0.23.1.tgz#5e3eacc515820ff729e90d0cb463183128e82fac" + integrity sha512-BcaL0Vn6QwCwre3Y717nVHZbAa4UBEigzFm6VdsVdT/MbZ38xoj1X9HPkZhbmaBGUD1W8vxAfffbDe8bA6AKnQ== + "@esbuild/win32-x64@0.18.20": version "0.18.20" resolved "https://registry.yarnpkg.com/@esbuild/win32-x64/-/win32-x64-0.18.20.tgz#786c5f41f043b07afb1af37683d7c33668858f6d" @@ -2860,6 +3126,11 @@ resolved "https://registry.yarnpkg.com/@esbuild/win32-x64/-/win32-x64-0.21.5.tgz#acad351d582d157bb145535db2a6ff53dd514b5c" integrity sha512-tQd/1efJuzPC6rCFwEvLtci/xNFcTZknmXs98FYDfGE4wP9ClFV98nyKrzJKVPMhdDnjzLhdUyMX4PsQAPjwIw== +"@esbuild/win32-x64@0.23.1": + version "0.23.1" + resolved "https://registry.yarnpkg.com/@esbuild/win32-x64/-/win32-x64-0.23.1.tgz#81fd50d11e2c32b2d6241470e3185b70c7b30699" + integrity sha512-BHpFFeslkWrXWyUPnbKm+xYYVYruCinGcftSBaa8zoF9hZO4BcSCFUvHVTtzpIY6YzUnYtuEhZ+C9iEXjxnasg== + "@eslint-community/eslint-utils@^4.1.2", "@eslint-community/eslint-utils@^4.2.0", "@eslint-community/eslint-utils@^4.4.0": version "4.4.0" resolved "https://registry.yarnpkg.com/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz#a23514e8fb9af1269d5f7788aa556798d61c6b59" @@ -3511,6 +3782,18 @@ resolved "https://registry.yarnpkg.com/@popperjs/core/-/core-2.1.1.tgz#12c572ab88ef7345b43f21883fca26631c223085" integrity sha512-sLqWxCzC5/QHLhziXSCAksBxHfOnQlhPRVgPK0egEw+ktWvG75T2k+aYWVjVh9+WKeT3tlG3ZNbZQvZLmfuOIw== +"@preact/signals-core@^1.7.0": + version "1.8.0" + resolved "https://registry.yarnpkg.com/@preact/signals-core/-/signals-core-1.8.0.tgz#45ffadb81b48a298a4accd26b3f6c0140cd6dacc" + integrity sha512-OBvUsRZqNmjzCZXWLxkZfhcgT+Fk8DDcT/8vD6a1xhDemodyy87UJRJfASMuSD8FaAIeGgGm85ydXhm7lr4fyA== + +"@preact/signals@^1.3.1": + version "1.3.1" + resolved "https://registry.yarnpkg.com/@preact/signals/-/signals-1.3.1.tgz#d11c8ad83abab1a0808e0f30a83e1517f8331f01" + integrity sha512-nNvSF2O7RDzxp1Rm7SkA5QhN1a2kN8pGE8J5o6UjgDof0F0Vlg6d6HUUVxxqZ1uJrN9xnH2DpL6rpII3Es0SsQ== + dependencies: + "@preact/signals-core" "^1.7.0" + "@radix-ui/number@1.0.1": version "1.0.1" resolved "https://registry.yarnpkg.com/@radix-ui/number/-/number-1.0.1.tgz#644161a3557f46ed38a042acf4a770e826021674" @@ -3940,6 +4223,15 @@ estree-walker "^2.0.2" picomatch "^2.3.1" +"@rollup/pluginutils@^5.1.3": + version "5.1.3" + resolved "https://registry.yarnpkg.com/@rollup/pluginutils/-/pluginutils-5.1.3.tgz#3001bf1a03f3ad24457591f2c259c8e514e0dbdf" + integrity sha512-Pnsb6f32CD2W3uCaLZIzDmeFyQ2b8UWMFI7xtwUezpcGBDVDW6y9XgAWIlARiGAo6eNF5FK5aQTr0LFyNyqq5A== + dependencies: + "@types/estree" "^1.0.0" + estree-walker "^2.0.2" + picomatch "^4.0.2" + "@rollup/rollup-android-arm-eabi@4.16.2": version "4.16.2" resolved "https://registry.yarnpkg.com/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.16.2.tgz#29b7b3c70ddf532fe6dcf859cbfc3e4714c34842" @@ -5637,7 +5929,7 @@ dependencies: undici-types "~5.26.4" -"@types/node@^20.9.0": +"@types/node@^20.17.9", "@types/node@^20.9.0": version "20.17.9" resolved "https://registry.yarnpkg.com/@types/node/-/node-20.17.9.tgz#5f141d4b7ee125cdee5faefe28de095398865bab" integrity sha512-0JOXkRyLanfGPE2QRCwgxhzlBAvaRdCNMcvbd7jFfpmD4eEXll7LRwy5ymJmyeZqk7Nh7eD2LeUyQ68BbndmXw== @@ -6449,6 +6741,11 @@ acorn@^8.10.0, acorn@^8.11.3, acorn@^8.2.4, acorn@^8.8.2, acorn@^8.9.0: resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.11.3.tgz#71e0b14e13a4ec160724b38fb7b0f233b1b81d7a" integrity sha512-Y9rRfJG5jcKOE0CLisYbojUjIrIEE7AGMzA/Sm4BslANhbS+cDMpgBdcPT91oJ7OuJ9hYJBx59RjbhxVnrF8Xg== +acorn@^8.14.0: + version "8.14.0" + resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.14.0.tgz#063e2c70cac5fb4f6467f0b11152e04c682795b0" + integrity sha512-cl669nCJTZBsL97OF4kUQm5g5hC2uihk0NxY3WENAC0TYdILVkAyHymAntgxGkl7K+t0cXIrH5siy5S4XkFycA== + add-stream@^1.0.0: version "1.0.0" resolved "https://registry.yarnpkg.com/add-stream/-/add-stream-1.0.0.tgz#6a7990437ca736d5e1288db92bd3266d5f5cb2aa" @@ -7327,6 +7624,11 @@ bindings@^1.5.0: dependencies: file-uri-to-path "1.0.0" +bippy@^0.0.10: + version "0.0.10" + resolved "https://registry.yarnpkg.com/bippy/-/bippy-0.0.10.tgz#30e746e2fe18ccf31c18896f1c98e48238715888" + integrity sha512-2E8U2h/3ZltRwxfVkT1c2DqWUjgIGFRg8cD1qQDJ0m7YOJCpxqI87s+vaaEzvIxRw4MJOUVJ3OZ6K904UNX+iw== + bl@^1.0.0: version "1.2.3" resolved "https://registry.yarnpkg.com/bl/-/bl-1.2.3.tgz#1e8dd80142eac80d7158c9dccc047fb620e035e7" @@ -7595,6 +7897,16 @@ browserslist@^4.0.0, browserslist@^4.12.0, browserslist@^4.22.1, browserslist@^4 node-releases "^2.0.14" update-browserslist-db "^1.0.13" +browserslist@^4.24.0: + version "4.24.2" + resolved "https://registry.yarnpkg.com/browserslist/-/browserslist-4.24.2.tgz#f5845bc91069dbd55ee89faf9822e1d885d16580" + integrity sha512-ZIc+Q62revdMcqC6aChtW4jz3My3klmCO1fEmINZY/8J3EpBg5/A/D0AKmBveUh6pgoeycoMkVMko84tuYS+Gg== + dependencies: + caniuse-lite "^1.0.30001669" + electron-to-chromium "^1.5.41" + node-releases "^2.0.18" + update-browserslist-db "^1.1.1" + bser@2.1.1: version "2.1.1" resolved "https://registry.yarnpkg.com/bser/-/bser-2.1.1.tgz#e6787da20ece9d07998533cfd9de6f5c38f4bc05" @@ -7994,6 +8306,11 @@ caniuse-lite@^1.0.0, caniuse-lite@^1.0.30001109, caniuse-lite@^1.0.30001587, can resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001612.tgz#d34248b4ec1f117b70b24ad9ee04c90e0b8a14ae" integrity sha512-lFgnZ07UhaCcsSZgWW0K5j4e69dK1u/ltrL9lTUiFOwNHs12S3UMIEYgBV0Z6C6hRDev7iRnMzzYmKabYdXF9g== +caniuse-lite@^1.0.30001669: + version "1.0.30001687" + resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001687.tgz#d0ac634d043648498eedf7a3932836beba90ebae" + integrity sha512-0S/FDhf4ZiqrTUiQ39dKeUjYRjkv7lOZU1Dgif2rIqrTzX/1wV2hfKu9TOm1IHkdSijfLswxTFzl/cvir+SLSQ== + caseless@~0.12.0: version "0.12.0" resolved "https://registry.yarnpkg.com/caseless/-/caseless-0.12.0.tgz#1b681c21ff84033c826543090689420d187151dc" @@ -10371,6 +10688,11 @@ electron-to-chromium@^1.4.668: resolved "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.4.746.tgz#787213e75f6c7bccb55dfe8b68170555c548d093" integrity sha512-jeWaIta2rIG2FzHaYIhSuVWqC6KJYo7oSBX4Jv7g+aVujKztfvdpf+n6MGwZdC5hQXbax4nntykLH2juIQrfPg== +electron-to-chromium@^1.5.41: + version "1.5.71" + resolved "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.5.71.tgz#d8b5dba1e55b320f2f4e9b1ca80738f53fcfec2b" + integrity sha512-dB68l59BI75W1BUGVTAEJy45CEVuEGy9qPVVQ8pnHyHMn36PLPPoE1mjLH+lo9rKulO3HC2OhbACI/8tCqJBcA== + electron-updater@6.3.9: version "6.3.9" resolved "https://registry.yarnpkg.com/electron-updater/-/electron-updater-6.3.9.tgz#e1e7f155624c58e6f3760f376c3a584028165ec4" @@ -10806,11 +11128,46 @@ esbuild@^0.21.3: "@esbuild/win32-ia32" "0.21.5" "@esbuild/win32-x64" "0.21.5" +esbuild@~0.23.0: + version "0.23.1" + resolved "https://registry.yarnpkg.com/esbuild/-/esbuild-0.23.1.tgz#40fdc3f9265ec0beae6f59824ade1bd3d3d2dab8" + integrity sha512-VVNz/9Sa0bs5SELtn3f7qhJCDPCF5oMEl5cO9/SSinpE9hbPVvxbd572HH5AKiP7WD8INO53GgfDDhRjkylHEg== + optionalDependencies: + "@esbuild/aix-ppc64" "0.23.1" + "@esbuild/android-arm" "0.23.1" + "@esbuild/android-arm64" "0.23.1" + "@esbuild/android-x64" "0.23.1" + "@esbuild/darwin-arm64" "0.23.1" + "@esbuild/darwin-x64" "0.23.1" + "@esbuild/freebsd-arm64" "0.23.1" + "@esbuild/freebsd-x64" "0.23.1" + "@esbuild/linux-arm" "0.23.1" + "@esbuild/linux-arm64" "0.23.1" + "@esbuild/linux-ia32" "0.23.1" + "@esbuild/linux-loong64" "0.23.1" + "@esbuild/linux-mips64el" "0.23.1" + "@esbuild/linux-ppc64" "0.23.1" + "@esbuild/linux-riscv64" "0.23.1" + "@esbuild/linux-s390x" "0.23.1" + "@esbuild/linux-x64" "0.23.1" + "@esbuild/netbsd-x64" "0.23.1" + "@esbuild/openbsd-arm64" "0.23.1" + "@esbuild/openbsd-x64" "0.23.1" + "@esbuild/sunos-x64" "0.23.1" + "@esbuild/win32-arm64" "0.23.1" + "@esbuild/win32-ia32" "0.23.1" + "@esbuild/win32-x64" "0.23.1" + escalade@^3.1.1: version "3.1.2" resolved "https://registry.yarnpkg.com/escalade/-/escalade-3.1.2.tgz#54076e9ab29ea5bf3d8f1ed62acffbb88272df27" integrity sha512-ErCHMCae19vR8vQGe50xIsVomy19rg6gFu3+r3jkEO46suLMWBksvVyoGgQV+jOfl84ZSOSlmv6Gxa89PmTGmA== +escalade@^3.2.0: + version "3.2.0" + resolved "https://registry.yarnpkg.com/escalade/-/escalade-3.2.0.tgz#011a3f69856ba189dffa7dc8fcce99d2a87903e5" + integrity sha512-WUj2qlxaQtO4g6Pq5c29GTcWGDyd8itL8zTlipgECz3JesAiiOKotd8JU6otB3PACgG6xkJUyVhboMS+bje/jA== + escape-goat@^2.0.0: version "2.1.1" resolved "https://registry.yarnpkg.com/escape-goat/-/escape-goat-2.1.1.tgz#1b2dc77003676c457ec760b2dc68edb648188675" @@ -12107,6 +12464,11 @@ fs.realpath@^1.0.0: resolved "https://registry.yarnpkg.com/fs.realpath/-/fs.realpath-1.0.0.tgz#1504ad2523158caa40db4a2787cb01411994ea4f" integrity sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw== +fsevents@2.3.2: + version "2.3.2" + resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-2.3.2.tgz#8a526f78b8fdf4623b709e0b975c52c24c02fd1a" + integrity sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA== + fsevents@^1.2.7: version "1.2.13" resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-1.2.13.tgz#f325cb0455592428bcf11b383370ef70e3bfcc38" @@ -12293,6 +12655,13 @@ get-tsconfig@^4.7.0: dependencies: resolve-pkg-maps "^1.0.0" +get-tsconfig@^4.7.5: + version "4.8.1" + resolved "https://registry.yarnpkg.com/get-tsconfig/-/get-tsconfig-4.8.1.tgz#8995eb391ae6e1638d251118c7b56de7eb425471" + integrity sha512-k9PN+cFBmaLWtVz29SkUoqU5O0slLuHJXt/2P+tMVFT+phsSGXGkp9t3rQIqdz0e+06EHNGs3oM6ZX1s2zHxRg== + dependencies: + resolve-pkg-maps "^1.0.0" + get-value@^2.0.3, get-value@^2.0.6: version "2.0.6" resolved "https://registry.yarnpkg.com/get-value/-/get-value-2.0.6.tgz#dc15ca1c672387ca76bd37ac0a395ba2042a2c28" @@ -14490,6 +14859,11 @@ jsesc@^2.5.1: resolved "https://registry.yarnpkg.com/jsesc/-/jsesc-2.5.2.tgz#80564d2e483dacf6e8ef209650a67df3f0c283a4" integrity sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA== +jsesc@^3.0.2: + version "3.0.2" + resolved "https://registry.yarnpkg.com/jsesc/-/jsesc-3.0.2.tgz#bb8b09a6597ba426425f2e4a07245c3d00b9343e" + integrity sha512-xKqzzWXDttJuOcawBt4KnKHHIf5oQ/Cxax+0PWFG+DFDgHNAdi+TXECADI+RYiFUMmx8792xsMbbgXj4CwnP4g== + jsesc@~0.5.0: version "0.5.0" resolved "https://registry.yarnpkg.com/jsesc/-/jsesc-0.5.0.tgz#e7dee66e35d6fc16f710fe91d5cf69f70f08911d" @@ -14686,6 +15060,11 @@ kleur@^3.0.3: resolved "https://registry.yarnpkg.com/kleur/-/kleur-3.0.3.tgz#a79c9ecc86ee1ce3fa6206d1216c501f147fc07e" integrity sha512-eTIzlVOSUR+JxdDFepEYcBMtZ9Qqdef+rnzWdRZuMbOywu5tO2w2N7rqjoANZ5k9vywhL6Br1VRjUIgTQx4E8w== +kleur@^4.1.5: + version "4.1.5" + resolved "https://registry.yarnpkg.com/kleur/-/kleur-4.1.5.tgz#95106101795f7050c6c650f350c683febddb1780" + integrity sha512-o+NO+8WrRiQEE4/7nwRJhN1HWpVmJm511pBHUxPLtp0BUISzlBplORYSmTclCnJvQq2tKu/sgl3xVpkc7ZWuQQ== + klona@^2.0.4: version "2.0.6" resolved "https://registry.yarnpkg.com/klona/-/klona-2.0.6.tgz#85bffbf819c03b2f53270412420a4555ef882e22" @@ -16130,6 +16509,11 @@ mqtt@4.3.8: ws "^7.5.5" xtend "^4.0.2" +mri@^1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/mri/-/mri-1.2.0.tgz#6721480fec2a11a4889861115a48b6cbe7cc8f0b" + integrity sha512-tzzskb3bG8LvYGFF/mDTpq3jpI6Q9wc3LEmBaghu+DdCssd1FakN7Bc0hVNmEyGq1bq3RgfkCb3cmQLpNPOroA== + ms@2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/ms/-/ms-2.0.0.tgz#5608aeadfc00be6c2901df5f9861788de0d597c8" @@ -16389,6 +16773,11 @@ node-releases@^2.0.14: resolved "https://registry.yarnpkg.com/node-releases/-/node-releases-2.0.14.tgz#2ffb053bceb8b2be8495ece1ab6ce600c4461b0b" integrity sha512-y10wOWt8yZpqXmOgRo77WaHEmhYQYGNA6y421PKsKYWEK8aW+cqAphborZDhqfyKrbZEN92CN1X2KbafY2s7Yw== +node-releases@^2.0.18: + version "2.0.18" + resolved "https://registry.yarnpkg.com/node-releases/-/node-releases-2.0.18.tgz#f010e8d35e2fe8d6b2944f03f70213ecedc4ca3f" + integrity sha512-d9VeXT4SJ7ZeOqGX6R5EM022wpL+eWPooLI+5UpWn2jCT1aosUQEhQP214x33Wkwx3JQMvIm+tIoVOdodFS40g== + node-source-walk@^4.0.0, node-source-walk@^4.2.0, node-source-walk@^4.2.2: version "4.3.0" resolved "https://registry.yarnpkg.com/node-source-walk/-/node-source-walk-4.3.0.tgz#8336b56cfed23ac5180fe98f1e3bb6b11fd5317c" @@ -17239,11 +17628,21 @@ picocolors@^1.0.0: resolved "https://registry.yarnpkg.com/picocolors/-/picocolors-1.0.0.tgz#cb5bdc74ff3f51892236eaf79d68bc44564ab81c" integrity sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ== +picocolors@^1.1.0: + version "1.1.1" + resolved "https://registry.yarnpkg.com/picocolors/-/picocolors-1.1.1.tgz#3d321af3eab939b083c8f929a1d12cda81c26b6b" + integrity sha512-xceH2snhtb5M9liqDsmEw56le376mTZkEX/jEb/RxNFyegNul7eNslCXP9FDj/Lcu0X8KEyMceP2ntpaHrDEVA== + picomatch@^2.0.4, picomatch@^2.2.1, picomatch@^2.2.2, picomatch@^2.2.3, picomatch@^2.3.0, picomatch@^2.3.1: version "2.3.1" resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.3.1.tgz#3ba3833733646d9d3e4995946c1365a67fb07a42" integrity sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA== +picomatch@^4.0.2: + version "4.0.2" + resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-4.0.2.tgz#77c742931e8f3b8820946c76cd0c1f13730d1dab" + integrity sha512-M7BAV6Rlcy5u+m6oPhAPFgJTzAioX/6B0DxyvDlo9l8+T3nLKbrczg2WLUyzd45L8RqfUMyGPzekbMvX2Ldkwg== + pify@^2.0.0, pify@^2.2.0, pify@^2.3.0: version "2.3.0" resolved "https://registry.yarnpkg.com/pify/-/pify-2.3.0.tgz#ed141a6ac043a849ea588498e7dca8b15330e90c" @@ -17313,6 +17712,20 @@ pkg-up@^3.0.1: dependencies: find-up "^3.0.0" +playwright-core@1.49.0: + version "1.49.0" + resolved "https://registry.yarnpkg.com/playwright-core/-/playwright-core-1.49.0.tgz#8e69ffed3f41855b854982f3632f2922c890afcb" + integrity sha512-R+3KKTQF3npy5GTiKH/T+kdhoJfJojjHESR1YEWhYuEKRVfVaxH3+4+GvXE5xyCngCxhxnykk0Vlah9v8fs3jA== + +playwright@^1.49.0: + version "1.49.0" + resolved "https://registry.yarnpkg.com/playwright/-/playwright-1.49.0.tgz#df6b9e05423377a99658202844a294a8afb95d0a" + integrity sha512-eKpmys0UFDnfNb3vfsf8Vx2LEOtflgRebl0Im2eQQnYMA4Aqd+Zw8bEOB+7ZKvN76901mRnqdsiOGKxzVTbi7A== + dependencies: + playwright-core "1.49.0" + optionalDependencies: + fsevents "2.3.2" + plist@^3.0.4, plist@^3.0.5, plist@^3.1.0: version "3.1.0" resolved "https://registry.yarnpkg.com/plist/-/plist-3.1.0.tgz#797a516a93e62f5bde55e0b9cc9c967f860893c9" @@ -18086,6 +18499,11 @@ postcss@^8.1.7, postcss@^8.4, postcss@^8.4.32, postcss@^8.4.38: picocolors "^1.0.0" source-map-js "^1.2.0" +preact@^10.25.1: + version "10.25.1" + resolved "https://registry.yarnpkg.com/preact/-/preact-10.25.1.tgz#1c4b84253c42dee874bfbf6a92bdce45e3662665" + integrity sha512-frxeZV2vhQSohQwJ7FvlqC40ze89+8friponWUFeVEkaCfhC6Eu4V0iND5C9CXz8JLndV07QRDeXzH1+Anz5Og== + precinct@^6.3.1: version "6.3.1" resolved "https://registry.yarnpkg.com/precinct/-/precinct-6.3.1.tgz#8ad735a8afdfc48b56ed39c9ad3bf999b6b928dc" @@ -18758,6 +19176,28 @@ react-router@6.24.1: dependencies: "@remix-run/router" "1.17.1" +react-scan@^0.0.38: + version "0.0.38" + resolved "https://registry.yarnpkg.com/react-scan/-/react-scan-0.0.38.tgz#f5c1fd1d60fa16f5fa508335bd0e2ac42235e672" + integrity sha512-n6+yIiw6FIx6EnIpf3B5dus9mmOZmU0wXpPQmXCG9rac/4rO9kv9UFBTdV6hgIA2L0JsrIJonkXpse7jt3Zi1Q== + dependencies: + "@babel/core" "^7.26.0" + "@babel/generator" "^7.26.2" + "@babel/types" "^7.26.0" + "@clack/core" "^0.3.5" + "@clack/prompts" "^0.8.2" + "@preact/signals" "^1.3.1" + "@rollup/pluginutils" "^5.1.3" + "@types/node" "^20.17.9" + bippy "^0.0.10" + estree-walker "^3.0.3" + kleur "^4.1.5" + mri "^1.2.0" + playwright "^1.49.0" + preact "^10.25.1" + tsx "^4.0.0" + unplugin "2.0.0-beta.2" + react-select@5.4.0: version "5.4.0" resolved "https://registry.yarnpkg.com/react-select/-/react-select-5.4.0.tgz#81f6ac73906126706f104751ee14437bd16798f4" @@ -21559,6 +21999,16 @@ tsutils@^3.17.1, tsutils@^3.21.0: dependencies: tslib "^1.8.1" +tsx@^4.0.0: + version "4.19.2" + resolved "https://registry.yarnpkg.com/tsx/-/tsx-4.19.2.tgz#2d7814783440e0ae42354d0417d9c2989a2ae92c" + integrity sha512-pOUl6Vo2LUq/bSa8S5q7b91cgNSjctn9ugq/+Mvow99qW6x/UZYwzxy/3NmqoT66eHYfCVvFvACC58UBPFf28g== + dependencies: + esbuild "~0.23.0" + get-tsconfig "^4.7.5" + optionalDependencies: + fsevents "~2.3.3" + tty-browserify@0.0.0: version "0.0.0" resolved "https://registry.yarnpkg.com/tty-browserify/-/tty-browserify-0.0.0.tgz#a157ba402da24e9bf957f9aa69d524eed42901a6" @@ -22043,6 +22493,14 @@ unpipe@1.0.0, unpipe@~1.0.0: resolved "https://registry.yarnpkg.com/unpipe/-/unpipe-1.0.0.tgz#b2bf4ee8514aae6165b4817829d21b2ef49904ec" integrity sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ== +unplugin@2.0.0-beta.2: + version "2.0.0-beta.2" + resolved "https://registry.yarnpkg.com/unplugin/-/unplugin-2.0.0-beta.2.tgz#a05912d32c560b87b0dbe534bff6fc3427652cd3" + integrity sha512-gWIFAjTFKFsHI9xSWQGhhoLkAqMoG/JzVZ0T4W0VeC02kitb8zIdiTjUBJXX5tCt0bdfr/0cJaOf2S7ujuVqtw== + dependencies: + acorn "^8.14.0" + webpack-virtual-modules "^0.6.2" + unplugin@^1.3.1: version "1.10.1" resolved "https://registry.yarnpkg.com/unplugin/-/unplugin-1.10.1.tgz#8ceda065dc71bc67d923dea0920f05c67f2cd68c" @@ -22101,6 +22559,14 @@ update-browserslist-db@^1.0.13: escalade "^3.1.1" picocolors "^1.0.0" +update-browserslist-db@^1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/update-browserslist-db/-/update-browserslist-db-1.1.1.tgz#80846fba1d79e82547fb661f8d141e0945755fe5" + integrity sha512-R8UzCaa9Az+38REPiJ1tXlImTJXlVfgHZsglwBD/k6nj76ctsH1E3q4doGrukiLQd3sGQYu56r5+lo5r94l29A== + dependencies: + escalade "^3.2.0" + picocolors "^1.1.0" + upper-case@^1.1.1: version "1.1.3" resolved "https://registry.yarnpkg.com/upper-case/-/upper-case-1.1.3.tgz#f6b4501c2ec4cdd26ba78be7222961de77621598" @@ -22766,6 +23232,11 @@ webpack-virtual-modules@^0.6.1: resolved "https://registry.yarnpkg.com/webpack-virtual-modules/-/webpack-virtual-modules-0.6.1.tgz#ac6fdb9c5adb8caecd82ec241c9631b7a3681b6f" integrity sha512-poXpCylU7ExuvZK8z+On3kX+S8o/2dQ/SVYueKA0D4WEMXROXgY8Ez50/bQEUmvoSMMrWcrJqCHuhAbsiwg7Dg== +webpack-virtual-modules@^0.6.2: + version "0.6.2" + resolved "https://registry.yarnpkg.com/webpack-virtual-modules/-/webpack-virtual-modules-0.6.2.tgz#057faa9065c8acf48f24cb57ac0e77739ab9a7e8" + integrity sha512-66/V2i5hQanC51vBQKPH4aI8NMAcBW59FVBs+rC7eGHupMyfn34q7rZIE+ETlJ+XTevqfUhVVBgSUNSW2flEUQ== + webpack@^4.41.6: version "4.47.0" resolved "https://registry.yarnpkg.com/webpack/-/webpack-4.47.0.tgz#8b8a02152d7076aeb03b61b47dad2eeed9810ebc" From b32aa125716c9390838ea9db7b3f682d5c94ab05 Mon Sep 17 00:00:00 2001 From: Jethary Alcid <66035149+jerader@users.noreply.github.com> Date: Wed, 11 Dec 2024 12:23:33 -0500 Subject: [PATCH 13/23] feat(protocol-designer, app, api): step grouping foundation (#15737) addresses AUTH-573 # Overview co-authored by @jbleon95 This is the foundation for Step grouping in the system. Step grouping is part of the PD redesign follow-up (originally it was part of the PD redesign but got descoped a few days ago. it IS still part of the redesign plans but will be in a follow up) The way step grouping works is the user in PD adds the step to a group and that information gets parsed into `commandAnnotations` in the schema as part of a `secondOrderCommand`. When uploading the protocol to the app, the `commandAnnotations` is part of the `CompletedProtocolAnalysis` which is displayed in the Timeline tab in `ProtocolDetails` - only on the desktop app. Note that the Timeline tab is only visible if you have the `Protocol timeline` feature flag turned on. --------- Co-authored-by: jbleon95 Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: jbleon95 <12025228+jbleon95@users.noreply.github.com> --- ...2_S_v2_11_P10S_P300M_MM_TC1_TM_Swift].json | 1 + ...[pl_BacteriaInoculation_Flex_6plates].json | 1 + ...2b][OT2_S_v2_7_P20S_None_Walkthrough].json | 1 + ...][pl_Flex_Protein_Digestion_Protocol].json | 1 + ...B_TC_TM_DeckConfiguration1NoFixtures].json | 1 + ...300M_P20S_aspirateDispenseMix0Volume].json | 1 + ...P300M_P20S_HS_TC_TM_dispense_changes].json | 1 + ...2_19_P300M_P20S_HS_TC_TM_SmokeTestV3].json | 1 + ...03a95825][Flex_S_v2_19_QIASeq_FX_48x].json | 1 + ...s_TooTallLabware_Override_south_west].json | 1 + ...TES_TC_VerifyThermocyclerLoadedSlots].json | 1 + ...][Flex_S_v2_18_Illumina_DNA_Prep_48x].json | 1 + ...InRTP_Override_wrong_type_in_maximum].json | 1 + ...es_TooTallLabware_Override_north_row].json | 1 + ...2_15_P300M_P20S_HS_TC_TM_SmokeTestV3].json | 1 + ...2_18_P300M_P20S_HS_TC_TM_SmokeTestV3].json | 1 + ..._EM_seq_48Samples_AllSteps_Edits_150].json | 1 + ...][Flex_S_v2_20_96_None_ROW_HappyPath].json | 1 + ...c2386b92][Flex_S_v2_20_96_AllCorners].json | 1 + ...11020a4e17][pl_Bradford_proteinassay].json | 1 + ..._X_v6_P300M_P20S_HS_MM_TM_TC_AllMods].json | 1 + ...a9c68b][Flex_S_v2_20_P8X1000_P50_LLD].json | 1 + ...llumina_Stranded_total_RNA_Ribo_Zero].json | 1 + ...0fccf4][pl_microBioID_beads_touchtip].json | 1 + ...94e3c49bb][pl_Normalization_with_PCR].json | 1 + ...errides_TooTallLabware_Override_west].json | 1 + ..._GRIP_TC_TM_GripperCollisionWithTips].json | 1 + ...HS_HeaterShakerConflictWithTrashBin2].json | 1 + ...l_Dynabeads_IP_Flex_96well_RIT_final].json | 1 + ...5c][OT2_S_v2_4_P300M_None_MM_TM_Zymo].json | 1 + ...c080][pl_MagMax_RNA_Cells_Flex_multi].json | 1 + ...InRTP_Override_wrong_type_in_minimum].json | 1 + ...f51][Flex_S_v2_18_KAPA_Library_Quant].json | 1 + ..._Omega_HDQ_DNA_Cells_Flex_96_channel].json | 1 + ..._X_v2_18_None_None_NoRTPdisplay_name].json | 1 + ...pshot[250e9496be][pl_BCApeptideassay].json | 1 + ...ooTallLabware_Override_mix_collision].json | 1 + ...7961bc58][pl_NiNTA_Flex_96well_final].json | 1 + ...9][pl_Omega_HDQ_DNA_Cells_Flex_multi].json | 1 + ...pl_Omega_HDQ_DNA_Bacteria_Flex_multi].json | 1 + ...ide_distribute_destination_collision].json | 1 + ...e_Override_transfer_source_collision].json | 1 + ...Flex_S_v2_18_P1000_96_TipTrackingBug].json | 1 + ...2bc6830494][pl_langone_ribo_pt1_ramp].json | 1 + ..._TooTallLabware_Override_east_column].json | 1 + ...TC_TM_TriggerPrepareForMountMovement].json | 1 + ..._S_v2_20_96_None_SINGLE_4Corners50ul].json | 1 + ...20_96_None_SINGLE_HappyPathNorthSide].json | 1 + ...None_MM1_MM2_EngageMagHeightFromBase].json | 1 + ...[pl_Takara_InFusionSnapAssembly_Flex].json | 1 + ...18_NO_PIPETTES_DescriptionTooLongRTP].json | 1 + ...allLabware_Override_bottom_left_edge].json | 1 + ...allLabware_Override_bottom_left_edge].json | 1 + ...P_Override_default_less_than_minimum].json | 1 + ...es_TooTallLabware_Override_south_row].json | 1 + ...f][pl_Dynabeads_IP_Flex_96well_final].json | 1 + ...fd9][Flex_S_v2_19_KAPA_Library_Quant].json | 1 + ...2_18_P1000_96_GRIP_HS_MB_TC_TM_Smoke].json | 1 + ...shot[4148613317][Flex_S_v2_19_ligseq].json | 1 + ...apshot[42beea80be][pl_96_ch_demo_rtp].json | 1 + ...8][OT2_X_v6_P20S_None_SimpleTransfer].json | 1 + ...T2_S_v2_18_NO_PIPETTES_GoldenRTP_OT2].json | 1 + ...ple_dilution_with_96_channel_pipette].json | 1 + ...2_16_P300M_P20S_HS_TC_TM_SmokeTestV3].json | 1 + ...P300M_P20S_HS_TC_TM_dispense_changes].json | 1 + ...ARTIAL_COLUMN_HappyPathMixedTipRacks].json | 1 + ...TTES_MM_MagneticModuleInFlexProtocol].json | 1 + ...Override_eight_partial_column_no_end].json | 1 + ...50c02c81][Flex_S_v2_19_AMPure_XP_48x].json | 1 + ...Override_wrong_type_in_variable_name].json | 1 + ...][pl_Zymo_Quick_RNA_Cells_Flex_multi].json | 1 + ...verride_default_greater_than_maximum].json | 1 + ...v6_P300M_P20S_MixTransferManyLiquids].json | 1 + ...ide_eight_partial_column_bottom_left].json | 1 + ...ooTallLabware_Override_c3_right_edge].json | 1 + ...Override_eight_partial_column_no_end].json | 1 + ...erifyNoFloatingPointErrorInPipetting].json | 1 + ...][Flex_S_v2_19_Illumina_DNA_Prep_48x].json | 1 + ...O_PIPETTES_TrashBinInStagingAreaCol4].json | 1 + ...shot[59b00713a7][Flex_S_v2_18_ligseq].json | 1 + ...ega_HDQ_DNA_Bacteria_Flex_96_channel].json | 1 + ...0MGen2_None_OT2PipetteInFlexProtocol].json | 1 + ...Override_ninety_six_partial_column_2].json | 1 + ...8_None_None_duplicateRTPVariableName].json | 1 + ..._PIPETTES_TM_ModuleInStagingAreaCol3].json | 1 + ...ride_int_default_no_matching_choices].json | 1 + ...Override_ninety_six_partial_column_1].json | 1 + ..._PIPETTES_TM_ModuleInStagingAreaCol4].json | 1 + ...][Flex_S_v2_18_NO_PIPETTES_GoldenRTP].json | 1 + ..._customizable_serial_dilution_upload].json | 1 + ...b47][pl_M_N_Nucleomag_DNA_Flex_multi].json | 1 + ...s_TooTallLabware_Override_south_east].json | 1 + ...errides_TooTallLabware_Override_east].json | 1 + ...pesInRTP_Override_wrong_type_in_unit].json | 1 + ...lex_S_v2_20_96_None_COLUMN_HappyPath].json | 1 + ...ython310SyntaxRobotAnalysisOnlyError].json | 1 + ...de_consolidate_destination_collision].json | 1 + ...96_GRIP_HS_MB_TM_MagMaxRNAExtraction].json | 1 + ...HS_HeaterShakerConflictWithTrashBin1].json | 1 + ...ride_str_default_no_matching_choices].json | 1 + ..._HS_TM_MB_TC_IlluminaDNAEnrichmentV4].json | 1 + ...OT2_S_v2_3_P300S_None_MM1_MM2_TM_Mix].json | 1 + ..._HS_TC_TM_aspirateDispenseMix0Volume].json | 1 + ...[pl_SamplePrep_MS_Digest_Flex_upto96].json | 1 + ...2_20_8_None_PARTIAL_COLUMN_HappyPath].json | 1 + ...lidConfigs_Override_return_tip_error].json | 1 + ...ebdcd29][pl_KAPA_Library_Quant_48_v8].json | 1 + ...e61426a2][Flex_S_v2_18_AMPure_XP_48x].json | 1 + ...de_wrong_type_in_choice_display_name].json | 1 + ..._TooTallLabware_Override_west_column].json | 1 + ..._QIAseq_FX_24x_Normalizer_Workflow_B].json | 1 + ...de_float_default_no_matching_choices].json | 1 + ...x_X_v2_16_NO_PIPETTES_TrashBinInCol2].json | 1 + ...a9][OT2_S_v2_12_P300M_P20S_FailOnRun].json | 1 + ...84cbc4][Flex_S_v2_18_IDT_xGen_EZ_48x].json | 1 + ...2_14_P300M_P20S_HS_TC_TM_SmokeTestV3].json | 1 + ...Zymo_Quick_RNA_Cells_Flex_96_Channel].json | 1 + ...][OT2_X_v6_P20S_P300M_HS_HSCollision].json | 1 + ...T2_X_v2_18_None_None_StrRTPwith_unit].json | 1 + ...tialTipPickupThermocyclerLidConflict].json | 1 + ...rrides_TooTallLabware_Override_south].json | 1 + ...figs_Override_drop_tip_with_location].json | 1 + ...pl_NiNTA_Flex_96well_PlatePrep_final].json | 1 + ...6_P1000_96_TC_PartialTipPickupColumn].json | 1 + ...747b2f9][pl_Illumina_DNA_Prep_48x_v8].json | 1 + ...de_eight_partial_column_bottom_right].json | 1 + ..._v3_P300SGen1_None_Gen1PipetteSimple].json | 1 + ..._TM_MB_OmegaHDQDNAExtractionBacteria].json | 1 + ..._P300S_TC1_TC2_ThermocyclerMoamError].json | 1 + ...TES_TC_verifyThermocyclerLoadedSlots].json | 1 + ...bcb0a3f13][pl_normalization_with_csv].json | 1 + ...1000_96_GRIP_DropLabwareIntoTrashBin].json | 1 + ...O_PIPETTES_TrashBinInStagingAreaCol3].json | 1 + ...P_Override_wrong_type_in_description].json | 1 + ...eckConfiguration1NoModulesNoFixtures].json | 1 + ...s_TooTallLabware_Override_north_west].json | 1 + ...pl_SamplePrep_MS_Cleanup_Flex_upto96].json | 1 + ...][Flex_S_v2_19_Illumina_DNA_PCR_Free].json | 1 + ...37534569][Flex_S_v2_19_kapahyperplus].json | 1 + ...l_Nanopore_Genomic_Ligation_v5_Final].json | 1 + ...4d3b3a2d3][pl_96_ch_demo_rtp_with_hs].json | 1 + ...2_13_P300M_P20S_HS_TC_TM_SmokeTestV3].json | 1 + ...20_96_None_SINGLE_HappyPathSouthSide].json | 1 + ...a8a5ad823d][pl_cherrypicking_flex_v3].json | 1 + ...4f22054f][Flex_S_v2_18_kapahyperplus].json | 1 + ...6_NO_PIPETTES_AccessToFixedTrashProp].json | 1 + ..._snapshot[aa61eee0bf][pl_sigdx_part2].json | 1 + ...shot[ac5a46e74b][pl_langone_pt2_ribo].json | 1 + ...6_GRIP_HS_MB_TC_TM_IDTXgen96Part1to3].json | 1 + ...ide_eight_partial_column_bottom_left].json | 1 + ...2_S_v6_P300M_P20S_HS_Smoke620release].json | 1 + ...lex_X_v2_18_NO_PIPETTES_ReservedWord].json | 1 + ..._pipetteCollisionWithThermocyclerLid].json | 1 + ...lidConfigs_Override_return_tip_error].json | 1 + ...96_TC_PartialTipPickupTryToReturnTip].json | 1 + ...407ff98][pl_cherrypicking_csv_airgap].json | 1 + ...llumina_Stranded_total_RNA_Ribo_Zero].json | 1 + ...figs_Override_drop_tip_with_location].json | 1 + ..._Override_wrong_type_in_choice_value].json | 1 + ...[pl_MagMax_RNA_Cells_Flex_96_Channel].json | 1 + ...P1000S_None_SimpleNormalizeLongRight].json | 1 + ...rride_transfer_destination_collision].json | 1 + ...rrides_TooTallLabware_Override_north].json | 1 + ...[OT2_S_v6_P1000S_None_SimpleTransfer].json | 1 + ...TES_TC_VerifyThermocyclerLoadedSlots].json | 1 + ...TES_TC_verifyThermocyclerLoadedSlots].json | 1 + ...TES_TC_VerifyThermocyclerLoadedSlots].json | 1 + ...llLabware_Override_bottom_right_edge].json | 1 + ..._96_GRIP_DeckConfiguration1NoModules].json | 1 + ..._P300M_P20S_MM_TC_TM_Smoke620Release].json | 1 + ...d2ca0089][Flex_S_v2_18_QIASeq_FX_48x].json | 1 + ...2_X_v4_P300M_P20S_MM_TC1_TM_e2eTests].json | 1 + ..._P20S_P300M_TransferReTransferLiquid].json | 1 + ...Flex_S_v2_20_8_None_SINGLE_HappyPath].json | 1 + ...[cecd51c8ee][pl_ExpressPlex_96_final].json | 1 + ...de_eight_partial_column_bottom_right].json | 1 + ...pl_Zymo_Magbead_DNA_Cells_Flex_multi].json | 1 + ...shot[d29d74d7fb][pl_QIASeq_FX_48x_v8].json | 1 + ...hot[d2c818bf00][Flex_S_v2_20_P50_LPD].json | 1 + ...oMagbeadRNAExtractionCellsOrBacteria].json | 1 + ...mo_Magbead_DNA_Cells_Flex_96_channel].json | 1 + ...2_17_P300M_P20S_HS_TC_TM_SmokeTestV3].json | 1 + ...11c5][OT2_X_v2_7_P300S_TwinningError].json | 1 + ...39e6a3][Flex_S_v2_19_IDT_xGen_EZ_48x].json | 1 + ...shot[d6389183c0][pl_AMPure_XP_48x_v8].json | 1 + ...v2_18_None_None_duplicateChoiceValue].json | 1 + ...6_P1000_96_TC_PartialTipPickupSingle].json | 1 + ...[OT2_S_v2_20_8_None_SINGLE_HappyPath].json | 1 + ...1][pl_Hyperplus_tiptracking_V4_final].json | 1 + ...2_19_P1000_96_GRIP_HS_MB_TC_TM_Smoke].json | 1 + ...Override_ninety_six_partial_column_3].json | 1 + ...TES_TC_VerifyThermocyclerLoadedSlots].json | 1 + ...S_TC_TrashBinAndThermocyclerConflict].json | 1 + ...tranded_total_RNA_Ribo_Zero_protocol].json | 1 + ...RIP_HS_TM_MB_TC_KAPALibraryQuantv4_8].json | 1 + ..._X_v2_13_None_None_PythonSyntaxError].json | 1 + ...2_S_v4_P300S_None_MM_TM_TM_MOAMTemps].json | 1 + ...InRTP_Override_wrong_type_in_default].json | 1 + ...][Flex_S_v2_18_Illumina_DNA_PCR_Free].json | 1 + ...e71b031f47][pl_Illumina_DNA_PCR_Free].json | 1 + ...des_TooTallLabware_Override_top_edge].json | 1 + ...Flex_S_v2_20_96_None_Column3_SINGLE_].json | 1 + ..._X_v2_16_NO_PIPETTES_TM_ModuleInCol2].json | 1 + ...verride_consolidate_source_collision].json | 1 + ...P_HS_TM_MB_TC_IlluminaDNAPrep24xV4_7].json | 1 + ...X_v2_16_P1000_96_DropTipsWithNoTrash].json | 1 + ...P_HS_MB_TC_TM_IlluminaDNAPrep96PART3].json | 1 + ...0M_P300S_HS_HS_NormalUseWithTransfer].json | 1 + ...][OT2_S_v4_P300M_P20S_MM_TM_TC1_PD40].json | 1 + ...16_NO_PIPETTES_verifyDoesNotDeadlock].json | 1 + ...2_16_P1000_96_GRIP_HS_MB_TC_TM_Smoke].json | 1 + ...00_96_TM_ModuleAndWasteChuteConflict].json | 1 + ...TES_TC_verifyThermocyclerLoadedSlots].json | 1 + ...ddbb32][pl_ExpressPlex_Pooling_Final].json | 1 + ...tteCollisionWithThermocyclerLidClips].json | 1 + ..._GRIP_HS_MB_TC_TM_DeckConfiguration1].json | 1 + ...Override_distribute_source_collision].json | 1 + ..._Override_wrong_type_in_display_name].json | 1 + ...P300M_P20S_HS_TC_TM_dispense_changes].json | 1 + api/src/opentrons/cli/analyze.py | 4 + api/src/opentrons/protocol_engine/types.py | 50 +++++ .../protocol_runner/json_translator.py | 19 +- .../protocol_runner/protocol_runner.py | 39 +++- .../protocol_runner/run_orchestrator.py | 9 + .../ProtocolDetails/AnnotatedSteps.tsx | 178 ++++++++++++++++-- .../__tests__/ProtocolDetails.test.tsx | 4 +- .../Desktop/ProtocolDetails/index.tsx | 22 ++- .../Protocols/ProtocolDetails/index.tsx | 15 +- app/src/redux/protocol-storage/selectors.ts | 26 ++- app/src/redux/protocol-storage/types.ts | 17 +- app/src/redux/protocol-storage/utils.ts | 47 +++++ .../src/file-data/selectors/fileCreator.ts | 33 +++- .../src/step-forms/actions/groups.ts | 60 ++++++ .../src/step-forms/reducers/index.ts | 62 ++++++ .../src/step-forms/selectors/index.ts | 9 + .../src/ui/steps/actions/actions.ts | 17 ++ .../src/ui/steps/actions/types.ts | 7 + protocol-designer/typings/reselect.d.ts | 10 +- .../maintenance_run_orchestrator_store.py | 7 +- .../robot_server/protocols/analysis_models.py | 5 + .../robot_server/protocols/analysis_store.py | 4 + .../protocols/protocol_analyzer.py | 2 + .../runs/run_orchestrator_store.py | 2 + .../protocols/test_v6_json_upload.tavern.yaml | 1 + .../test_v8_json_upload_flex.tavern.yaml | 11 ++ .../test_v8_json_upload_ot2.tavern.yaml | 11 ++ .../tests/protocols/test_analysis_store.py | 9 + .../test_completed_analysis_store.py | 1 + .../tests/protocols/test_protocol_analyzer.py | 5 + .../tests/runs/test_run_controller.py | 23 ++- .../tests/runs/test_run_data_manager.py | 18 +- shared-data/js/types.ts | 2 + shared-data/protocol/types/schemaV8/index.ts | 1 + 253 files changed, 911 insertions(+), 38 deletions(-) create mode 100644 app/src/redux/protocol-storage/utils.ts create mode 100644 protocol-designer/src/step-forms/actions/groups.ts diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[004ebb2b82][OT2_S_v2_11_P10S_P300M_MM_TC1_TM_Swift].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[004ebb2b82][OT2_S_v2_11_P10S_P300M_MM_TC1_TM_Swift].json index f59c9684e23..1e59022b2a8 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[004ebb2b82][OT2_S_v2_11_P10S_P300M_MM_TC1_TM_Swift].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[004ebb2b82][OT2_S_v2_11_P10S_P300M_MM_TC1_TM_Swift].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[00574c503f][pl_BacteriaInoculation_Flex_6plates].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[00574c503f][pl_BacteriaInoculation_Flex_6plates].json index 05fa920a764..0a408e946c3 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[00574c503f][pl_BacteriaInoculation_Flex_6plates].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[00574c503f][pl_BacteriaInoculation_Flex_6plates].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[011481812b][OT2_S_v2_7_P20S_None_Walkthrough].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[011481812b][OT2_S_v2_7_P20S_None_Walkthrough].json index c709366a42a..387b9f0e3f5 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[011481812b][OT2_S_v2_7_P20S_None_Walkthrough].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[011481812b][OT2_S_v2_7_P20S_None_Walkthrough].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[01255c3f3b][pl_Flex_Protein_Digestion_Protocol].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[01255c3f3b][pl_Flex_Protein_Digestion_Protocol].json index 2da7a9c47bd..67327c84b0e 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[01255c3f3b][pl_Flex_Protein_Digestion_Protocol].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[01255c3f3b][pl_Flex_Protein_Digestion_Protocol].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0190369ce5][Flex_S_v2_16_P1000_96_GRIP_HS_MB_TC_TM_DeckConfiguration1NoFixtures].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0190369ce5][Flex_S_v2_16_P1000_96_GRIP_HS_MB_TC_TM_DeckConfiguration1NoFixtures].json index 4f1452dcdfc..df7062d67b5 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0190369ce5][Flex_S_v2_16_P1000_96_GRIP_HS_MB_TC_TM_DeckConfiguration1NoFixtures].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0190369ce5][Flex_S_v2_16_P1000_96_GRIP_HS_MB_TC_TM_DeckConfiguration1NoFixtures].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0256665840][OT2_S_v2_16_P300M_P20S_aspirateDispenseMix0Volume].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0256665840][OT2_S_v2_16_P300M_P20S_aspirateDispenseMix0Volume].json index 39491fae6aa..6d0b815689f 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0256665840][OT2_S_v2_16_P300M_P20S_aspirateDispenseMix0Volume].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0256665840][OT2_S_v2_16_P300M_P20S_aspirateDispenseMix0Volume].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[041ad55e7b][OT2_S_v2_15_P300M_P20S_HS_TC_TM_dispense_changes].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[041ad55e7b][OT2_S_v2_15_P300M_P20S_HS_TC_TM_dispense_changes].json index a561da0a387..eba6890b1dc 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[041ad55e7b][OT2_S_v2_15_P300M_P20S_HS_TC_TM_dispense_changes].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[041ad55e7b][OT2_S_v2_15_P300M_P20S_HS_TC_TM_dispense_changes].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[057de2035d][OT2_S_v2_19_P300M_P20S_HS_TC_TM_SmokeTestV3].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[057de2035d][OT2_S_v2_19_P300M_P20S_HS_TC_TM_SmokeTestV3].json index fe3d81be11b..f88d031bd87 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[057de2035d][OT2_S_v2_19_P300M_P20S_HS_TC_TM_SmokeTestV3].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[057de2035d][OT2_S_v2_19_P300M_P20S_HS_TC_TM_SmokeTestV3].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0903a95825][Flex_S_v2_19_QIASeq_FX_48x].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0903a95825][Flex_S_v2_19_QIASeq_FX_48x].json index f85b03c5703..d1d7e581f85 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0903a95825][Flex_S_v2_19_QIASeq_FX_48x].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0903a95825][Flex_S_v2_19_QIASeq_FX_48x].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[09676b9f7e][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_south_west].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[09676b9f7e][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_south_west].json index 0f7d7d308b5..e81582f2998 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[09676b9f7e][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_south_west].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[09676b9f7e][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_south_west].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[09ba51132a][OT2_S_v2_14_NO_PIPETTES_TC_VerifyThermocyclerLoadedSlots].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[09ba51132a][OT2_S_v2_14_NO_PIPETTES_TC_VerifyThermocyclerLoadedSlots].json index d9895fb2c9e..112049809ad 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[09ba51132a][OT2_S_v2_14_NO_PIPETTES_TC_VerifyThermocyclerLoadedSlots].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[09ba51132a][OT2_S_v2_14_NO_PIPETTES_TC_VerifyThermocyclerLoadedSlots].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0a9ef592c8][Flex_S_v2_18_Illumina_DNA_Prep_48x].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0a9ef592c8][Flex_S_v2_18_Illumina_DNA_Prep_48x].json index f892fc456ce..f9343e792c6 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0a9ef592c8][Flex_S_v2_18_Illumina_DNA_Prep_48x].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0a9ef592c8][Flex_S_v2_18_Illumina_DNA_Prep_48x].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0affe60373][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_maximum].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0affe60373][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_maximum].json index a877268d0bd..bba25d3dccf 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0affe60373][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_maximum].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0affe60373][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_maximum].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [], "config": { "apiVersion": [ diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0b42cfc151][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_north_row].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0b42cfc151][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_north_row].json index 3a0f63a8f99..3951be19f24 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0b42cfc151][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_north_row].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0b42cfc151][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_north_row].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0c4ae179bb][OT2_S_v2_15_P300M_P20S_HS_TC_TM_SmokeTestV3].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0c4ae179bb][OT2_S_v2_15_P300M_P20S_HS_TC_TM_SmokeTestV3].json index 957e685c737..c5a57c18fc4 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0c4ae179bb][OT2_S_v2_15_P300M_P20S_HS_TC_TM_SmokeTestV3].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0c4ae179bb][OT2_S_v2_15_P300M_P20S_HS_TC_TM_SmokeTestV3].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0cbde10c37][OT2_S_v2_18_P300M_P20S_HS_TC_TM_SmokeTestV3].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0cbde10c37][OT2_S_v2_18_P300M_P20S_HS_TC_TM_SmokeTestV3].json index 35dc7ecc804..e9c6717fdd0 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0cbde10c37][OT2_S_v2_18_P300M_P20S_HS_TC_TM_SmokeTestV3].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0cbde10c37][OT2_S_v2_18_P300M_P20S_HS_TC_TM_SmokeTestV3].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0dd21c0ee5][pl_EM_seq_48Samples_AllSteps_Edits_150].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0dd21c0ee5][pl_EM_seq_48Samples_AllSteps_Edits_150].json index db42ce35fdc..b964f2a7367 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0dd21c0ee5][pl_EM_seq_48Samples_AllSteps_Edits_150].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[0dd21c0ee5][pl_EM_seq_48Samples_AllSteps_Edits_150].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[109b7ad1f0][Flex_S_v2_20_96_None_ROW_HappyPath].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[109b7ad1f0][Flex_S_v2_20_96_None_ROW_HappyPath].json index cf56c96470e..64a1766fb6a 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[109b7ad1f0][Flex_S_v2_20_96_None_ROW_HappyPath].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[109b7ad1f0][Flex_S_v2_20_96_None_ROW_HappyPath].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[10c2386b92][Flex_S_v2_20_96_AllCorners].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[10c2386b92][Flex_S_v2_20_96_AllCorners].json index e4de2f89a14..581a3e3ea51 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[10c2386b92][Flex_S_v2_20_96_AllCorners].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[10c2386b92][Flex_S_v2_20_96_AllCorners].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[11020a4e17][pl_Bradford_proteinassay].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[11020a4e17][pl_Bradford_proteinassay].json index 7ce2978d56a..d63c91e8a57 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[11020a4e17][pl_Bradford_proteinassay].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[11020a4e17][pl_Bradford_proteinassay].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[134037b2aa][OT2_X_v6_P300M_P20S_HS_MM_TM_TC_AllMods].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[134037b2aa][OT2_X_v6_P300M_P20S_HS_MM_TM_TC_AllMods].json index d33b6cf51cb..19b3454722f 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[134037b2aa][OT2_X_v6_P300M_P20S_HS_MM_TM_TC_AllMods].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[134037b2aa][OT2_X_v6_P300M_P20S_HS_MM_TM_TC_AllMods].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[13e5a9c68b][Flex_S_v2_20_P8X1000_P50_LLD].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[13e5a9c68b][Flex_S_v2_20_P8X1000_P50_LLD].json index 8fece97c06c..9519a2e4438 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[13e5a9c68b][Flex_S_v2_20_P8X1000_P50_LLD].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[13e5a9c68b][Flex_S_v2_20_P8X1000_P50_LLD].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[13ec753045][Flex_S_v2_18_Illumina_Stranded_total_RNA_Ribo_Zero].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[13ec753045][Flex_S_v2_18_Illumina_Stranded_total_RNA_Ribo_Zero].json index c30b18aa93e..087cbb927b9 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[13ec753045][Flex_S_v2_18_Illumina_Stranded_total_RNA_Ribo_Zero].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[13ec753045][Flex_S_v2_18_Illumina_Stranded_total_RNA_Ribo_Zero].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[15a60fccf4][pl_microBioID_beads_touchtip].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[15a60fccf4][pl_microBioID_beads_touchtip].json index 3f500210e5a..6b7d81ff805 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[15a60fccf4][pl_microBioID_beads_touchtip].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[15a60fccf4][pl_microBioID_beads_touchtip].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[194e3c49bb][pl_Normalization_with_PCR].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[194e3c49bb][pl_Normalization_with_PCR].json index 059f375baec..1dad0a643db 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[194e3c49bb][pl_Normalization_with_PCR].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[194e3c49bb][pl_Normalization_with_PCR].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[196ec488f7][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_west].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[196ec488f7][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_west].json index 4c621f4bce7..c39bcbb3546 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[196ec488f7][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_west].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[196ec488f7][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_west].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[19c783e363][Flex_X_v8_P1000_96_HS_GRIP_TC_TM_GripperCollisionWithTips].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[19c783e363][Flex_X_v8_P1000_96_HS_GRIP_TC_TM_GripperCollisionWithTips].json index 54caa90c5aa..7a817b9879d 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[19c783e363][Flex_X_v8_P1000_96_HS_GRIP_TC_TM_GripperCollisionWithTips].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[19c783e363][Flex_X_v8_P1000_96_HS_GRIP_TC_TM_GripperCollisionWithTips].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[19ffa9c839][OT2_X_v2_16_None_None_HS_HeaterShakerConflictWithTrashBin2].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[19ffa9c839][OT2_X_v2_16_None_None_HS_HeaterShakerConflictWithTrashBin2].json index 53c7ab3a948..6863507448c 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[19ffa9c839][OT2_X_v2_16_None_None_HS_HeaterShakerConflictWithTrashBin2].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[19ffa9c839][OT2_X_v2_16_None_None_HS_HeaterShakerConflictWithTrashBin2].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[1b73b8a126][pl_Dynabeads_IP_Flex_96well_RIT_final].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[1b73b8a126][pl_Dynabeads_IP_Flex_96well_RIT_final].json index d77bd5df928..d4ea924e585 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[1b73b8a126][pl_Dynabeads_IP_Flex_96well_RIT_final].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[1b73b8a126][pl_Dynabeads_IP_Flex_96well_RIT_final].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[1c19a2055c][OT2_S_v2_4_P300M_None_MM_TM_Zymo].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[1c19a2055c][OT2_S_v2_4_P300M_None_MM_TM_Zymo].json index 3a1bb3b88bb..fc41febf592 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[1c19a2055c][OT2_S_v2_4_P300M_None_MM_TM_Zymo].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[1c19a2055c][OT2_S_v2_4_P300M_None_MM_TM_Zymo].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[1d37cbc080][pl_MagMax_RNA_Cells_Flex_multi].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[1d37cbc080][pl_MagMax_RNA_Cells_Flex_multi].json index 2ad485275e5..6258b8500a1 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[1d37cbc080][pl_MagMax_RNA_Cells_Flex_multi].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[1d37cbc080][pl_MagMax_RNA_Cells_Flex_multi].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[1e5825a070][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_minimum].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[1e5825a070][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_minimum].json index 0bdc144dbb3..7c43a7ee370 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[1e5825a070][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_minimum].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[1e5825a070][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_minimum].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [], "config": { "apiVersion": [ diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[238912ff51][Flex_S_v2_18_KAPA_Library_Quant].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[238912ff51][Flex_S_v2_18_KAPA_Library_Quant].json index 7a8b8a1548d..a18cfa29797 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[238912ff51][Flex_S_v2_18_KAPA_Library_Quant].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[238912ff51][Flex_S_v2_18_KAPA_Library_Quant].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[248a2a3107][pl_Omega_HDQ_DNA_Cells_Flex_96_channel].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[248a2a3107][pl_Omega_HDQ_DNA_Cells_Flex_96_channel].json index f03c791524b..6e3feab4269 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[248a2a3107][pl_Omega_HDQ_DNA_Cells_Flex_96_channel].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[248a2a3107][pl_Omega_HDQ_DNA_Cells_Flex_96_channel].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[24a6b167a7][OT2_X_v2_18_None_None_NoRTPdisplay_name].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[24a6b167a7][OT2_X_v2_18_None_None_NoRTPdisplay_name].json index ae30ee77a48..f76c32c355f 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[24a6b167a7][OT2_X_v2_18_None_None_NoRTPdisplay_name].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[24a6b167a7][OT2_X_v2_18_None_None_NoRTPdisplay_name].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [], "config": { "apiVersion": [ diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[250e9496be][pl_BCApeptideassay].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[250e9496be][pl_BCApeptideassay].json index 71e01f083be..48190df7f82 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[250e9496be][pl_BCApeptideassay].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[250e9496be][pl_BCApeptideassay].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[255d014c70][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_mix_collision].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[255d014c70][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_mix_collision].json index 12c32c5f5da..225541d9e20 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[255d014c70][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_mix_collision].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[255d014c70][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_mix_collision].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[277961bc58][pl_NiNTA_Flex_96well_final].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[277961bc58][pl_NiNTA_Flex_96well_final].json index 0b9dd33046c..6a4c99f2bbc 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[277961bc58][pl_NiNTA_Flex_96well_final].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[277961bc58][pl_NiNTA_Flex_96well_final].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[28fdeebdd9][pl_Omega_HDQ_DNA_Cells_Flex_multi].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[28fdeebdd9][pl_Omega_HDQ_DNA_Cells_Flex_multi].json index c71e685c32b..d52ff5e72e4 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[28fdeebdd9][pl_Omega_HDQ_DNA_Cells_Flex_multi].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[28fdeebdd9][pl_Omega_HDQ_DNA_Cells_Flex_multi].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[29bb5df52d][pl_Omega_HDQ_DNA_Bacteria_Flex_multi].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[29bb5df52d][pl_Omega_HDQ_DNA_Bacteria_Flex_multi].json index a5bd8540f28..e8cb6c52713 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[29bb5df52d][pl_Omega_HDQ_DNA_Bacteria_Flex_multi].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[29bb5df52d][pl_Omega_HDQ_DNA_Bacteria_Flex_multi].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[29e143f047][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_distribute_destination_collision].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[29e143f047][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_distribute_destination_collision].json index 0f6af7ae5e7..4d1fef18df8 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[29e143f047][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_distribute_destination_collision].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[29e143f047][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_distribute_destination_collision].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[29eec5a85a][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_transfer_source_collision].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[29eec5a85a][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_transfer_source_collision].json index 43393e2d50a..bed5e33f447 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[29eec5a85a][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_transfer_source_collision].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[29eec5a85a][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_transfer_source_collision].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[2b7fcb5b23][Flex_S_v2_18_P1000_96_TipTrackingBug].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[2b7fcb5b23][Flex_S_v2_18_P1000_96_TipTrackingBug].json index 23052e0a20e..2dbe272ad3a 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[2b7fcb5b23][Flex_S_v2_18_P1000_96_TipTrackingBug].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[2b7fcb5b23][Flex_S_v2_18_P1000_96_TipTrackingBug].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[2bc6830494][pl_langone_ribo_pt1_ramp].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[2bc6830494][pl_langone_ribo_pt1_ramp].json index d67b4a678fb..9e8f25df1f1 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[2bc6830494][pl_langone_ribo_pt1_ramp].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[2bc6830494][pl_langone_ribo_pt1_ramp].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[2cc8efae68][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_east_column].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[2cc8efae68][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_east_column].json index fee41d6f9c0..1fe105e1626 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[2cc8efae68][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_east_column].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[2cc8efae68][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_east_column].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[2eaf98de6a][Flex_S_v2_16_P1000_96_GRIP_HS_MB_TC_TM_TriggerPrepareForMountMovement].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[2eaf98de6a][Flex_S_v2_16_P1000_96_GRIP_HS_MB_TC_TM_TriggerPrepareForMountMovement].json index 70bf58777f2..9a752b5cc56 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[2eaf98de6a][Flex_S_v2_16_P1000_96_GRIP_HS_MB_TC_TM_TriggerPrepareForMountMovement].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[2eaf98de6a][Flex_S_v2_16_P1000_96_GRIP_HS_MB_TC_TM_TriggerPrepareForMountMovement].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[30c05024e8][Flex_S_v2_20_96_None_SINGLE_4Corners50ul].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[30c05024e8][Flex_S_v2_20_96_None_SINGLE_4Corners50ul].json index 1dd24aae658..b51efe39d43 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[30c05024e8][Flex_S_v2_20_96_None_SINGLE_4Corners50ul].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[30c05024e8][Flex_S_v2_20_96_None_SINGLE_4Corners50ul].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[31d1aec819][Flex_S_v2_20_96_None_SINGLE_HappyPathNorthSide].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[31d1aec819][Flex_S_v2_20_96_None_SINGLE_HappyPathNorthSide].json index bbe6bf4ba4e..c50efd7f6d3 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[31d1aec819][Flex_S_v2_20_96_None_SINGLE_HappyPathNorthSide].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[31d1aec819][Flex_S_v2_20_96_None_SINGLE_HappyPathNorthSide].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[3251c6e175][OT2_S_v2_2_P300S_None_MM1_MM2_EngageMagHeightFromBase].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[3251c6e175][OT2_S_v2_2_P300S_None_MM1_MM2_EngageMagHeightFromBase].json index 8461051e13d..99eecf6abd7 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[3251c6e175][OT2_S_v2_2_P300S_None_MM1_MM2_EngageMagHeightFromBase].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[3251c6e175][OT2_S_v2_2_P300S_None_MM1_MM2_EngageMagHeightFromBase].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[33c134ee09][pl_Takara_InFusionSnapAssembly_Flex].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[33c134ee09][pl_Takara_InFusionSnapAssembly_Flex].json index 5d8bc380c63..34c36cbea16 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[33c134ee09][pl_Takara_InFusionSnapAssembly_Flex].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[33c134ee09][pl_Takara_InFusionSnapAssembly_Flex].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[33db294a9b][Flex_X_v2_18_NO_PIPETTES_DescriptionTooLongRTP].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[33db294a9b][Flex_X_v2_18_NO_PIPETTES_DescriptionTooLongRTP].json index 0c53a820ae6..680eb63c792 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[33db294a9b][Flex_X_v2_18_NO_PIPETTES_DescriptionTooLongRTP].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[33db294a9b][Flex_X_v2_18_NO_PIPETTES_DescriptionTooLongRTP].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[376765183a0][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_bottom_left_edge].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[376765183a0][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_bottom_left_edge].json index 2247878b82f..e2bc115fd1b 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[376765183a0][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_bottom_left_edge].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[376765183a0][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_bottom_left_edge].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[376765183a1][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_bottom_left_edge].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[376765183a1][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_bottom_left_edge].json index 2247878b82f..e2bc115fd1b 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[376765183a1][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_bottom_left_edge].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[376765183a1][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_bottom_left_edge].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[38b5298c77][Flex_X_v2_18_NO_PIPETTES_Overrides_DefaultOutOfRangeRTP_Override_default_less_than_minimum].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[38b5298c77][Flex_X_v2_18_NO_PIPETTES_Overrides_DefaultOutOfRangeRTP_Override_default_less_than_minimum].json index 02fce766da7..a7a0f35a79f 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[38b5298c77][Flex_X_v2_18_NO_PIPETTES_Overrides_DefaultOutOfRangeRTP_Override_default_less_than_minimum].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[38b5298c77][Flex_X_v2_18_NO_PIPETTES_Overrides_DefaultOutOfRangeRTP_Override_default_less_than_minimum].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [], "config": { "apiVersion": [ diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[39191e3573][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_south_row].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[39191e3573][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_south_row].json index 2476fb92ee9..b574f7610f7 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[39191e3573][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_south_row].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[39191e3573][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_south_row].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[3a039d726f][pl_Dynabeads_IP_Flex_96well_final].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[3a039d726f][pl_Dynabeads_IP_Flex_96well_final].json index 7a9171aea40..571c18a8986 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[3a039d726f][pl_Dynabeads_IP_Flex_96well_final].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[3a039d726f][pl_Dynabeads_IP_Flex_96well_final].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[3cec61dfd9][Flex_S_v2_19_KAPA_Library_Quant].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[3cec61dfd9][Flex_S_v2_19_KAPA_Library_Quant].json index 5f6c64e445e..6e32c48363a 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[3cec61dfd9][Flex_S_v2_19_KAPA_Library_Quant].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[3cec61dfd9][Flex_S_v2_19_KAPA_Library_Quant].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[3cf6a3778e][Flex_S_v2_18_P1000_96_GRIP_HS_MB_TC_TM_Smoke].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[3cf6a3778e][Flex_S_v2_18_P1000_96_GRIP_HS_MB_TC_TM_Smoke].json index 7037c88b55e..262eed6262d 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[3cf6a3778e][Flex_S_v2_18_P1000_96_GRIP_HS_MB_TC_TM_Smoke].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[3cf6a3778e][Flex_S_v2_18_P1000_96_GRIP_HS_MB_TC_TM_Smoke].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4148613317][Flex_S_v2_19_ligseq].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4148613317][Flex_S_v2_19_ligseq].json index d39133b22ee..c25eab4039e 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4148613317][Flex_S_v2_19_ligseq].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4148613317][Flex_S_v2_19_ligseq].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[42beea80be][pl_96_ch_demo_rtp].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[42beea80be][pl_96_ch_demo_rtp].json index 9b3df810c9c..1263405e382 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[42beea80be][pl_96_ch_demo_rtp].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[42beea80be][pl_96_ch_demo_rtp].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4389e3ab18][OT2_X_v6_P20S_None_SimpleTransfer].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4389e3ab18][OT2_X_v6_P20S_None_SimpleTransfer].json index 10f4fe66ddd..b6d711f8ad5 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4389e3ab18][OT2_X_v6_P20S_None_SimpleTransfer].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4389e3ab18][OT2_X_v6_P20S_None_SimpleTransfer].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4458220422][OT2_S_v2_18_NO_PIPETTES_GoldenRTP_OT2].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4458220422][OT2_S_v2_18_NO_PIPETTES_GoldenRTP_OT2].json index 6db970d3310..e8d85babe1e 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4458220422][OT2_S_v2_18_NO_PIPETTES_GoldenRTP_OT2].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4458220422][OT2_S_v2_18_NO_PIPETTES_GoldenRTP_OT2].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4753259c3e][pl_sample_dilution_with_96_channel_pipette].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4753259c3e][pl_sample_dilution_with_96_channel_pipette].json index 079f1b1347e..b45ed38fb45 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4753259c3e][pl_sample_dilution_with_96_channel_pipette].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4753259c3e][pl_sample_dilution_with_96_channel_pipette].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4a82419f1f][OT2_S_v2_16_P300M_P20S_HS_TC_TM_SmokeTestV3].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4a82419f1f][OT2_S_v2_16_P300M_P20S_HS_TC_TM_SmokeTestV3].json index 454746d4581..bab063b11f0 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4a82419f1f][OT2_S_v2_16_P300M_P20S_HS_TC_TM_SmokeTestV3].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4a82419f1f][OT2_S_v2_16_P300M_P20S_HS_TC_TM_SmokeTestV3].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4b17883f74][OT2_S_v2_17_P300M_P20S_HS_TC_TM_dispense_changes].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4b17883f74][OT2_S_v2_17_P300M_P20S_HS_TC_TM_dispense_changes].json index fa5d7b43a3f..b9c7fe3eccb 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4b17883f74][OT2_S_v2_17_P300M_P20S_HS_TC_TM_dispense_changes].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4b17883f74][OT2_S_v2_17_P300M_P20S_HS_TC_TM_dispense_changes].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4b9e0f93d9][OT2_S_v2_20_8_None_PARTIAL_COLUMN_HappyPathMixedTipRacks].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4b9e0f93d9][OT2_S_v2_20_8_None_PARTIAL_COLUMN_HappyPathMixedTipRacks].json index fd7b30ca845..2c0e359ce5f 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4b9e0f93d9][OT2_S_v2_20_8_None_PARTIAL_COLUMN_HappyPathMixedTipRacks].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4b9e0f93d9][OT2_S_v2_20_8_None_PARTIAL_COLUMN_HappyPathMixedTipRacks].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4cb705bdbf][Flex_X_v2_16_NO_PIPETTES_MM_MagneticModuleInFlexProtocol].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4cb705bdbf][Flex_X_v2_16_NO_PIPETTES_MM_MagneticModuleInFlexProtocol].json index b63443781ac..dd52de35f74 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4cb705bdbf][Flex_X_v2_16_NO_PIPETTES_MM_MagneticModuleInFlexProtocol].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4cb705bdbf][Flex_X_v2_16_NO_PIPETTES_MM_MagneticModuleInFlexProtocol].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4ea9d66206][Flex_X_v2_20_96_and_8_Overrides_InvalidConfigs_Override_eight_partial_column_no_end].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4ea9d66206][Flex_X_v2_20_96_and_8_Overrides_InvalidConfigs_Override_eight_partial_column_no_end].json index a126374479b..25f1fc6f062 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4ea9d66206][Flex_X_v2_20_96_and_8_Overrides_InvalidConfigs_Override_eight_partial_column_no_end].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4ea9d66206][Flex_X_v2_20_96_and_8_Overrides_InvalidConfigs_Override_eight_partial_column_no_end].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4f50c02c81][Flex_S_v2_19_AMPure_XP_48x].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4f50c02c81][Flex_S_v2_19_AMPure_XP_48x].json index f102cab8bc5..65dd9d4920b 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4f50c02c81][Flex_S_v2_19_AMPure_XP_48x].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4f50c02c81][Flex_S_v2_19_AMPure_XP_48x].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4fadc166c0][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_variable_name].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4fadc166c0][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_variable_name].json index 484c6600849..0e9136c426d 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4fadc166c0][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_variable_name].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[4fadc166c0][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_variable_name].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [], "config": { "apiVersion": [ diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[50d7be4518][pl_Zymo_Quick_RNA_Cells_Flex_multi].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[50d7be4518][pl_Zymo_Quick_RNA_Cells_Flex_multi].json index 3a839b9cdbd..bc7eb440f6e 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[50d7be4518][pl_Zymo_Quick_RNA_Cells_Flex_multi].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[50d7be4518][pl_Zymo_Quick_RNA_Cells_Flex_multi].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[51a761307d][Flex_X_v2_18_NO_PIPETTES_Overrides_DefaultOutOfRangeRTP_Override_default_greater_than_maximum].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[51a761307d][Flex_X_v2_18_NO_PIPETTES_Overrides_DefaultOutOfRangeRTP_Override_default_greater_than_maximum].json index 72f8481bc29..c702bc58d97 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[51a761307d][Flex_X_v2_18_NO_PIPETTES_Overrides_DefaultOutOfRangeRTP_Override_default_greater_than_maximum].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[51a761307d][Flex_X_v2_18_NO_PIPETTES_Overrides_DefaultOutOfRangeRTP_Override_default_greater_than_maximum].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [], "config": { "apiVersion": [ diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[51fc977577][OT2_S_v6_P300M_P20S_MixTransferManyLiquids].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[51fc977577][OT2_S_v6_P300M_P20S_MixTransferManyLiquids].json index 4c45089bc7c..40774e92cc3 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[51fc977577][OT2_S_v6_P300M_P20S_MixTransferManyLiquids].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[51fc977577][OT2_S_v6_P300M_P20S_MixTransferManyLiquids].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[53db9bf516][Flex_X_v2_20_96_and_8_Overrides_InvalidConfigs_Override_eight_partial_column_bottom_left].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[53db9bf516][Flex_X_v2_20_96_and_8_Overrides_InvalidConfigs_Override_eight_partial_column_bottom_left].json index 58b6e3ffb42..e514b696c6a 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[53db9bf516][Flex_X_v2_20_96_and_8_Overrides_InvalidConfigs_Override_eight_partial_column_bottom_left].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[53db9bf516][Flex_X_v2_20_96_and_8_Overrides_InvalidConfigs_Override_eight_partial_column_bottom_left].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[549cc904ac][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_c3_right_edge].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[549cc904ac][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_c3_right_edge].json index dde453f20ab..aeac8222289 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[549cc904ac][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_c3_right_edge].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[549cc904ac][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_c3_right_edge].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[54b0b509cd][OT2_X_v2_20_8_Overrides_InvalidConfigs_Override_eight_partial_column_no_end].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[54b0b509cd][OT2_X_v2_20_8_Overrides_InvalidConfigs_Override_eight_partial_column_no_end].json index 8cb5125c17c..c639bf70fc2 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[54b0b509cd][OT2_X_v2_20_8_Overrides_InvalidConfigs_Override_eight_partial_column_no_end].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[54b0b509cd][OT2_X_v2_20_8_Overrides_InvalidConfigs_Override_eight_partial_column_no_end].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[54f717cfd1][OT2_S_v2_16_P300S_None_verifyNoFloatingPointErrorInPipetting].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[54f717cfd1][OT2_S_v2_16_P300S_None_verifyNoFloatingPointErrorInPipetting].json index 27656b80cca..69e890d57fd 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[54f717cfd1][OT2_S_v2_16_P300S_None_verifyNoFloatingPointErrorInPipetting].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[54f717cfd1][OT2_S_v2_16_P300S_None_verifyNoFloatingPointErrorInPipetting].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[555b2fff00][Flex_S_v2_19_Illumina_DNA_Prep_48x].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[555b2fff00][Flex_S_v2_19_Illumina_DNA_Prep_48x].json index 84bff8651d2..cd6ea36def3 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[555b2fff00][Flex_S_v2_19_Illumina_DNA_Prep_48x].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[555b2fff00][Flex_S_v2_19_Illumina_DNA_Prep_48x].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[58750bf5fb][Flex_X_v2_16_NO_PIPETTES_TrashBinInStagingAreaCol4].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[58750bf5fb][Flex_X_v2_16_NO_PIPETTES_TrashBinInStagingAreaCol4].json index 63ed50d9c04..d11ea9fe7d6 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[58750bf5fb][Flex_X_v2_16_NO_PIPETTES_TrashBinInStagingAreaCol4].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[58750bf5fb][Flex_X_v2_16_NO_PIPETTES_TrashBinInStagingAreaCol4].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[59b00713a7][Flex_S_v2_18_ligseq].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[59b00713a7][Flex_S_v2_18_ligseq].json index 4744b1f1992..17c3ea8b6a4 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[59b00713a7][Flex_S_v2_18_ligseq].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[59b00713a7][Flex_S_v2_18_ligseq].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[5c57add326][pl_Omega_HDQ_DNA_Bacteria_Flex_96_channel].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[5c57add326][pl_Omega_HDQ_DNA_Bacteria_Flex_96_channel].json index 353a1b46f45..dbe4146e8e1 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[5c57add326][pl_Omega_HDQ_DNA_Bacteria_Flex_96_channel].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[5c57add326][pl_Omega_HDQ_DNA_Bacteria_Flex_96_channel].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[5e958b7c98][Flex_X_v2_16_P300MGen2_None_OT2PipetteInFlexProtocol].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[5e958b7c98][Flex_X_v2_16_P300MGen2_None_OT2PipetteInFlexProtocol].json index 059e7fc2b84..accbbbbda1e 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[5e958b7c98][Flex_X_v2_16_P300MGen2_None_OT2PipetteInFlexProtocol].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[5e958b7c98][Flex_X_v2_16_P300MGen2_None_OT2PipetteInFlexProtocol].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[5edb9b4de3][Flex_X_v2_20_96_and_8_Overrides_InvalidConfigs_Override_ninety_six_partial_column_2].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[5edb9b4de3][Flex_X_v2_20_96_and_8_Overrides_InvalidConfigs_Override_ninety_six_partial_column_2].json index 47c65a0dfc5..122bbadc03d 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[5edb9b4de3][Flex_X_v2_20_96_and_8_Overrides_InvalidConfigs_Override_ninety_six_partial_column_2].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[5edb9b4de3][Flex_X_v2_20_96_and_8_Overrides_InvalidConfigs_Override_ninety_six_partial_column_2].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[60015c6e65][OT2_X_v2_18_None_None_duplicateRTPVariableName].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[60015c6e65][OT2_X_v2_18_None_None_duplicateRTPVariableName].json index 3c69dda38e7..87a9f4d3b02 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[60015c6e65][OT2_X_v2_18_None_None_duplicateRTPVariableName].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[60015c6e65][OT2_X_v2_18_None_None_duplicateRTPVariableName].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [], "config": { "apiVersion": [ diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[604023f7f1][Flex_X_v2_16_NO_PIPETTES_TM_ModuleInStagingAreaCol3].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[604023f7f1][Flex_X_v2_16_NO_PIPETTES_TM_ModuleInStagingAreaCol3].json index fde783d94b8..ac1235fe4a1 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[604023f7f1][Flex_X_v2_16_NO_PIPETTES_TM_ModuleInStagingAreaCol3].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[604023f7f1][Flex_X_v2_16_NO_PIPETTES_TM_ModuleInStagingAreaCol3].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[60c1d39463][Flex_X_v2_18_NO_PIPETTES_Overrides_DefaultChoiceNoMatchChoice_Override_int_default_no_matching_choices].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[60c1d39463][Flex_X_v2_18_NO_PIPETTES_Overrides_DefaultChoiceNoMatchChoice_Override_int_default_no_matching_choices].json index b8ef1cbc5f2..f119f6dd2c6 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[60c1d39463][Flex_X_v2_18_NO_PIPETTES_Overrides_DefaultChoiceNoMatchChoice_Override_int_default_no_matching_choices].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[60c1d39463][Flex_X_v2_18_NO_PIPETTES_Overrides_DefaultChoiceNoMatchChoice_Override_int_default_no_matching_choices].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [], "config": { "apiVersion": [ diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6122c72996][Flex_X_v2_20_96_and_8_Overrides_InvalidConfigs_Override_ninety_six_partial_column_1].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6122c72996][Flex_X_v2_20_96_and_8_Overrides_InvalidConfigs_Override_ninety_six_partial_column_1].json index 180178d1d44..341397530c7 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6122c72996][Flex_X_v2_20_96_and_8_Overrides_InvalidConfigs_Override_ninety_six_partial_column_1].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6122c72996][Flex_X_v2_20_96_and_8_Overrides_InvalidConfigs_Override_ninety_six_partial_column_1].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6126498df7][Flex_X_v2_16_NO_PIPETTES_TM_ModuleInStagingAreaCol4].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6126498df7][Flex_X_v2_16_NO_PIPETTES_TM_ModuleInStagingAreaCol4].json index 8623a021746..a2736f68c26 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6126498df7][Flex_X_v2_16_NO_PIPETTES_TM_ModuleInStagingAreaCol4].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6126498df7][Flex_X_v2_16_NO_PIPETTES_TM_ModuleInStagingAreaCol4].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[61619d5498][Flex_S_v2_18_NO_PIPETTES_GoldenRTP].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[61619d5498][Flex_S_v2_18_NO_PIPETTES_GoldenRTP].json index 8b06eca9390..6ed42554132 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[61619d5498][Flex_S_v2_18_NO_PIPETTES_GoldenRTP].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[61619d5498][Flex_S_v2_18_NO_PIPETTES_GoldenRTP].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[618f29898f][pl_Flex_customizable_serial_dilution_upload].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[618f29898f][pl_Flex_customizable_serial_dilution_upload].json index b1528f23cbf..708560a51cb 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[618f29898f][pl_Flex_customizable_serial_dilution_upload].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[618f29898f][pl_Flex_customizable_serial_dilution_upload].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[63ea171b47][pl_M_N_Nucleomag_DNA_Flex_multi].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[63ea171b47][pl_M_N_Nucleomag_DNA_Flex_multi].json index 1441d3d1cac..871692a8ff2 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[63ea171b47][pl_M_N_Nucleomag_DNA_Flex_multi].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[63ea171b47][pl_M_N_Nucleomag_DNA_Flex_multi].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[675d2c2562][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_south_east].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[675d2c2562][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_south_east].json index d27c90a866c..77e2166f737 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[675d2c2562][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_south_east].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[675d2c2562][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_south_east].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[68614da0b3][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_east].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[68614da0b3][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_east].json index 7209e028a2b..df66e371d7b 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[68614da0b3][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_east].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[68614da0b3][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_east].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6ad5590adf][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_unit].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6ad5590adf][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_unit].json index e30b5bee0d8..a57c328ac0d 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6ad5590adf][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_unit].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6ad5590adf][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_unit].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [], "config": { "apiVersion": [ diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6c20d6c570][Flex_S_v2_20_96_None_COLUMN_HappyPath].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6c20d6c570][Flex_S_v2_20_96_None_COLUMN_HappyPath].json index 3ac36a59ee5..e4961b84c9f 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6c20d6c570][Flex_S_v2_20_96_None_COLUMN_HappyPath].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6c20d6c570][Flex_S_v2_20_96_None_COLUMN_HappyPath].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6cee20a957][OT2_S_v2_12_NO_PIPETTES_Python310SyntaxRobotAnalysisOnlyError].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6cee20a957][OT2_S_v2_12_NO_PIPETTES_Python310SyntaxRobotAnalysisOnlyError].json index da1993d6e56..b7a95b5bf1d 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6cee20a957][OT2_S_v2_12_NO_PIPETTES_Python310SyntaxRobotAnalysisOnlyError].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6cee20a957][OT2_S_v2_12_NO_PIPETTES_Python310SyntaxRobotAnalysisOnlyError].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6e2f6f10c5][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_consolidate_destination_collision].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6e2f6f10c5][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_consolidate_destination_collision].json index 0e079e7daa2..e8590ac1760 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6e2f6f10c5][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_consolidate_destination_collision].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6e2f6f10c5][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_consolidate_destination_collision].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6e34343cfc][Flex_S_v2_15_P1000_96_GRIP_HS_MB_TM_MagMaxRNAExtraction].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6e34343cfc][Flex_S_v2_15_P1000_96_GRIP_HS_MB_TM_MagMaxRNAExtraction].json index eba57a84196..2f40e05d2ac 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6e34343cfc][Flex_S_v2_15_P1000_96_GRIP_HS_MB_TM_MagMaxRNAExtraction].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6e34343cfc][Flex_S_v2_15_P1000_96_GRIP_HS_MB_TM_MagMaxRNAExtraction].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6e5128f107][OT2_X_v2_16_None_None_HS_HeaterShakerConflictWithTrashBin1].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6e5128f107][OT2_X_v2_16_None_None_HS_HeaterShakerConflictWithTrashBin1].json index f052823d867..39393aae057 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6e5128f107][OT2_X_v2_16_None_None_HS_HeaterShakerConflictWithTrashBin1].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6e5128f107][OT2_X_v2_16_None_None_HS_HeaterShakerConflictWithTrashBin1].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6e744cbb48][Flex_X_v2_18_NO_PIPETTES_Overrides_DefaultChoiceNoMatchChoice_Override_str_default_no_matching_choices].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6e744cbb48][Flex_X_v2_18_NO_PIPETTES_Overrides_DefaultChoiceNoMatchChoice_Override_str_default_no_matching_choices].json index 2b5614762ba..2f0492db119 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6e744cbb48][Flex_X_v2_18_NO_PIPETTES_Overrides_DefaultChoiceNoMatchChoice_Override_str_default_no_matching_choices].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6e744cbb48][Flex_X_v2_18_NO_PIPETTES_Overrides_DefaultChoiceNoMatchChoice_Override_str_default_no_matching_choices].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [], "config": { "apiVersion": [ diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6f246e1cd8][Flex_S_2_18_P1000M_P50M_GRIP_HS_TM_MB_TC_IlluminaDNAEnrichmentV4].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6f246e1cd8][Flex_S_2_18_P1000M_P50M_GRIP_HS_TM_MB_TC_IlluminaDNAEnrichmentV4].json index fd1c3550795..3887f7772b7 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6f246e1cd8][Flex_S_2_18_P1000M_P50M_GRIP_HS_TM_MB_TC_IlluminaDNAEnrichmentV4].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6f246e1cd8][Flex_S_2_18_P1000M_P50M_GRIP_HS_TM_MB_TC_IlluminaDNAEnrichmentV4].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6f3e297a11][OT2_S_v2_3_P300S_None_MM1_MM2_TM_Mix].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6f3e297a11][OT2_S_v2_3_P300S_None_MM1_MM2_TM_Mix].json index 0028c36df1b..64fbca40974 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6f3e297a11][OT2_S_v2_3_P300S_None_MM1_MM2_TM_Mix].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6f3e297a11][OT2_S_v2_3_P300S_None_MM1_MM2_TM_Mix].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6f84e60cb0][OT2_S_v2_16_P300M_P20S_HS_TC_TM_aspirateDispenseMix0Volume].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6f84e60cb0][OT2_S_v2_16_P300M_P20S_HS_TC_TM_aspirateDispenseMix0Volume].json index 86023eb8c12..03aae1235b6 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6f84e60cb0][OT2_S_v2_16_P300M_P20S_HS_TC_TM_aspirateDispenseMix0Volume].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[6f84e60cb0][OT2_S_v2_16_P300M_P20S_HS_TC_TM_aspirateDispenseMix0Volume].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[70b873c24b][pl_SamplePrep_MS_Digest_Flex_upto96].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[70b873c24b][pl_SamplePrep_MS_Digest_Flex_upto96].json index b79aec33a1b..1921f4827d7 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[70b873c24b][pl_SamplePrep_MS_Digest_Flex_upto96].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[70b873c24b][pl_SamplePrep_MS_Digest_Flex_upto96].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[733c9cdf62][Flex_S_v2_20_8_None_PARTIAL_COLUMN_HappyPath].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[733c9cdf62][Flex_S_v2_20_8_None_PARTIAL_COLUMN_HappyPath].json index a79c72e6781..0eabefc61c9 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[733c9cdf62][Flex_S_v2_20_8_None_PARTIAL_COLUMN_HappyPath].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[733c9cdf62][Flex_S_v2_20_8_None_PARTIAL_COLUMN_HappyPath].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[7583faec7c][OT2_X_v2_20_8_Overrides_InvalidConfigs_Override_return_tip_error].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[7583faec7c][OT2_X_v2_20_8_Overrides_InvalidConfigs_Override_return_tip_error].json index 3a2911f043d..be40cf92526 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[7583faec7c][OT2_X_v2_20_8_Overrides_InvalidConfigs_Override_return_tip_error].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[7583faec7c][OT2_X_v2_20_8_Overrides_InvalidConfigs_Override_return_tip_error].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[770ebdcd29][pl_KAPA_Library_Quant_48_v8].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[770ebdcd29][pl_KAPA_Library_Quant_48_v8].json index c577f539508..6778bd9d11d 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[770ebdcd29][pl_KAPA_Library_Quant_48_v8].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[770ebdcd29][pl_KAPA_Library_Quant_48_v8].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[79e61426a2][Flex_S_v2_18_AMPure_XP_48x].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[79e61426a2][Flex_S_v2_18_AMPure_XP_48x].json index 00efc4b9178..f47755414b1 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[79e61426a2][Flex_S_v2_18_AMPure_XP_48x].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[79e61426a2][Flex_S_v2_18_AMPure_XP_48x].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[7d06568bfe][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_choice_display_name].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[7d06568bfe][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_choice_display_name].json index ae9e8d99862..43927f6a145 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[7d06568bfe][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_choice_display_name].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[7d06568bfe][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_choice_display_name].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [], "config": { "apiVersion": [ diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[7e7a90041b][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_west_column].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[7e7a90041b][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_west_column].json index 48077d59118..485e79b56ad 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[7e7a90041b][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_west_column].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[7e7a90041b][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_west_column].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[7ebefe4580][pl_QIAseq_FX_24x_Normalizer_Workflow_B].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[7ebefe4580][pl_QIAseq_FX_24x_Normalizer_Workflow_B].json index ac4311409dc..62f2ce5038d 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[7ebefe4580][pl_QIAseq_FX_24x_Normalizer_Workflow_B].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[7ebefe4580][pl_QIAseq_FX_24x_Normalizer_Workflow_B].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[7f2ef0eaff][Flex_X_v2_18_NO_PIPETTES_Overrides_DefaultChoiceNoMatchChoice_Override_float_default_no_matching_choices].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[7f2ef0eaff][Flex_X_v2_18_NO_PIPETTES_Overrides_DefaultChoiceNoMatchChoice_Override_float_default_no_matching_choices].json index 235d5eb9fe3..b4b14a04d6d 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[7f2ef0eaff][Flex_X_v2_18_NO_PIPETTES_Overrides_DefaultChoiceNoMatchChoice_Override_float_default_no_matching_choices].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[7f2ef0eaff][Flex_X_v2_18_NO_PIPETTES_Overrides_DefaultChoiceNoMatchChoice_Override_float_default_no_matching_choices].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [], "config": { "apiVersion": [ diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[82e9853b34][Flex_X_v2_16_NO_PIPETTES_TrashBinInCol2].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[82e9853b34][Flex_X_v2_16_NO_PIPETTES_TrashBinInCol2].json index e0fd663c213..deb12bf8743 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[82e9853b34][Flex_X_v2_16_NO_PIPETTES_TrashBinInCol2].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[82e9853b34][Flex_X_v2_16_NO_PIPETTES_TrashBinInCol2].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[8455adcea9][OT2_S_v2_12_P300M_P20S_FailOnRun].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[8455adcea9][OT2_S_v2_12_P300M_P20S_FailOnRun].json index d4cf07c0f99..78518efc2cd 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[8455adcea9][OT2_S_v2_12_P300M_P20S_FailOnRun].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[8455adcea9][OT2_S_v2_12_P300M_P20S_FailOnRun].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[84f684cbc4][Flex_S_v2_18_IDT_xGen_EZ_48x].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[84f684cbc4][Flex_S_v2_18_IDT_xGen_EZ_48x].json index 2312c3a011e..34a3f37e3c1 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[84f684cbc4][Flex_S_v2_18_IDT_xGen_EZ_48x].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[84f684cbc4][Flex_S_v2_18_IDT_xGen_EZ_48x].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[8860ee702c][OT2_S_v2_14_P300M_P20S_HS_TC_TM_SmokeTestV3].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[8860ee702c][OT2_S_v2_14_P300M_P20S_HS_TC_TM_SmokeTestV3].json index ac524674f7e..d7826dfd6f6 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[8860ee702c][OT2_S_v2_14_P300M_P20S_HS_TC_TM_SmokeTestV3].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[8860ee702c][OT2_S_v2_14_P300M_P20S_HS_TC_TM_SmokeTestV3].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[88abcfdbca][pl_Zymo_Quick_RNA_Cells_Flex_96_Channel].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[88abcfdbca][pl_Zymo_Quick_RNA_Cells_Flex_96_Channel].json index 7fb0dceab92..001c1074b47 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[88abcfdbca][pl_Zymo_Quick_RNA_Cells_Flex_96_Channel].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[88abcfdbca][pl_Zymo_Quick_RNA_Cells_Flex_96_Channel].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[88de2fb78f][OT2_X_v6_P20S_P300M_HS_HSCollision].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[88de2fb78f][OT2_X_v6_P20S_P300M_HS_HSCollision].json index 7eedccb2cf8..3e65e6d11ca 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[88de2fb78f][OT2_X_v6_P20S_P300M_HS_HSCollision].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[88de2fb78f][OT2_X_v6_P20S_P300M_HS_HSCollision].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[89a255db0b][OT2_X_v2_18_None_None_StrRTPwith_unit].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[89a255db0b][OT2_X_v2_18_None_None_StrRTPwith_unit].json index 70bb212b45b..fb3e1ff9524 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[89a255db0b][OT2_X_v2_18_None_None_StrRTPwith_unit].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[89a255db0b][OT2_X_v2_18_None_None_StrRTPwith_unit].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [], "config": { "apiVersion": [ diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[89a8226c4e][Flex_X_v2_16_P1000_96_TC_PartialTipPickupThermocyclerLidConflict].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[89a8226c4e][Flex_X_v2_16_P1000_96_TC_PartialTipPickupThermocyclerLidConflict].json index ea3c1cc76b0..a8dc215c6e1 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[89a8226c4e][Flex_X_v2_16_P1000_96_TC_PartialTipPickupThermocyclerLidConflict].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[89a8226c4e][Flex_X_v2_16_P1000_96_TC_PartialTipPickupThermocyclerLidConflict].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[8a663305c4][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_south].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[8a663305c4][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_south].json index cadf197c142..c90d4eae5e8 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[8a663305c4][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_south].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[8a663305c4][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_south].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[8b07e799f6][Flex_X_v2_20_96_and_8_Overrides_InvalidConfigs_Override_drop_tip_with_location].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[8b07e799f6][Flex_X_v2_20_96_and_8_Overrides_InvalidConfigs_Override_drop_tip_with_location].json index e433acf53ff..546aa74d915 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[8b07e799f6][Flex_X_v2_20_96_and_8_Overrides_InvalidConfigs_Override_drop_tip_with_location].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[8b07e799f6][Flex_X_v2_20_96_and_8_Overrides_InvalidConfigs_Override_drop_tip_with_location].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[8e1f35ed6c][pl_NiNTA_Flex_96well_PlatePrep_final].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[8e1f35ed6c][pl_NiNTA_Flex_96well_PlatePrep_final].json index c21c19205cf..e4338349baa 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[8e1f35ed6c][pl_NiNTA_Flex_96well_PlatePrep_final].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[8e1f35ed6c][pl_NiNTA_Flex_96well_PlatePrep_final].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[8fcfd2ced0][Flex_S_v2_16_P1000_96_TC_PartialTipPickupColumn].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[8fcfd2ced0][Flex_S_v2_16_P1000_96_TC_PartialTipPickupColumn].json index 933aa66cf7d..69045761942 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[8fcfd2ced0][Flex_S_v2_16_P1000_96_TC_PartialTipPickupColumn].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[8fcfd2ced0][Flex_S_v2_16_P1000_96_TC_PartialTipPickupColumn].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[918747b2f9][pl_Illumina_DNA_Prep_48x_v8].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[918747b2f9][pl_Illumina_DNA_Prep_48x_v8].json index 794499f75ce..f3cf1bfa2cc 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[918747b2f9][pl_Illumina_DNA_Prep_48x_v8].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[918747b2f9][pl_Illumina_DNA_Prep_48x_v8].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[93b724671e][OT2_X_v2_20_8_Overrides_InvalidConfigs_Override_eight_partial_column_bottom_right].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[93b724671e][OT2_X_v2_20_8_Overrides_InvalidConfigs_Override_eight_partial_column_bottom_right].json index d9f59af3587..85f4f9f5ea7 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[93b724671e][OT2_X_v2_20_8_Overrides_InvalidConfigs_Override_eight_partial_column_bottom_right].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[93b724671e][OT2_X_v2_20_8_Overrides_InvalidConfigs_Override_eight_partial_column_bottom_right].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[94913d2988][OT2_S_v3_P300SGen1_None_Gen1PipetteSimple].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[94913d2988][OT2_S_v3_P300SGen1_None_Gen1PipetteSimple].json index 405df785df9..a446fa1799b 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[94913d2988][OT2_S_v3_P300SGen1_None_Gen1PipetteSimple].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[94913d2988][OT2_S_v3_P300SGen1_None_Gen1PipetteSimple].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[95da6fbef2][Flex_S_2_15_P1000M_GRIP_HS_TM_MB_OmegaHDQDNAExtractionBacteria].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[95da6fbef2][Flex_S_2_15_P1000M_GRIP_HS_TM_MB_OmegaHDQDNAExtractionBacteria].json index 004f5251126..7e82355e220 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[95da6fbef2][Flex_S_2_15_P1000M_GRIP_HS_TM_MB_OmegaHDQDNAExtractionBacteria].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[95da6fbef2][Flex_S_2_15_P1000M_GRIP_HS_TM_MB_OmegaHDQDNAExtractionBacteria].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[9618a6623c][OT2_X_v2_11_P300S_TC1_TC2_ThermocyclerMoamError].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[9618a6623c][OT2_X_v2_11_P300S_TC1_TC2_ThermocyclerMoamError].json index 8a871949e46..407236c5c35 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[9618a6623c][OT2_X_v2_11_P300S_TC1_TC2_ThermocyclerMoamError].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[9618a6623c][OT2_X_v2_11_P300S_TC1_TC2_ThermocyclerMoamError].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[973fa979e6][Flex_S_v2_16_NO_PIPETTES_TC_verifyThermocyclerLoadedSlots].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[973fa979e6][Flex_S_v2_16_NO_PIPETTES_TC_verifyThermocyclerLoadedSlots].json index 5538166da59..51ed5bbe694 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[973fa979e6][Flex_S_v2_16_NO_PIPETTES_TC_verifyThermocyclerLoadedSlots].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[973fa979e6][Flex_S_v2_16_NO_PIPETTES_TC_verifyThermocyclerLoadedSlots].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[9bcb0a3f13][pl_normalization_with_csv].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[9bcb0a3f13][pl_normalization_with_csv].json index 23fd7f389a0..ccab060d501 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[9bcb0a3f13][pl_normalization_with_csv].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[9bcb0a3f13][pl_normalization_with_csv].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[9e56ee92f6][Flex_X_v2_16_P1000_96_GRIP_DropLabwareIntoTrashBin].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[9e56ee92f6][Flex_X_v2_16_P1000_96_GRIP_DropLabwareIntoTrashBin].json index aba00388845..6263cb86172 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[9e56ee92f6][Flex_X_v2_16_P1000_96_GRIP_DropLabwareIntoTrashBin].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[9e56ee92f6][Flex_X_v2_16_P1000_96_GRIP_DropLabwareIntoTrashBin].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a01a35c14a][Flex_X_v2_16_NO_PIPETTES_TrashBinInStagingAreaCol3].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a01a35c14a][Flex_X_v2_16_NO_PIPETTES_TrashBinInStagingAreaCol3].json index 7cb88cd0308..ddc34e08100 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a01a35c14a][Flex_X_v2_16_NO_PIPETTES_TrashBinInStagingAreaCol3].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a01a35c14a][Flex_X_v2_16_NO_PIPETTES_TrashBinInStagingAreaCol3].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a06502b2dc][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_description].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a06502b2dc][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_description].json index e2a5dced311..64da6dc2027 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a06502b2dc][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_description].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a06502b2dc][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_description].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [], "config": { "apiVersion": [ diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a08c261369][Flex_S_v2_16_P1000_96_GRIP_DeckConfiguration1NoModulesNoFixtures].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a08c261369][Flex_S_v2_16_P1000_96_GRIP_DeckConfiguration1NoModulesNoFixtures].json index 5bc309d3cac..ade4d36bb2a 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a08c261369][Flex_S_v2_16_P1000_96_GRIP_DeckConfiguration1NoModulesNoFixtures].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a08c261369][Flex_S_v2_16_P1000_96_GRIP_DeckConfiguration1NoModulesNoFixtures].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a0b755a1a1][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_north_west].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a0b755a1a1][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_north_west].json index 68185db5dbd..5113dbf3b85 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a0b755a1a1][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_north_west].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a0b755a1a1][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_north_west].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a0dad2eb8e][pl_SamplePrep_MS_Cleanup_Flex_upto96].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a0dad2eb8e][pl_SamplePrep_MS_Cleanup_Flex_upto96].json index 7aecea25f6a..b4c5a58392a 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a0dad2eb8e][pl_SamplePrep_MS_Cleanup_Flex_upto96].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a0dad2eb8e][pl_SamplePrep_MS_Cleanup_Flex_upto96].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a3dfca7f0c][Flex_S_v2_19_Illumina_DNA_PCR_Free].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a3dfca7f0c][Flex_S_v2_19_Illumina_DNA_PCR_Free].json index 36400ae7de7..6b9ce6ed6d2 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a3dfca7f0c][Flex_S_v2_19_Illumina_DNA_PCR_Free].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a3dfca7f0c][Flex_S_v2_19_Illumina_DNA_PCR_Free].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a437534569][Flex_S_v2_19_kapahyperplus].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a437534569][Flex_S_v2_19_kapahyperplus].json index fe8184c0608..17c5183316b 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a437534569][Flex_S_v2_19_kapahyperplus].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a437534569][Flex_S_v2_19_kapahyperplus].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a46928c103][pl_Nanopore_Genomic_Ligation_v5_Final].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a46928c103][pl_Nanopore_Genomic_Ligation_v5_Final].json index e623aec42f7..f022770ef34 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a46928c103][pl_Nanopore_Genomic_Ligation_v5_Final].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a46928c103][pl_Nanopore_Genomic_Ligation_v5_Final].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a4d3b3a2d3][pl_96_ch_demo_rtp_with_hs].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a4d3b3a2d3][pl_96_ch_demo_rtp_with_hs].json index 0aacb0b3e73..1c8d45ae20b 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a4d3b3a2d3][pl_96_ch_demo_rtp_with_hs].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a4d3b3a2d3][pl_96_ch_demo_rtp_with_hs].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a66d700ed6][OT2_S_v2_13_P300M_P20S_HS_TC_TM_SmokeTestV3].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a66d700ed6][OT2_S_v2_13_P300M_P20S_HS_TC_TM_SmokeTestV3].json index e6cb5eace9a..147dc3fdddd 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a66d700ed6][OT2_S_v2_13_P300M_P20S_HS_TC_TM_SmokeTestV3].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a66d700ed6][OT2_S_v2_13_P300M_P20S_HS_TC_TM_SmokeTestV3].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a8528e52b4][Flex_S_v2_20_96_None_SINGLE_HappyPathSouthSide].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a8528e52b4][Flex_S_v2_20_96_None_SINGLE_HappyPathSouthSide].json index b0eb2e93f00..aa07f2c7074 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a8528e52b4][Flex_S_v2_20_96_None_SINGLE_HappyPathSouthSide].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a8528e52b4][Flex_S_v2_20_96_None_SINGLE_HappyPathSouthSide].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a8a5ad823d][pl_cherrypicking_flex_v3].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a8a5ad823d][pl_cherrypicking_flex_v3].json index 86a33113a16..63d50a1508a 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a8a5ad823d][pl_cherrypicking_flex_v3].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a8a5ad823d][pl_cherrypicking_flex_v3].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a94f22054f][Flex_S_v2_18_kapahyperplus].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a94f22054f][Flex_S_v2_18_kapahyperplus].json index 52120bd6dc3..e2cf7a80abc 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a94f22054f][Flex_S_v2_18_kapahyperplus].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a94f22054f][Flex_S_v2_18_kapahyperplus].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a9557d762c][Flex_X_v2_16_NO_PIPETTES_AccessToFixedTrashProp].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a9557d762c][Flex_X_v2_16_NO_PIPETTES_AccessToFixedTrashProp].json index 1d043a44952..f9d80664de4 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a9557d762c][Flex_X_v2_16_NO_PIPETTES_AccessToFixedTrashProp].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[a9557d762c][Flex_X_v2_16_NO_PIPETTES_AccessToFixedTrashProp].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[aa61eee0bf][pl_sigdx_part2].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[aa61eee0bf][pl_sigdx_part2].json index 93eff2447db..d9080b06e23 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[aa61eee0bf][pl_sigdx_part2].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[aa61eee0bf][pl_sigdx_part2].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[ac5a46e74b][pl_langone_pt2_ribo].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[ac5a46e74b][pl_langone_pt2_ribo].json index ec2e77260d2..6bbc9666568 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[ac5a46e74b][pl_langone_pt2_ribo].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[ac5a46e74b][pl_langone_pt2_ribo].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[ac886d7768][Flex_S_v2_15_P1000_96_GRIP_HS_MB_TC_TM_IDTXgen96Part1to3].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[ac886d7768][Flex_S_v2_15_P1000_96_GRIP_HS_MB_TC_TM_IDTXgen96Part1to3].json index 30f2c70b0ea..47f6cf592cf 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[ac886d7768][Flex_S_v2_15_P1000_96_GRIP_HS_MB_TC_TM_IDTXgen96Part1to3].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[ac886d7768][Flex_S_v2_15_P1000_96_GRIP_HS_MB_TC_TM_IDTXgen96Part1to3].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[acefe91275][OT2_X_v2_20_8_Overrides_InvalidConfigs_Override_eight_partial_column_bottom_left].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[acefe91275][OT2_X_v2_20_8_Overrides_InvalidConfigs_Override_eight_partial_column_bottom_left].json index 1f453e29cf8..752268901b8 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[acefe91275][OT2_X_v2_20_8_Overrides_InvalidConfigs_Override_eight_partial_column_bottom_left].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[acefe91275][OT2_X_v2_20_8_Overrides_InvalidConfigs_Override_eight_partial_column_bottom_left].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[ad627dcedf][OT2_S_v6_P300M_P20S_HS_Smoke620release].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[ad627dcedf][OT2_S_v6_P300M_P20S_HS_Smoke620release].json index 4af69fce36b..a7893fa69f2 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[ad627dcedf][OT2_S_v6_P300M_P20S_HS_Smoke620release].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[ad627dcedf][OT2_S_v6_P300M_P20S_HS_Smoke620release].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[ad9184067d][Flex_X_v2_18_NO_PIPETTES_ReservedWord].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[ad9184067d][Flex_X_v2_18_NO_PIPETTES_ReservedWord].json index ed08b660a33..3940f782426 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[ad9184067d][Flex_X_v2_18_NO_PIPETTES_ReservedWord].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[ad9184067d][Flex_X_v2_18_NO_PIPETTES_ReservedWord].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [], "config": { "apiVersion": [ diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[adc0621263][Flex_X_v2_16_P1000_96_TC_pipetteCollisionWithThermocyclerLid].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[adc0621263][Flex_X_v2_16_P1000_96_TC_pipetteCollisionWithThermocyclerLid].json index a18485392e9..2a342fcb3b8 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[adc0621263][Flex_X_v2_16_P1000_96_TC_pipetteCollisionWithThermocyclerLid].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[adc0621263][Flex_X_v2_16_P1000_96_TC_pipetteCollisionWithThermocyclerLid].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[afd5d372a9][Flex_X_v2_20_96_and_8_Overrides_InvalidConfigs_Override_return_tip_error].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[afd5d372a9][Flex_X_v2_20_96_and_8_Overrides_InvalidConfigs_Override_return_tip_error].json index 9f12179d1e2..6fe758b1dcf 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[afd5d372a9][Flex_X_v2_20_96_and_8_Overrides_InvalidConfigs_Override_return_tip_error].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[afd5d372a9][Flex_X_v2_20_96_and_8_Overrides_InvalidConfigs_Override_return_tip_error].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[b0ce7dde5d][Flex_X_v2_16_P1000_96_TC_PartialTipPickupTryToReturnTip].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[b0ce7dde5d][Flex_X_v2_16_P1000_96_TC_PartialTipPickupTryToReturnTip].json index b41b7117e24..9149f86b3eb 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[b0ce7dde5d][Flex_X_v2_16_P1000_96_TC_PartialTipPickupTryToReturnTip].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[b0ce7dde5d][Flex_X_v2_16_P1000_96_TC_PartialTipPickupTryToReturnTip].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[b48407ff98][pl_cherrypicking_csv_airgap].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[b48407ff98][pl_cherrypicking_csv_airgap].json index 6dffb02e16c..96dab168388 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[b48407ff98][pl_cherrypicking_csv_airgap].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[b48407ff98][pl_cherrypicking_csv_airgap].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[b777168ac1][Flex_S_v2_19_Illumina_Stranded_total_RNA_Ribo_Zero].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[b777168ac1][Flex_S_v2_19_Illumina_Stranded_total_RNA_Ribo_Zero].json index 43f62a32282..68b2b5c1f76 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[b777168ac1][Flex_S_v2_19_Illumina_Stranded_total_RNA_Ribo_Zero].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[b777168ac1][Flex_S_v2_19_Illumina_Stranded_total_RNA_Ribo_Zero].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[b79134ab8a][OT2_X_v2_20_8_Overrides_InvalidConfigs_Override_drop_tip_with_location].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[b79134ab8a][OT2_X_v2_20_8_Overrides_InvalidConfigs_Override_drop_tip_with_location].json index 7956e369c52..d55cf157f22 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[b79134ab8a][OT2_X_v2_20_8_Overrides_InvalidConfigs_Override_drop_tip_with_location].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[b79134ab8a][OT2_X_v2_20_8_Overrides_InvalidConfigs_Override_drop_tip_with_location].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[b806f07be9][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_choice_value].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[b806f07be9][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_choice_value].json index cf8ec946db5..cb3c1622c42 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[b806f07be9][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_choice_value].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[b806f07be9][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_choice_value].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [], "config": { "apiVersion": [ diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[b91d31eaa2][pl_MagMax_RNA_Cells_Flex_96_Channel].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[b91d31eaa2][pl_MagMax_RNA_Cells_Flex_96_Channel].json index db24530e196..713e70bd1a3 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[b91d31eaa2][pl_MagMax_RNA_Cells_Flex_96_Channel].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[b91d31eaa2][pl_MagMax_RNA_Cells_Flex_96_Channel].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[baf79d9b4a][Flex_S_v2_15_P1000S_None_SimpleNormalizeLongRight].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[baf79d9b4a][Flex_S_v2_15_P1000S_None_SimpleNormalizeLongRight].json index 851fd7e1fbb..92be36d9082 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[baf79d9b4a][Flex_S_v2_15_P1000S_None_SimpleNormalizeLongRight].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[baf79d9b4a][Flex_S_v2_15_P1000S_None_SimpleNormalizeLongRight].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[bc049301c1][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_transfer_destination_collision].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[bc049301c1][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_transfer_destination_collision].json index 8c741ed84ba..588a958e032 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[bc049301c1][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_transfer_destination_collision].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[bc049301c1][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_transfer_destination_collision].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c0435f08da][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_north].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c0435f08da][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_north].json index 8c38d6c5f57..6caf8361175 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c0435f08da][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_north].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c0435f08da][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_north].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c064d0de2c][OT2_S_v6_P1000S_None_SimpleTransfer].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c064d0de2c][OT2_S_v6_P1000S_None_SimpleTransfer].json index 4d2cd13d215..85bd3c10876 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c064d0de2c][OT2_S_v6_P1000S_None_SimpleTransfer].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c064d0de2c][OT2_S_v6_P1000S_None_SimpleTransfer].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c195291f84][OT2_S_v2_17_NO_PIPETTES_TC_VerifyThermocyclerLoadedSlots].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c195291f84][OT2_S_v2_17_NO_PIPETTES_TC_VerifyThermocyclerLoadedSlots].json index c2e5c309dcf..2409fd654ad 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c195291f84][OT2_S_v2_17_NO_PIPETTES_TC_VerifyThermocyclerLoadedSlots].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c195291f84][OT2_S_v2_17_NO_PIPETTES_TC_VerifyThermocyclerLoadedSlots].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c1c04baffd][Flex_S_v2_17_NO_PIPETTES_TC_verifyThermocyclerLoadedSlots].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c1c04baffd][Flex_S_v2_17_NO_PIPETTES_TC_verifyThermocyclerLoadedSlots].json index 7c817b2b869..f90f20fca53 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c1c04baffd][Flex_S_v2_17_NO_PIPETTES_TC_verifyThermocyclerLoadedSlots].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c1c04baffd][Flex_S_v2_17_NO_PIPETTES_TC_verifyThermocyclerLoadedSlots].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c3098303ad][OT2_S_v2_15_NO_PIPETTES_TC_VerifyThermocyclerLoadedSlots].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c3098303ad][OT2_S_v2_15_NO_PIPETTES_TC_VerifyThermocyclerLoadedSlots].json index f69446ee9cb..71660ebb915 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c3098303ad][OT2_S_v2_15_NO_PIPETTES_TC_VerifyThermocyclerLoadedSlots].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c3098303ad][OT2_S_v2_15_NO_PIPETTES_TC_VerifyThermocyclerLoadedSlots].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c343dfb5a0][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_bottom_right_edge].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c343dfb5a0][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_bottom_right_edge].json index fe3f96abc67..eeef20742b5 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c343dfb5a0][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_bottom_right_edge].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c343dfb5a0][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_bottom_right_edge].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c745e5824a][Flex_S_v2_16_P1000_96_GRIP_DeckConfiguration1NoModules].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c745e5824a][Flex_S_v2_16_P1000_96_GRIP_DeckConfiguration1NoModules].json index 1a48b84ae0a..ee6ea8de744 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c745e5824a][Flex_S_v2_16_P1000_96_GRIP_DeckConfiguration1NoModules].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c745e5824a][Flex_S_v2_16_P1000_96_GRIP_DeckConfiguration1NoModules].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c821e64fad][OT2_S_v2_13_P300M_P20S_MM_TC_TM_Smoke620Release].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c821e64fad][OT2_S_v2_13_P300M_P20S_MM_TC_TM_Smoke620Release].json index 253a2bcff9d..860e0a4992d 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c821e64fad][OT2_S_v2_13_P300M_P20S_MM_TC_TM_Smoke620Release].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c821e64fad][OT2_S_v2_13_P300M_P20S_MM_TC_TM_Smoke620Release].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c8d2ca0089][Flex_S_v2_18_QIASeq_FX_48x].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c8d2ca0089][Flex_S_v2_18_QIASeq_FX_48x].json index 06153dd11b4..0ca8d07a257 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c8d2ca0089][Flex_S_v2_18_QIASeq_FX_48x].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c8d2ca0089][Flex_S_v2_18_QIASeq_FX_48x].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c9e6e3d59d][OT2_X_v4_P300M_P20S_MM_TC1_TM_e2eTests].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c9e6e3d59d][OT2_X_v4_P300M_P20S_MM_TC1_TM_e2eTests].json index cf748ae6fa0..6d0b54aca57 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c9e6e3d59d][OT2_X_v4_P300M_P20S_MM_TC1_TM_e2eTests].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[c9e6e3d59d][OT2_X_v4_P300M_P20S_MM_TC1_TM_e2eTests].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[cb5adc3d23][OT2_S_v6_P20S_P300M_TransferReTransferLiquid].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[cb5adc3d23][OT2_S_v6_P20S_P300M_TransferReTransferLiquid].json index ac74dbfc2a4..24fdb3ce9d5 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[cb5adc3d23][OT2_S_v6_P20S_P300M_TransferReTransferLiquid].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[cb5adc3d23][OT2_S_v6_P20S_P300M_TransferReTransferLiquid].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[cc26c104b4][Flex_S_v2_20_8_None_SINGLE_HappyPath].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[cc26c104b4][Flex_S_v2_20_8_None_SINGLE_HappyPath].json index c9afc886f56..00720d8483b 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[cc26c104b4][Flex_S_v2_20_8_None_SINGLE_HappyPath].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[cc26c104b4][Flex_S_v2_20_8_None_SINGLE_HappyPath].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[cecd51c8ee][pl_ExpressPlex_96_final].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[cecd51c8ee][pl_ExpressPlex_96_final].json index b591039cbbb..f25a99a256d 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[cecd51c8ee][pl_ExpressPlex_96_final].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[cecd51c8ee][pl_ExpressPlex_96_final].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d0154b1493][Flex_X_v2_20_96_and_8_Overrides_InvalidConfigs_Override_eight_partial_column_bottom_right].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d0154b1493][Flex_X_v2_20_96_and_8_Overrides_InvalidConfigs_Override_eight_partial_column_bottom_right].json index f449eff0d94..376f1a9c3d3 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d0154b1493][Flex_X_v2_20_96_and_8_Overrides_InvalidConfigs_Override_eight_partial_column_bottom_right].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d0154b1493][Flex_X_v2_20_96_and_8_Overrides_InvalidConfigs_Override_eight_partial_column_bottom_right].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d14738bdfe][pl_Zymo_Magbead_DNA_Cells_Flex_multi].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d14738bdfe][pl_Zymo_Magbead_DNA_Cells_Flex_multi].json index a4d46be3d94..5f8a3cd017b 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d14738bdfe][pl_Zymo_Magbead_DNA_Cells_Flex_multi].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d14738bdfe][pl_Zymo_Magbead_DNA_Cells_Flex_multi].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d29d74d7fb][pl_QIASeq_FX_48x_v8].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d29d74d7fb][pl_QIASeq_FX_48x_v8].json index 2f0c52a853f..52ac185b29c 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d29d74d7fb][pl_QIASeq_FX_48x_v8].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d29d74d7fb][pl_QIASeq_FX_48x_v8].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d2c818bf00][Flex_S_v2_20_P50_LPD].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d2c818bf00][Flex_S_v2_20_P50_LPD].json index 1b664b4e963..28841e807c1 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d2c818bf00][Flex_S_v2_20_P50_LPD].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d2c818bf00][Flex_S_v2_20_P50_LPD].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d391213095][Flex_S_v2_15_P1000_96_GRIP_HS_TM_QuickZymoMagbeadRNAExtractionCellsOrBacteria].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d391213095][Flex_S_v2_15_P1000_96_GRIP_HS_TM_QuickZymoMagbeadRNAExtractionCellsOrBacteria].json index 7fd14d2f851..e4a1286a637 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d391213095][Flex_S_v2_15_P1000_96_GRIP_HS_TM_QuickZymoMagbeadRNAExtractionCellsOrBacteria].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d391213095][Flex_S_v2_15_P1000_96_GRIP_HS_TM_QuickZymoMagbeadRNAExtractionCellsOrBacteria].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d3b28ea1d7][pl_Zymo_Magbead_DNA_Cells_Flex_96_channel].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d3b28ea1d7][pl_Zymo_Magbead_DNA_Cells_Flex_96_channel].json index 7916f424286..b1e13b8b61b 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d3b28ea1d7][pl_Zymo_Magbead_DNA_Cells_Flex_96_channel].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d3b28ea1d7][pl_Zymo_Magbead_DNA_Cells_Flex_96_channel].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d48bc4f0c9][OT2_S_v2_17_P300M_P20S_HS_TC_TM_SmokeTestV3].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d48bc4f0c9][OT2_S_v2_17_P300M_P20S_HS_TC_TM_SmokeTestV3].json index 718e0a0df13..e4aa4e3412a 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d48bc4f0c9][OT2_S_v2_17_P300M_P20S_HS_TC_TM_SmokeTestV3].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d48bc4f0c9][OT2_S_v2_17_P300M_P20S_HS_TC_TM_SmokeTestV3].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d6026e11c5][OT2_X_v2_7_P300S_TwinningError].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d6026e11c5][OT2_X_v2_7_P300S_TwinningError].json index 5b6c3c3c690..78d90f8534f 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d6026e11c5][OT2_X_v2_7_P300S_TwinningError].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d6026e11c5][OT2_X_v2_7_P300S_TwinningError].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d61739e6a3][Flex_S_v2_19_IDT_xGen_EZ_48x].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d61739e6a3][Flex_S_v2_19_IDT_xGen_EZ_48x].json index 170de395195..d66fcb6e942 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d61739e6a3][Flex_S_v2_19_IDT_xGen_EZ_48x].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d61739e6a3][Flex_S_v2_19_IDT_xGen_EZ_48x].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d6389183c0][pl_AMPure_XP_48x_v8].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d6389183c0][pl_AMPure_XP_48x_v8].json index 1ad848a9ef8..5e05f94c563 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d6389183c0][pl_AMPure_XP_48x_v8].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d6389183c0][pl_AMPure_XP_48x_v8].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d7e862d601][OT2_S_v2_18_None_None_duplicateChoiceValue].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d7e862d601][OT2_S_v2_18_None_None_duplicateChoiceValue].json index 87b61a0454d..da230dfc11c 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d7e862d601][OT2_S_v2_18_None_None_duplicateChoiceValue].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d7e862d601][OT2_S_v2_18_None_None_duplicateChoiceValue].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d8cb88b3b2][Flex_S_v2_16_P1000_96_TC_PartialTipPickupSingle].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d8cb88b3b2][Flex_S_v2_16_P1000_96_TC_PartialTipPickupSingle].json index aba7dd56957..1587a2ce11d 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d8cb88b3b2][Flex_S_v2_16_P1000_96_TC_PartialTipPickupSingle].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d8cb88b3b2][Flex_S_v2_16_P1000_96_TC_PartialTipPickupSingle].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d979799443][OT2_S_v2_20_8_None_SINGLE_HappyPath].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d979799443][OT2_S_v2_20_8_None_SINGLE_HappyPath].json index bd408636813..30710e984f2 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d979799443][OT2_S_v2_20_8_None_SINGLE_HappyPath].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[d979799443][OT2_S_v2_20_8_None_SINGLE_HappyPath].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[da326082e1][pl_Hyperplus_tiptracking_V4_final].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[da326082e1][pl_Hyperplus_tiptracking_V4_final].json index 2651a003e75..47372d63a60 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[da326082e1][pl_Hyperplus_tiptracking_V4_final].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[da326082e1][pl_Hyperplus_tiptracking_V4_final].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[dabb7872d8][Flex_S_v2_19_P1000_96_GRIP_HS_MB_TC_TM_Smoke].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[dabb7872d8][Flex_S_v2_19_P1000_96_GRIP_HS_MB_TC_TM_Smoke].json index c52ed516ba1..cdbd9ad8690 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[dabb7872d8][Flex_S_v2_19_P1000_96_GRIP_HS_MB_TC_TM_Smoke].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[dabb7872d8][Flex_S_v2_19_P1000_96_GRIP_HS_MB_TC_TM_Smoke].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[db1fae41ec][Flex_X_v2_20_96_and_8_Overrides_InvalidConfigs_Override_ninety_six_partial_column_3].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[db1fae41ec][Flex_X_v2_20_96_and_8_Overrides_InvalidConfigs_Override_ninety_six_partial_column_3].json index 62ea1e316b2..dd86269548a 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[db1fae41ec][Flex_X_v2_20_96_and_8_Overrides_InvalidConfigs_Override_ninety_six_partial_column_3].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[db1fae41ec][Flex_X_v2_20_96_and_8_Overrides_InvalidConfigs_Override_ninety_six_partial_column_3].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[dbba7a71a8][OT2_S_v2_16_NO_PIPETTES_TC_VerifyThermocyclerLoadedSlots].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[dbba7a71a8][OT2_S_v2_16_NO_PIPETTES_TC_VerifyThermocyclerLoadedSlots].json index 9e3cf07280a..34f2475222d 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[dbba7a71a8][OT2_S_v2_16_NO_PIPETTES_TC_VerifyThermocyclerLoadedSlots].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[dbba7a71a8][OT2_S_v2_16_NO_PIPETTES_TC_VerifyThermocyclerLoadedSlots].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[de4249ddfb][Flex_X_v2_16_NO_PIPETTES_TC_TrashBinAndThermocyclerConflict].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[de4249ddfb][Flex_X_v2_16_NO_PIPETTES_TC_TrashBinAndThermocyclerConflict].json index 2eb5308529f..9ea60fdbe89 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[de4249ddfb][Flex_X_v2_16_NO_PIPETTES_TC_TrashBinAndThermocyclerConflict].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[de4249ddfb][Flex_X_v2_16_NO_PIPETTES_TC_TrashBinAndThermocyclerConflict].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e0b0133ffb][pl_Illumina_Stranded_total_RNA_Ribo_Zero_protocol].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e0b0133ffb][pl_Illumina_Stranded_total_RNA_Ribo_Zero_protocol].json index 1bb680c2c4f..dba92ac69c0 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e0b0133ffb][pl_Illumina_Stranded_total_RNA_Ribo_Zero_protocol].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e0b0133ffb][pl_Illumina_Stranded_total_RNA_Ribo_Zero_protocol].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e18bdd6f5d][Flex_S_2_15_P1000M_P50M_GRIP_HS_TM_MB_TC_KAPALibraryQuantv4_8].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e18bdd6f5d][Flex_S_2_15_P1000M_P50M_GRIP_HS_TM_MB_TC_KAPALibraryQuantv4_8].json index 6c6c30ace61..5d73cd7496a 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e18bdd6f5d][Flex_S_2_15_P1000M_P50M_GRIP_HS_TM_MB_TC_KAPALibraryQuantv4_8].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e18bdd6f5d][Flex_S_2_15_P1000M_P50M_GRIP_HS_TM_MB_TC_KAPALibraryQuantv4_8].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e42e36e3ca][OT2_X_v2_13_None_None_PythonSyntaxError].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e42e36e3ca][OT2_X_v2_13_None_None_PythonSyntaxError].json index 0dd0410636f..954ce38e892 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e42e36e3ca][OT2_X_v2_13_None_None_PythonSyntaxError].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e42e36e3ca][OT2_X_v2_13_None_None_PythonSyntaxError].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [], "config": { "apiVersion": [ diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e4660ca6df][OT2_S_v4_P300S_None_MM_TM_TM_MOAMTemps].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e4660ca6df][OT2_S_v4_P300S_None_MM_TM_TM_MOAMTemps].json index 1e4573b1d8e..779ef4878c0 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e4660ca6df][OT2_S_v4_P300S_None_MM_TM_TM_MOAMTemps].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e4660ca6df][OT2_S_v4_P300S_None_MM_TM_TM_MOAMTemps].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e496fec176][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_default].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e496fec176][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_default].json index f6c1ad84067..63d7284587d 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e496fec176][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_default].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e496fec176][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_default].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [], "config": { "apiVersion": [ diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e4b5b30b2e][Flex_S_v2_18_Illumina_DNA_PCR_Free].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e4b5b30b2e][Flex_S_v2_18_Illumina_DNA_PCR_Free].json index aca7454ff36..881892ce99c 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e4b5b30b2e][Flex_S_v2_18_Illumina_DNA_PCR_Free].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e4b5b30b2e][Flex_S_v2_18_Illumina_DNA_PCR_Free].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e71b031f47][pl_Illumina_DNA_PCR_Free].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e71b031f47][pl_Illumina_DNA_PCR_Free].json index 803f4133451..94c209d56fb 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e71b031f47][pl_Illumina_DNA_PCR_Free].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e71b031f47][pl_Illumina_DNA_PCR_Free].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e84e23a4ea][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_top_edge].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e84e23a4ea][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_top_edge].json index ea9fbf3efb7..b7124e15878 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e84e23a4ea][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_top_edge].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e84e23a4ea][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_top_edge].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e8f451df45][Flex_S_v2_20_96_None_Column3_SINGLE_].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e8f451df45][Flex_S_v2_20_96_None_Column3_SINGLE_].json index 81ebf160345..44a1b40bdff 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e8f451df45][Flex_S_v2_20_96_None_Column3_SINGLE_].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[e8f451df45][Flex_S_v2_20_96_None_Column3_SINGLE_].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[ed1e64c539][Flex_X_v2_16_NO_PIPETTES_TM_ModuleInCol2].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[ed1e64c539][Flex_X_v2_16_NO_PIPETTES_TM_ModuleInCol2].json index 709b448717c..b3a25267695 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[ed1e64c539][Flex_X_v2_16_NO_PIPETTES_TM_ModuleInCol2].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[ed1e64c539][Flex_X_v2_16_NO_PIPETTES_TM_ModuleInCol2].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[ed26635ff7][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_consolidate_source_collision].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[ed26635ff7][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_consolidate_source_collision].json index ed5d5a67171..5b9053fbea9 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[ed26635ff7][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_consolidate_source_collision].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[ed26635ff7][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_consolidate_source_collision].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[ed2f3800b6][Flex_S_2_18_P1000M_P50M_GRIP_HS_TM_MB_TC_IlluminaDNAPrep24xV4_7].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[ed2f3800b6][Flex_S_2_18_P1000M_P50M_GRIP_HS_TM_MB_TC_IlluminaDNAPrep24xV4_7].json index d946aae6d9d..0b3e8abb54a 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[ed2f3800b6][Flex_S_2_18_P1000M_P50M_GRIP_HS_TM_MB_TC_IlluminaDNAPrep24xV4_7].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[ed2f3800b6][Flex_S_2_18_P1000M_P50M_GRIP_HS_TM_MB_TC_IlluminaDNAPrep24xV4_7].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f0efddcd7d][Flex_X_v2_16_P1000_96_DropTipsWithNoTrash].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f0efddcd7d][Flex_X_v2_16_P1000_96_DropTipsWithNoTrash].json index d1a7a88d075..f7d8523d4ed 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f0efddcd7d][Flex_X_v2_16_P1000_96_DropTipsWithNoTrash].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f0efddcd7d][Flex_X_v2_16_P1000_96_DropTipsWithNoTrash].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f24bb0b4d9][Flex_S_v2_15_P1000_96_GRIP_HS_MB_TC_TM_IlluminaDNAPrep96PART3].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f24bb0b4d9][Flex_S_v2_15_P1000_96_GRIP_HS_MB_TC_TM_IlluminaDNAPrep96PART3].json index d454695d871..4edad2057aa 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f24bb0b4d9][Flex_S_v2_15_P1000_96_GRIP_HS_MB_TC_TM_IlluminaDNAPrep96PART3].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f24bb0b4d9][Flex_S_v2_15_P1000_96_GRIP_HS_MB_TC_TM_IlluminaDNAPrep96PART3].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f301704f56][OT2_S_v6_P300M_P300S_HS_HS_NormalUseWithTransfer].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f301704f56][OT2_S_v6_P300M_P300S_HS_HS_NormalUseWithTransfer].json index 3d7f6d10b51..f8f18638c3c 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f301704f56][OT2_S_v6_P300M_P300S_HS_HS_NormalUseWithTransfer].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f301704f56][OT2_S_v6_P300M_P300S_HS_HS_NormalUseWithTransfer].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f345e8e33a][OT2_S_v4_P300M_P20S_MM_TM_TC1_PD40].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f345e8e33a][OT2_S_v4_P300M_P20S_MM_TM_TC1_PD40].json index d86eae54045..9fe2587f149 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f345e8e33a][OT2_S_v4_P300M_P20S_MM_TM_TC1_PD40].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f345e8e33a][OT2_S_v4_P300M_P20S_MM_TM_TC1_PD40].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f37bb0ec36][OT2_S_v2_16_NO_PIPETTES_verifyDoesNotDeadlock].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f37bb0ec36][OT2_S_v2_16_NO_PIPETTES_verifyDoesNotDeadlock].json index e0c21a82e55..494cd46f04d 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f37bb0ec36][OT2_S_v2_16_NO_PIPETTES_verifyDoesNotDeadlock].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f37bb0ec36][OT2_S_v2_16_NO_PIPETTES_verifyDoesNotDeadlock].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f51172f73b][Flex_S_v2_16_P1000_96_GRIP_HS_MB_TC_TM_Smoke].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f51172f73b][Flex_S_v2_16_P1000_96_GRIP_HS_MB_TC_TM_Smoke].json index 50ab65351e1..02fc36fe2bd 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f51172f73b][Flex_S_v2_16_P1000_96_GRIP_HS_MB_TC_TM_Smoke].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f51172f73b][Flex_S_v2_16_P1000_96_GRIP_HS_MB_TC_TM_Smoke].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f5f3b9c5bb][Flex_X_v2_16_P1000_96_TM_ModuleAndWasteChuteConflict].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f5f3b9c5bb][Flex_X_v2_16_P1000_96_TM_ModuleAndWasteChuteConflict].json index 950c5ee4395..48d7508e005 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f5f3b9c5bb][Flex_X_v2_16_P1000_96_TM_ModuleAndWasteChuteConflict].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f5f3b9c5bb][Flex_X_v2_16_P1000_96_TM_ModuleAndWasteChuteConflict].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f639acc89d][Flex_S_v2_15_NO_PIPETTES_TC_verifyThermocyclerLoadedSlots].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f639acc89d][Flex_S_v2_15_NO_PIPETTES_TC_verifyThermocyclerLoadedSlots].json index e4fed39c549..8ebd28d3748 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f639acc89d][Flex_S_v2_15_NO_PIPETTES_TC_verifyThermocyclerLoadedSlots].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f639acc89d][Flex_S_v2_15_NO_PIPETTES_TC_verifyThermocyclerLoadedSlots].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f6c1ddbb32][pl_ExpressPlex_Pooling_Final].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f6c1ddbb32][pl_ExpressPlex_Pooling_Final].json index 920a648041a..b4e6116993a 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f6c1ddbb32][pl_ExpressPlex_Pooling_Final].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f6c1ddbb32][pl_ExpressPlex_Pooling_Final].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f7085d7134][Flex_X_v2_16_P1000_96_TC_pipetteCollisionWithThermocyclerLidClips].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f7085d7134][Flex_X_v2_16_P1000_96_TC_pipetteCollisionWithThermocyclerLidClips].json index 7ad30e9d04e..81a870ec2c9 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f7085d7134][Flex_X_v2_16_P1000_96_TC_pipetteCollisionWithThermocyclerLidClips].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f7085d7134][Flex_X_v2_16_P1000_96_TC_pipetteCollisionWithThermocyclerLidClips].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f834b97da1][Flex_S_v2_16_P1000_96_GRIP_HS_MB_TC_TM_DeckConfiguration1].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f834b97da1][Flex_S_v2_16_P1000_96_GRIP_HS_MB_TC_TM_DeckConfiguration1].json index acf7455e286..6d3153af4eb 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f834b97da1][Flex_S_v2_16_P1000_96_GRIP_HS_MB_TC_TM_DeckConfiguration1].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f834b97da1][Flex_S_v2_16_P1000_96_GRIP_HS_MB_TC_TM_DeckConfiguration1].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f86713b4d4][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_distribute_source_collision].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f86713b4d4][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_distribute_source_collision].json index 1fdb58d69ab..044d6d802f4 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f86713b4d4][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_distribute_source_collision].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f86713b4d4][Flex_X_v2_20_96_None_Overrides_TooTallLabware_Override_distribute_source_collision].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f88b7d6e30][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_display_name].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f88b7d6e30][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_display_name].json index fe2e22fae05..e181f59e6cd 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f88b7d6e30][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_display_name].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[f88b7d6e30][Flex_X_v2_18_NO_PIPETTES_Overrides_BadTypesInRTP_Override_wrong_type_in_display_name].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [], "config": { "apiVersion": [ diff --git a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[fc60ef9cbd][OT2_S_v2_16_P300M_P20S_HS_TC_TM_dispense_changes].json b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[fc60ef9cbd][OT2_S_v2_16_P300M_P20S_HS_TC_TM_dispense_changes].json index cd25845d931..da344f2c829 100644 --- a/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[fc60ef9cbd][OT2_S_v2_16_P300M_P20S_HS_TC_TM_dispense_changes].json +++ b/analyses-snapshot-testing/tests/__snapshots__/analyses_snapshot_test/test_analysis_snapshot[fc60ef9cbd][OT2_S_v2_16_P300M_P20S_HS_TC_TM_dispense_changes].json @@ -1,4 +1,5 @@ { + "commandAnnotations": [], "commands": [ { "commandType": "home", diff --git a/api/src/opentrons/cli/analyze.py b/api/src/opentrons/cli/analyze.py index 4c994fcf630..e98f3e807d7 100644 --- a/api/src/opentrons/cli/analyze.py +++ b/api/src/opentrons/cli/analyze.py @@ -57,6 +57,7 @@ StateSummary, ) from opentrons.protocol_engine.protocol_engine import code_in_error_tree +from opentrons.protocol_engine.types import CommandAnnotation from opentrons_shared_data.robot.types import RobotType @@ -337,6 +338,7 @@ async def _do_analyze( liquidClasses=[], ), parameters=[], + command_annotations=[], ) return analysis return await orchestrator.run(deck_configuration=[]) @@ -401,6 +403,7 @@ async def _analyze( pipettes=analysis.state_summary.pipettes, modules=analysis.state_summary.modules, liquids=analysis.state_summary.liquids, + commandAnnotations=analysis.command_annotations, liquidClasses=analysis.state_summary.liquidClasses, ) @@ -491,3 +494,4 @@ class AnalyzeResults(BaseModel): liquids: List[Liquid] liquidClasses: List[LiquidClassRecordWithId] errors: List[ErrorOccurrence] + commandAnnotations: List[CommandAnnotation] diff --git a/api/src/opentrons/protocol_engine/types.py b/api/src/opentrons/protocol_engine/types.py index f5cfb485611..11f1972e105 100644 --- a/api/src/opentrons/protocol_engine/types.py +++ b/api/src/opentrons/protocol_engine/types.py @@ -13,6 +13,7 @@ StrictInt, StrictStr, validator, + Extra, ) from typing import ( Optional, @@ -1146,6 +1147,55 @@ class NoTipAvailable(BaseModel): ) +class BaseCommandAnnotation(BaseModel): + """Optional annotations for protocol engine commands.""" + + commandKeys: List[str] = Field( + ..., description="Command keys to which this annotation applies" + ) + annotationType: str = Field( + ..., description="The type of annotation (for machine parsing)" + ) + + +class SecondOrderCommandAnnotation(BaseCommandAnnotation): + """Annotates a group of atomic commands which were the direct result of a second order command. + + Examples of second order commands would be transfer, consolidate, mix, etc. + """ + + annotationType: Literal["secondOrderCommand"] = "secondOrderCommand" + params: Dict[str, Any] = Field( + ..., + description="Key value pairs of the parameters passed to the second order command that this annotates.", + ) + machineReadableName: str = Field( + ..., + description="The name of the second order command in the form that the generating software refers to it", + ) + userSpecifiedName: Optional[str] = Field( + None, description="The optional user-specified name of the second order command" + ) + userSpecifiedDescription: Optional[str] = Field( + None, + description="The optional user-specified description of the second order command", + ) + + +class CustomCommandAnnotation(BaseCommandAnnotation): + """Annotates a group of atomic commands in some manner that Opentrons software does not anticipate or originate.""" + + annotationType: Literal["custom"] = "custom" + + class Config: + """Config to allow extra, non-defined properties.""" + + extra = Extra.allow + + +CommandAnnotation = Union[SecondOrderCommandAnnotation, CustomCommandAnnotation] + + # TODO (spp, 2024-04-02): move all RTP types to runner class RTPBase(BaseModel): """Parameters defined in a protocol.""" diff --git a/api/src/opentrons/protocol_runner/json_translator.py b/api/src/opentrons/protocol_runner/json_translator.py index 6c670baf97a..767bf058730 100644 --- a/api/src/opentrons/protocol_runner/json_translator.py +++ b/api/src/opentrons/protocol_runner/json_translator.py @@ -22,7 +22,7 @@ DeckSlotLocation, Liquid, ) -from opentrons.protocol_engine.types import HexColor +from opentrons.protocol_engine.types import HexColor, CommandAnnotation class CommandTranslatorError(Exception): @@ -284,3 +284,20 @@ def translate_all_commands() -> Iterator[pe_commands.CommandCreate]: ) return list(translate_all_commands()) + + def translate_command_annotations( + self, + protocol: Union[ProtocolSchemaV8, ProtocolSchemaV7, ProtocolSchemaV6], + ) -> List[CommandAnnotation]: + """Translate command annotations in json protocol schema v8.""" + if isinstance(protocol, (ProtocolSchemaV6, ProtocolSchemaV7)): + return [] + else: + command_annotations: List[CommandAnnotation] = [ + parse_obj_as( + CommandAnnotation, # type: ignore[arg-type] + command_annotation.dict(), + ) + for command_annotation in protocol.commandAnnotations + ] + return command_annotations diff --git a/api/src/opentrons/protocol_runner/protocol_runner.py b/api/src/opentrons/protocol_runner/protocol_runner.py index aec2aae80df..ed540020d24 100644 --- a/api/src/opentrons/protocol_runner/protocol_runner.py +++ b/api/src/opentrons/protocol_runner/protocol_runner.py @@ -24,6 +24,7 @@ Command, commands as pe_commands, ) +from opentrons.protocol_engine.types import CommandAnnotation from opentrons.protocols.parse import PythonParseMode from opentrons.util.async_helpers import asyncio_yield from opentrons.util.broker import Broker @@ -56,6 +57,7 @@ class RunResult(NamedTuple): commands: List[Command] state_summary: StateSummary parameters: List[RunTimeParameter] + command_annotations: List[CommandAnnotation] class AbstractRunner(ABC): @@ -93,6 +95,11 @@ def run_time_parameters(self) -> List[RunTimeParameter]: """Parameter definitions defined by protocol, if any. Currently only for python protocols.""" return [] + @property + def command_annotations(self) -> List[CommandAnnotation]: + """Command annotations defined by protocol, if any. Currently only for json protocols.""" + return [] + def was_started(self) -> bool: """Whether the run has been started. @@ -177,7 +184,7 @@ def __init__( @property def run_time_parameters(self) -> List[RunTimeParameter]: - """Parameter definitions defined by protocol, if any. Will always be empty before execution.""" + """Parameter definitions defined by protocol, if any.""" if self._parameter_context is not None: return self._parameter_context.export_parameters_for_analysis() return [] @@ -278,7 +285,10 @@ async def run( # noqa: D102 commands = self._protocol_engine.state_view.commands.get_all() parameters = self.run_time_parameters return RunResult( - commands=commands, state_summary=run_data, parameters=parameters + commands=commands, + state_summary=run_data, + parameters=parameters, + command_annotations=[], ) @@ -313,6 +323,12 @@ def __init__( hardware_api.should_taskify_movement_execution(taskify=False) self._queued_commands: List[pe_commands.CommandCreate] = [] + self._command_annotations: List[CommandAnnotation] = [] + + @property + def command_annotations(self) -> List[CommandAnnotation]: + """Command annotations defined by protocol, if any.""" + return self._command_annotations async def load(self, protocol_source: ProtocolSource) -> None: """Load a JSONv6+ ProtocolSource into managed ProtocolEngine.""" @@ -355,6 +371,11 @@ async def load(self, protocol_source: ProtocolSource) -> None: ) await asyncio_yield() + self._command_annotations = await anyio.to_thread.run_sync( + self._json_translator.translate_command_annotations, + protocol, + ) + initial_home_command = pe_commands.HomeCreate( params=pe_commands.HomeParams(axes=None) ) @@ -382,7 +403,12 @@ async def run( # noqa: D102 run_data = self._protocol_engine.state_view.get_summary() commands = self._protocol_engine.state_view.commands.get_all() - return RunResult(commands=commands, state_summary=run_data, parameters=[]) + return RunResult( + commands=commands, + state_summary=run_data, + parameters=[], + command_annotations=self._command_annotations, + ) async def _add_and_execute_commands(self) -> None: for command_request in self._queued_commands: @@ -453,7 +479,12 @@ async def run( # noqa: D102 run_data = self._protocol_engine.state_view.get_summary() commands = self._protocol_engine.state_view.commands.get_all() - return RunResult(commands=commands, state_summary=run_data, parameters=[]) + return RunResult( + commands=commands, + state_summary=run_data, + parameters=[], + command_annotations=[], + ) AnyRunner = Union[PythonAndLegacyRunner, JsonRunner, LiveRunner] diff --git a/api/src/opentrons/protocol_runner/run_orchestrator.py b/api/src/opentrons/protocol_runner/run_orchestrator.py index 5568639f246..28266a9c485 100644 --- a/api/src/opentrons/protocol_runner/run_orchestrator.py +++ b/api/src/opentrons/protocol_runner/run_orchestrator.py @@ -37,6 +37,7 @@ RunTimeParameter, PrimitiveRunTimeParamValuesType, CSVRuntimeParamPaths, + CommandAnnotation, ) from ..protocol_engine.error_recovery_policy import ErrorRecoveryPolicy @@ -254,6 +255,14 @@ def get_run_time_parameters(self) -> List[RunTimeParameter]: else self._protocol_runner.run_time_parameters ) + def get_command_annotations(self) -> List[CommandAnnotation]: + """Get the list of command annotations defined in the protocol, if any.""" + return ( + [] + if self._protocol_runner is None + else self._protocol_runner.command_annotations + ) + def get_current_command(self) -> Optional[CommandPointer]: """Get the "current" command, if any.""" return self._protocol_engine.state_view.commands.get_current() diff --git a/app/src/organisms/Desktop/ProtocolDetails/AnnotatedSteps.tsx b/app/src/organisms/Desktop/ProtocolDetails/AnnotatedSteps.tsx index 52837338fca..ba871e50fef 100644 --- a/app/src/organisms/Desktop/ProtocolDetails/AnnotatedSteps.tsx +++ b/app/src/organisms/Desktop/ProtocolDetails/AnnotatedSteps.tsx @@ -1,4 +1,4 @@ -import { useMemo } from 'react' +import { useMemo, useState } from 'react' import { css } from 'styled-components' import { FLEX_ROBOT_TYPE } from '@opentrons/shared-data' @@ -12,31 +12,34 @@ import { LegacyStyledText, TYPOGRAPHY, OVERFLOW_AUTO, + Icon, + ALIGN_FLEX_START, + CURSOR_POINTER, } from '@opentrons/components' import { CommandIcon, CommandText } from '/app/molecules/Command' import { getLabwareDefinitionsFromCommands } from '/app/local-resources/labware' - import type { CompletedProtocolAnalysis, ProtocolAnalysisOutput, RunTimeCommand, LabwareDefinition2, } from '@opentrons/shared-data' +import type { GroupedCommands, LeafNode } from '/app/redux/protocol-storage' interface AnnotatedStepsProps { analysis: CompletedProtocolAnalysis | ProtocolAnalysisOutput + groupedCommands: GroupedCommands | null currentCommandIndex?: number } export function AnnotatedSteps(props: AnnotatedStepsProps): JSX.Element { - const { analysis, currentCommandIndex } = props + const { analysis, currentCommandIndex, groupedCommands } = props const HIDE_SCROLLBAR = css` ::-webkit-scrollbar { display: none; } ` - const isValidRobotSideAnalysis = analysis != null const allRunDefs = useMemo( () => @@ -45,6 +48,30 @@ export function AnnotatedSteps(props: AnnotatedStepsProps): JSX.Element { : [], [isValidRobotSideAnalysis] ) + const annotations = analysis?.commandAnnotations ?? [] + + // NOTE: isHighlighted is meant to show when running on the protocol in the run log + // but isn't in use during protocol details. Therefore, this info is not in use and is + // merely a proof-of-concept for when we do add this to the run log. + const groupedCommandsHighlightedInfo = groupedCommands?.map(node => { + if ('annotationIndex' in node) { + return { + ...node, + isHighlighted: node.subCommands.some(subNode => subNode.isHighlighted), + subCommands: node.subCommands.map(subNode => ({ + ...subNode, + isHighlighted: + currentCommandIndex === analysis.commands.indexOf(subNode.command), + })), + } + } else { + return { + ...node, + isHighlighted: + currentCommandIndex === analysis.commands.indexOf(node.command), + } + } + }) return ( - {analysis.commands.map((c, i) => ( - - ))} + {groupedCommandsHighlightedInfo != null && + groupedCommandsHighlightedInfo.length > 0 + ? groupedCommandsHighlightedInfo.map((c, i) => + 'annotationIndex' in c ? ( + + ) : ( + + ) + ) + : analysis.commands.map((c, i) => ( + + ))} ) } +interface AnnotatedGroupProps { + annotationType: string + subCommands: LeafNode[] + analysis: ProtocolAnalysisOutput | CompletedProtocolAnalysis + stepNumber: string + isHighlighted: boolean + allRunDefs: LabwareDefinition2[] +} +function AnnotatedGroup(props: AnnotatedGroupProps): JSX.Element { + const { + subCommands, + annotationType, + analysis, + stepNumber, + allRunDefs, + isHighlighted, + } = props + const [isExpanded, setIsExpanded] = useState(false) + const backgroundColor = isHighlighted ? COLORS.blue30 : COLORS.grey20 + return ( + { + setIsExpanded(!isExpanded) + }} + cursor={CURSOR_POINTER} + > + {isExpanded ? ( + + + + {stepNumber} + + + + {annotationType} + + + + + + {subCommands.map((c, i) => ( + + ))} + + + ) : ( + + {stepNumber} + + + {annotationType} + + + + + )} + + ) +} + interface IndividualCommandProps { command: RunTimeCommand analysis: ProtocolAnalysisOutput | CompletedProtocolAnalysis diff --git a/app/src/organisms/Desktop/ProtocolDetails/__tests__/ProtocolDetails.test.tsx b/app/src/organisms/Desktop/ProtocolDetails/__tests__/ProtocolDetails.test.tsx index 8ef02d4d67a..f613c108b77 100644 --- a/app/src/organisms/Desktop/ProtocolDetails/__tests__/ProtocolDetails.test.tsx +++ b/app/src/organisms/Desktop/ProtocolDetails/__tests__/ProtocolDetails.test.tsx @@ -41,7 +41,9 @@ const render = ( ) => { return renderWithProviders( - + , { i18nInstance: i18n, diff --git a/app/src/organisms/Desktop/ProtocolDetails/index.tsx b/app/src/organisms/Desktop/ProtocolDetails/index.tsx index 607321f76db..860c4170a69 100644 --- a/app/src/organisms/Desktop/ProtocolDetails/index.tsx +++ b/app/src/organisms/Desktop/ProtocolDetails/index.tsx @@ -77,7 +77,10 @@ import type { PythonConfig, LoadLabwareRunTimeCommand, } from '@opentrons/shared-data' -import type { StoredProtocolData } from '/app/redux/protocol-storage' +import type { + GroupedCommands, + StoredProtocolData, +} from '/app/redux/protocol-storage' import type { State, Dispatch } from '/app/redux/types' const GRID_STYLE = css` @@ -203,14 +206,22 @@ const ReadMoreContent = (props: ReadMoreContentProps): JSX.Element => { ) } -interface ProtocolDetailsProps extends StoredProtocolData {} +interface ProtocolDetailsProps extends StoredProtocolData { + groupedCommands: GroupedCommands | null +} export function ProtocolDetails( props: ProtocolDetailsProps ): JSX.Element | null { const trackEvent = useTrackEvent() const dispatch = useDispatch() - const { protocolKey, srcFileNames, mostRecentAnalysis, modified } = props + const { + protocolKey, + srcFileNames, + mostRecentAnalysis, + modified, + groupedCommands, + } = props const { t, i18n } = useTranslation(['protocol_details', 'shared']) const enableProtocolStats = useFeatureFlag('protocolStats') const enableProtocolTimeline = useFeatureFlag('protocolTimeline') @@ -338,7 +349,10 @@ export function ProtocolDetails( ) : null, timeline: enableProtocolTimeline && mostRecentAnalysis != null ? ( - + ) : null, parameters: , } diff --git a/app/src/pages/Desktop/Protocols/ProtocolDetails/index.tsx b/app/src/pages/Desktop/Protocols/ProtocolDetails/index.tsx index 66402416da7..bd301c526f4 100644 --- a/app/src/pages/Desktop/Protocols/ProtocolDetails/index.tsx +++ b/app/src/pages/Desktop/Protocols/ProtocolDetails/index.tsx @@ -2,7 +2,11 @@ import { useEffect } from 'react' import { useParams, Navigate } from 'react-router-dom' import { useDispatch, useSelector } from 'react-redux' -import { fetchProtocols, getStoredProtocol } from '/app/redux/protocol-storage' +import { + fetchProtocols, + getStoredProtocol, + getStoredProtocolGroupedCommands, +} from '/app/redux/protocol-storage' import { ProtocolDetails as ProtocolDetailsContents } from '/app/organisms/Desktop/ProtocolDetails' import type { Dispatch, State } from '/app/redux/types' @@ -17,13 +21,18 @@ export function ProtocolDetails(): JSX.Element { const storedProtocol = useSelector((state: State) => getStoredProtocol(state, protocolKey) ) - + const groupedCommands = useSelector((state: State) => + getStoredProtocolGroupedCommands(state, protocolKey) + ) useEffect(() => { dispatch(fetchProtocols()) }, [dispatch]) return storedProtocol != null ? ( - + ) : ( ) diff --git a/app/src/redux/protocol-storage/selectors.ts b/app/src/redux/protocol-storage/selectors.ts index 4684443918b..c351f07b708 100644 --- a/app/src/redux/protocol-storage/selectors.ts +++ b/app/src/redux/protocol-storage/selectors.ts @@ -1,7 +1,8 @@ import { createSelector } from 'reselect' +import { getGroupedCommands } from './utils' import type { State } from '../types' -import type { StoredProtocolData } from './types' +import type { GroupedCommands, StoredProtocolData } from './types' export const getStoredProtocols: ( state: State @@ -27,3 +28,26 @@ export const getIsProtocolAnalysisInProgress: ( protocolKey: string ) => boolean = (state, protocolKey) => state.protocolStorage.inProgressAnalysisProtocolKeys.includes(protocolKey) + +export const getStoredProtocolGroupedCommands: ( + state: State, + protocolKey?: string | null +) => GroupedCommands | null = (state, protocolKey) => { + const storedProtocolData = + protocolKey != null + ? state.protocolStorage.filesByProtocolKey[protocolKey] ?? null + : null + + if (storedProtocolData == null) { + return null + } + const mostRecentAnalysis = storedProtocolData.mostRecentAnalysis + const groupedCommands = + mostRecentAnalysis != null && + mostRecentAnalysis.commandAnnotations != null && + mostRecentAnalysis.commandAnnotations.length > 0 + ? getGroupedCommands(mostRecentAnalysis) + : [] + + return groupedCommands +} diff --git a/app/src/redux/protocol-storage/types.ts b/app/src/redux/protocol-storage/types.ts index e406cee24ca..5297c09c417 100644 --- a/app/src/redux/protocol-storage/types.ts +++ b/app/src/redux/protocol-storage/types.ts @@ -1,6 +1,9 @@ // common types -import type { ProtocolAnalysisOutput } from '@opentrons/shared-data' +import type { + ProtocolAnalysisOutput, + RunTimeCommand, +} from '@opentrons/shared-data' export type ProtocolSort = | 'alphabetical' @@ -10,6 +13,18 @@ export type ProtocolSort = | 'flex' | 'ot2' +interface ParentNode { + annotationIndex: number + subCommands: LeafNode[] + isHighlighted: boolean +} +export interface LeafNode { + command: RunTimeCommand + isHighlighted: boolean +} + +export type GroupedCommands = Array + export interface StoredProtocolDir { dirPath: string modified: number diff --git a/app/src/redux/protocol-storage/utils.ts b/app/src/redux/protocol-storage/utils.ts new file mode 100644 index 00000000000..8d1094aee5d --- /dev/null +++ b/app/src/redux/protocol-storage/utils.ts @@ -0,0 +1,47 @@ +import type { + CompletedProtocolAnalysis, + ProtocolAnalysisOutput, +} from '@opentrons/shared-data' +import type { GroupedCommands } from './types' + +export const getGroupedCommands = ( + mostRecentAnalysis: ProtocolAnalysisOutput | CompletedProtocolAnalysis +): GroupedCommands => { + const annotations = mostRecentAnalysis?.commandAnnotations ?? [] + return mostRecentAnalysis.commands.reduce((acc, c) => { + const foundAnnotationIndex = annotations.findIndex( + a => c.key != null && a.commandKeys.includes(c.key) + ) + const lastAccNode = acc[acc.length - 1] + if ( + acc.length > 0 && + c.key != null && + 'annotationIndex' in lastAccNode && + lastAccNode.annotationIndex != null && + annotations[lastAccNode.annotationIndex]?.commandKeys.includes(c.key) + ) { + return [ + ...acc.slice(0, -1), + { + ...lastAccNode, + subCommands: [ + ...lastAccNode.subCommands, + { command: c, isHighlighted: false }, + ], + isHighlighted: false, + }, + ] + } else if (foundAnnotationIndex >= 0) { + return [ + ...acc, + { + annotationIndex: foundAnnotationIndex, + subCommands: [{ command: c, isHighlighted: false }], + isHighlighted: false, + }, + ] + } else { + return [...acc, { command: c, isHighlighted: false }] + } + }, []) +} diff --git a/protocol-designer/src/file-data/selectors/fileCreator.ts b/protocol-designer/src/file-data/selectors/fileCreator.ts index a4d62f7d8ba..89b059e8fc7 100644 --- a/protocol-designer/src/file-data/selectors/fileCreator.ts +++ b/protocol-designer/src/file-data/selectors/fileCreator.ts @@ -28,6 +28,7 @@ import { DEFAULT_MM_TOUCH_TIP_OFFSET_FROM_TOP, DEFAULT_MM_BLOWOUT_OFFSET_FROM_TOP, } from '../../constants' +import { getStepGroups } from '../../step-forms/selectors' import { getFileMetadata, getRobotType } from './fileFields' import { getInitialRobotState, getRobotStateTimeline } from './commands' @@ -57,6 +58,7 @@ import type { import type { LabwareDefByDefURI } from '../../labware-defs' import type { Selector } from '../../types' import type { DesignerApplicationData } from '../../load-file/migration/utils/getLoadLiquidCommands' +import type { SecondOrderCommandAnnotation } from '@opentrons/shared-data/commandAnnotation/types' // TODO: BC: 2018-02-21 uncomment this assert, causes test failures // console.assert(!isEmpty(process.env.OT_PD_VERSION), 'Could not find application version!') @@ -111,6 +113,7 @@ export const createFile: Selector = createSelector( stepFormSelectors.getPipetteEntities, uiLabwareSelectors.getLabwareNicknamesById, labwareDefSelectors.getLabwareDefsByURI, + getStepGroups, ( fileMetadata, initialRobotState, @@ -125,9 +128,11 @@ export const createFile: Selector = createSelector( moduleEntities, pipetteEntities, labwareNicknamesById, - labwareDefsByURI + labwareDefsByURI, + stepGroups ) => { const { author, description, created } = fileMetadata + const name = fileMetadata.protocolName || 'untitled' const lastModified = fileMetadata.lastModified // TODO: Ian 2018-07-10 allow user to save steps in JSON file, even if those @@ -381,9 +386,33 @@ export const createFile: Selector = createSelector( commands, } + const commandAnnotations: SecondOrderCommandAnnotation[] = Object.entries( + stepGroups + ).map(([name, groupStepIds]) => { + // map stepIds from group to orderedStepIds and return indices from orderedStepIds + const stepIndices = groupStepIds + .map(groupStepId => orderedStepIds.indexOf(groupStepId)) + .filter(index => index !== -1) + + // return commands assosciated with the indices + const commands = stepIndices.flatMap( + index => robotStateTimeline.timeline[index].commands + ) + const commandKeys = commands.map(command => command.key ?? '') + + const annotation: SecondOrderCommandAnnotation = { + annotationType: 'secondOrderCommand', + machineReadableName: name, + params: {}, // what is this used for? + commandKeys, + } + + return annotation + }) + const commandAnnotionaV1Mixin: CommandAnnotationV1Mixin = { commandAnnotationSchemaId: 'opentronsCommandAnnotationSchemaV1', - commandAnnotations: [], + commandAnnotations, } const protocolBase: ProtocolBase = { diff --git a/protocol-designer/src/step-forms/actions/groups.ts b/protocol-designer/src/step-forms/actions/groups.ts new file mode 100644 index 00000000000..f77a44cb086 --- /dev/null +++ b/protocol-designer/src/step-forms/actions/groups.ts @@ -0,0 +1,60 @@ +import { + ADD_STEPS_TO_GROUP, + CLEAR_UNSAVED_GROUP, + CREATE_GROUP, + REMOVE_GROUP, + SELECT_STEP_FOR_UNSAVED_GROUP, +} from '../reducers' + +export interface RemoveGroupAction { + type: typeof REMOVE_GROUP + payload: { groupName: string } +} + +export interface SaveGroupAction { + type: typeof CREATE_GROUP + payload: { groupName: string } +} +export interface AddStepToGroupAction { + type: typeof ADD_STEPS_TO_GROUP + payload: { groupName: string; stepIds: string[] } +} +export interface ClearGroupAction { + type: typeof CLEAR_UNSAVED_GROUP +} +export interface SelectedStepForGroupAction { + type: typeof SELECT_STEP_FOR_UNSAVED_GROUP + payload: { stepId: string } +} + +export const addStepToGroup = ( + args: AddStepToGroupAction['payload'] +): AddStepToGroupAction => ({ + type: ADD_STEPS_TO_GROUP, + payload: args, +}) + +export const createGroup = ( + args: SaveGroupAction['payload'] +): SaveGroupAction => ({ + type: CREATE_GROUP, + payload: args, +}) + +export const selectStepForUnsavedGroup = ( + args: SelectedStepForGroupAction['payload'] +): SelectedStepForGroupAction => ({ + type: SELECT_STEP_FOR_UNSAVED_GROUP, + payload: args, +}) + +export const clearUnsavedGroup = (): ClearGroupAction => ({ + type: CLEAR_UNSAVED_GROUP, +}) + +export const removeGroup = ( + args: RemoveGroupAction['payload'] +): RemoveGroupAction => ({ + type: REMOVE_GROUP, + payload: args, +}) diff --git a/protocol-designer/src/step-forms/reducers/index.ts b/protocol-designer/src/step-forms/reducers/index.ts index 8591449e8a6..4e35d9af6e3 100644 --- a/protocol-designer/src/step-forms/reducers/index.ts +++ b/protocol-designer/src/step-forms/reducers/index.ts @@ -1423,6 +1423,64 @@ export const additionalEquipmentInvariantProperties = handleActions +const initialStepGroupState = {} +const stepGroups: Reducer = handleActions< + StepGroupsState, + any +>( + { + CREATE_GROUP: (state, action) => { + return { + ...state, + [action.payload.groupName]: [], + } + }, + REMOVE_GROUP: (state, action) => { + const { + [action.payload.groupName]: removedGroup, + ...remainingGroups + } = state + return remainingGroups + }, + ADD_STEPS_TO_GROUP: (state, action) => { + return { + ...state, + [action.payload.groupName]: [ + ...state[action.payload.groupName], + ...action.payload.stepIds, + ], + } + }, + }, + initialStepGroupState +) +export type UnsavedGroupState = StepIdType[] +export const SELECT_STEP_FOR_UNSAVED_GROUP = 'SELECT_STEP_FOR_UNSAVED_GROUP' +export const CLEAR_UNSAVED_GROUP = 'CLEAR_UNSAVED_GROUP' +const initialUnsavedGroupState: StepIdType[] = [] +const unsavedGroup: Reducer = handleActions< + UnsavedGroupState, + any +>( + { + SELECT_STEP_FOR_UNSAVED_GROUP: (state, action) => { + const stepId: string = action.payload.stepId + if (state.includes(stepId)) { + return state.filter(id => id !== stepId) + } else { + return [...state, stepId] + } + }, + CLEAR_UNSAVED_GROUP: () => { + return [] + }, + }, + initialUnsavedGroupState +) export type OrderedStepIdsState = StepIdType[] const initialOrderedStepIdsState: string[] = [] @@ -1539,6 +1597,8 @@ export const presavedStepForm = ( } } export interface RootState { + unsavedGroup: UnsavedGroupState + stepGroups: StepGroupsState orderedStepIds: OrderedStepIdsState labwareDefs: LabwareDefsRootState labwareInvariantProperties: NormalizedLabwareById @@ -1555,6 +1615,8 @@ export interface RootState { // TODO: Ian 2018-12-13 remove this 'action: any' type export const rootReducer: Reducer = nestedCombineReducers( ({ action, state, prevStateFallback }) => ({ + unsavedGroup: unsavedGroup(prevStateFallback.unsavedGroup, action), + stepGroups: stepGroups(prevStateFallback.stepGroups, action), orderedStepIds: orderedStepIds(prevStateFallback.orderedStepIds, action), labwareInvariantProperties: labwareInvariantProperties( prevStateFallback.labwareInvariantProperties, diff --git a/protocol-designer/src/step-forms/selectors/index.ts b/protocol-designer/src/step-forms/selectors/index.ts index 75c47774fca..ebc1a19a96b 100644 --- a/protocol-designer/src/step-forms/selectors/index.ts +++ b/protocol-designer/src/step-forms/selectors/index.ts @@ -479,6 +479,15 @@ export const getModulesForEditModulesCard: Selector< } ) ) +export const getUnsavedGroup: Selector< + BaseState, + StepIdType[] +> = createSelector(rootSelector, state => state.unsavedGroup) +export const getStepGroups: Selector< + BaseState, + Record +> = createSelector(rootSelector, state => state.stepGroups) + export const getUnsavedForm: Selector< BaseState, FormData | null | undefined diff --git a/protocol-designer/src/ui/steps/actions/actions.ts b/protocol-designer/src/ui/steps/actions/actions.ts index d569bbef508..c85db48137d 100644 --- a/protocol-designer/src/ui/steps/actions/actions.ts +++ b/protocol-designer/src/ui/steps/actions/actions.ts @@ -25,6 +25,7 @@ import type { ClearWellSelectionLabwareKeyAction, SelectStepAction, SelectMultipleStepsAction, + SelectMultipleStepsForGroupAction, ToggleViewSubstepAction, ViewSubstep, } from './types' @@ -145,6 +146,22 @@ export const selectMultipleSteps = ( } dispatch(selectStepAction) } +export const selectMultipleStepsForGroup = ( + stepIds: StepIdType[], + lastSelected: StepIdType +): ThunkAction => ( + dispatch: ThunkDispatch, + getState: GetState +) => { + const selectStepAction: SelectMultipleStepsForGroupAction = { + type: 'SELECT_MULTIPLE_STEPS_FOR_GROUP', + payload: { + stepIds, + lastSelected, + }, + } + dispatch(selectStepAction) +} export const selectAllSteps = (): ThunkAction< SelectMultipleStepsAction | AnalyticsEventAction > => ( diff --git a/protocol-designer/src/ui/steps/actions/types.ts b/protocol-designer/src/ui/steps/actions/types.ts index 7c1b8b83e3c..ebbf1e4dff2 100644 --- a/protocol-designer/src/ui/steps/actions/types.ts +++ b/protocol-designer/src/ui/steps/actions/types.ts @@ -74,6 +74,13 @@ export interface SelectMultipleStepsAction { } } +export interface SelectMultipleStepsForGroupAction { + type: 'SELECT_MULTIPLE_STEPS_FOR_GROUP' + payload: { + stepIds: StepIdType[] + lastSelected: StepIdType + } +} export type ViewSubstep = StepIdType | null export interface ToggleViewSubstepAction { type: 'TOGGLE_VIEW_SUBSTEP' diff --git a/protocol-designer/typings/reselect.d.ts b/protocol-designer/typings/reselect.d.ts index 8a80c1fd544..de43b405f6a 100644 --- a/protocol-designer/typings/reselect.d.ts +++ b/protocol-designer/typings/reselect.d.ts @@ -1,6 +1,6 @@ import type { OutputSelector, Selector } from 'reselect' declare module 'reselect' { - // declaring type for createSelector with 14 selectors because the reselect types only support up to 12 selectors + // declaring type for createSelector with 15 selectors because the reselect types only support up to 12 selectors export function createSelector< S, R1, @@ -17,6 +17,7 @@ declare module 'reselect' { R12, R13, R14, + R15, T >( selector1: Selector, @@ -33,6 +34,7 @@ declare module 'reselect' { selector12: Selector, selector13: Selector, selector14: Selector, + selector15: Selector, combiner: ( res1: R1, res2: R2, @@ -47,7 +49,8 @@ declare module 'reselect' { res11: R11, res12: R12, res13: R13, - res14: R14 + res14: R14, + res15: R15 ) => T ): OutputSelector< S, @@ -66,7 +69,8 @@ declare module 'reselect' { res11: R11, res12: R12, res13: R13, - res14: R14 + res14: R14, + res15: R15 ) => T > } diff --git a/robot-server/robot_server/maintenance_runs/maintenance_run_orchestrator_store.py b/robot-server/robot_server/maintenance_runs/maintenance_run_orchestrator_store.py index 9bb1012a789..530cdc87563 100644 --- a/robot-server/robot_server/maintenance_runs/maintenance_run_orchestrator_store.py +++ b/robot-server/robot_server/maintenance_runs/maintenance_run_orchestrator_store.py @@ -216,7 +216,12 @@ async def clear(self) -> RunResult: self._run_orchestrator = None self._created_at = None - return RunResult(state_summary=run_data, commands=commands, parameters=[]) + return RunResult( + state_summary=run_data, + commands=commands, + parameters=[], + command_annotations=[], + ) def get_command_slice( self, diff --git a/robot-server/robot_server/protocols/analysis_models.py b/robot-server/robot_server/protocols/analysis_models.py index 61a66866bb0..f4b5c54fec8 100644 --- a/robot-server/robot_server/protocols/analysis_models.py +++ b/robot-server/robot_server/protocols/analysis_models.py @@ -6,6 +6,7 @@ RunTimeParameter, PrimitiveRunTimeParamValuesType, CSVRunTimeParamFilesType, + CommandAnnotation, ) from opentrons_shared_data.robot.types import RobotType from pydantic import BaseModel, Field @@ -198,6 +199,10 @@ class CompletedAnalysis(BaseModel): " but it won't have more than one element." ), ) + commandAnnotations: List[CommandAnnotation] = Field( + default_factory=list, + description="Optional annotations for commands in this run.", + ) AnalysisParameterType = Union[float, bool, str, None] diff --git a/robot-server/robot_server/protocols/analysis_store.py b/robot-server/robot_server/protocols/analysis_store.py index 2f46f7857cb..be69601466f 100644 --- a/robot-server/robot_server/protocols/analysis_store.py +++ b/robot-server/robot_server/protocols/analysis_store.py @@ -11,6 +11,7 @@ from opentrons.protocol_engine.types import ( RunTimeParameter, CSVParameter, + CommandAnnotation, ) from opentrons.protocol_engine import ( Command, @@ -154,6 +155,7 @@ async def update( errors: List[ErrorOccurrence], liquids: List[Liquid], liquidClasses: List[LiquidClassRecordWithId], + command_annotations: List[CommandAnnotation], ) -> None: """Promote a pending analysis to completed, adding details of its results. @@ -171,6 +173,7 @@ async def update( liquids: See `CompletedAnalysis.liquids`. liquidClasses: See `CompletedAnalysis.liquidClasses`. robot_type: See `CompletedAnalysis.robotType`. + command_annotations: See `CompletedAnalysis.command_annotations`. """ protocol_id = self._pending_store.get_protocol_id(analysis_id=analysis_id) @@ -205,6 +208,7 @@ async def update( errors=errors, liquids=liquids, liquidClasses=liquidClasses, + commandAnnotations=command_annotations, ) completed_analysis_resource = CompletedAnalysisResource( id=completed_analysis.id, diff --git a/robot-server/robot_server/protocols/protocol_analyzer.py b/robot-server/robot_server/protocols/protocol_analyzer.py index cf1d0687062..678af02f0bb 100644 --- a/robot-server/robot_server/protocols/protocol_analyzer.py +++ b/robot-server/robot_server/protocols/protocol_analyzer.py @@ -108,6 +108,7 @@ async def analyze( errors=result.state_summary.errors, liquids=result.state_summary.liquids, liquidClasses=result.state_summary.liquidClasses, + command_annotations=result.command_annotations, ) async def update_to_failed_analysis( @@ -138,6 +139,7 @@ async def update_to_failed_analysis( ], liquids=[], liquidClasses=[], + command_annotations=[], ) def __del__(self) -> None: diff --git a/robot-server/robot_server/runs/run_orchestrator_store.py b/robot-server/robot_server/runs/run_orchestrator_store.py index a8ad429db4a..adb7cac151e 100644 --- a/robot-server/robot_server/runs/run_orchestrator_store.py +++ b/robot-server/robot_server/runs/run_orchestrator_store.py @@ -289,6 +289,7 @@ async def clear(self) -> RunResult: run_data = self.run_orchestrator.get_state_summary() commands = self.run_orchestrator.get_all_commands() run_time_parameters = self.run_orchestrator.get_run_time_parameters() + command_annotations = self.run_orchestrator.get_command_annotations() self._run_orchestrator = None @@ -296,6 +297,7 @@ async def clear(self) -> RunResult: state_summary=run_data, commands=commands, parameters=run_time_parameters, + command_annotations=command_annotations, ) # todo(mm, 2024-11-15): Are all of these pass-through methods helpful? diff --git a/robot-server/tests/integration/http_api/protocols/test_v6_json_upload.tavern.yaml b/robot-server/tests/integration/http_api/protocols/test_v6_json_upload.tavern.yaml index 516221c500c..4d3f655a929 100644 --- a/robot-server/tests/integration/http_api/protocols/test_v6_json_upload.tavern.yaml +++ b/robot-server/tests/integration/http_api/protocols/test_v6_json_upload.tavern.yaml @@ -89,6 +89,7 @@ stages: result: ok robotType: OT-2 Standard runTimeParameters: [] + commandAnnotations: [] pipettes: - id: pipetteId pipetteName: p10_single diff --git a/robot-server/tests/integration/http_api/protocols/test_v8_json_upload_flex.tavern.yaml b/robot-server/tests/integration/http_api/protocols/test_v8_json_upload_flex.tavern.yaml index 022c86da35e..ff42ba79367 100644 --- a/robot-server/tests/integration/http_api/protocols/test_v8_json_upload_flex.tavern.yaml +++ b/robot-server/tests/integration/http_api/protocols/test_v8_json_upload_flex.tavern.yaml @@ -90,6 +90,17 @@ stages: result: ok robotType: OT-3 Standard runTimeParameters: [] + commandAnnotations: + - annotationType: custom + commandKeys: [ + 1abc123, + 2abc123, + 3abc123, + 4abc123, + 5abc123, + 6abc123, + 7abc123, + ] pipettes: - id: pipetteId pipetteName: p1000_96 diff --git a/robot-server/tests/integration/http_api/protocols/test_v8_json_upload_ot2.tavern.yaml b/robot-server/tests/integration/http_api/protocols/test_v8_json_upload_ot2.tavern.yaml index 961a9a26601..456dd76089d 100644 --- a/robot-server/tests/integration/http_api/protocols/test_v8_json_upload_ot2.tavern.yaml +++ b/robot-server/tests/integration/http_api/protocols/test_v8_json_upload_ot2.tavern.yaml @@ -88,6 +88,17 @@ stages: result: ok robotType: OT-2 Standard runTimeParameters: [] + commandAnnotations: + - annotationType: custom + commandKeys: [ + 1abc123, + 2abc123, + 3abc123, + 4abc123, + 5abc123, + 6abc123, + 7abc123, + ] pipettes: - id: pipetteId pipetteName: p10_single diff --git a/robot-server/tests/protocols/test_analysis_store.py b/robot-server/tests/protocols/test_analysis_store.py index d15e9925a18..56d710ec122 100644 --- a/robot-server/tests/protocols/test_analysis_store.py +++ b/robot-server/tests/protocols/test_analysis_store.py @@ -204,6 +204,7 @@ async def test_returned_in_order_added( errors=[], liquids=[], liquidClasses=[], + command_annotations=[], ) subject.add_pending( @@ -252,6 +253,7 @@ async def test_update_adds_details_and_completes_analysis( value=2.0, default=3.0, ) + command_annotation = pe_types.CustomCommandAnnotation(commandKeys=["abc", "xyz"]) subject.add_pending( protocol_id="protocol-id", analysis_id="analysis-id", run_time_parameters=[] ) @@ -268,6 +270,7 @@ async def test_update_adds_details_and_completes_analysis( errors=[], liquids=[], liquidClasses=[], + command_annotations=[command_annotation], ) result = await subject.get("analysis-id") @@ -286,6 +289,7 @@ async def test_update_adds_details_and_completes_analysis( errors=[], liquids=[], liquidClasses=[], + commandAnnotations=[command_annotation], ) assert await subject.get_by_protocol("protocol-id") == [result] assert json.loads(result_as_document) == { @@ -320,6 +324,9 @@ async def test_update_adds_details_and_completes_analysis( "liquids": [], "liquidClasses": [], "modules": [], + "commandAnnotations": [ + {"annotationType": "custom", "commandKeys": ["abc", "xyz"]} + ], } @@ -390,6 +397,7 @@ async def test_update_adds_rtp_values_to_completed_store( errors=[], liquids=[], liquidClasses=[], + command_annotations=[], ) decoy.verify( await mock_completed_store.make_room_and_add( @@ -494,6 +502,7 @@ async def test_update_infers_status_from_errors( pipettes=[], liquids=[], liquidClasses=[], + command_annotations=[], ) analysis = (await subject.get_by_protocol("protocol-id"))[0] assert isinstance(analysis, CompletedAnalysis) diff --git a/robot-server/tests/protocols/test_completed_analysis_store.py b/robot-server/tests/protocols/test_completed_analysis_store.py index a8112cdda16..f882d7667e4 100644 --- a/robot-server/tests/protocols/test_completed_analysis_store.py +++ b/robot-server/tests/protocols/test_completed_analysis_store.py @@ -212,6 +212,7 @@ async def test_get_by_analysis_id_as_document( "liquidClasses": [], "modules": [], "pipettes": [], + "commandAnnotations": [], } diff --git a/robot-server/tests/protocols/test_protocol_analyzer.py b/robot-server/tests/protocols/test_protocol_analyzer.py index 3fab95879fe..5f581afebb4 100644 --- a/robot-server/tests/protocols/test_protocol_analyzer.py +++ b/robot-server/tests/protocols/test_protocol_analyzer.py @@ -165,6 +165,8 @@ async def test_analyze( displayName="Foo", variableName="Bar", default=True, value=False ) + command_annotation = pe_types.CustomCommandAnnotation(commandKeys=["abc", "xyz"]) + orchestrator = decoy.mock(cls=protocol_runner.RunOrchestrator) decoy.when( await simulating_runner.create_simulating_orchestrator( @@ -195,6 +197,7 @@ async def test_analyze( hasEverEnteredErrorRecovery=False, ), parameters=[bool_parameter], + command_annotations=[command_annotation], ) ) @@ -213,6 +216,7 @@ async def test_analyze( errors=[], liquids=[], liquidClasses=[], + command_annotations=[command_annotation], ) ) @@ -297,5 +301,6 @@ async def test_analyze_updates_pending_on_error( errors=[error_occurrence], liquids=[], liquidClasses=[], + command_annotations=[], ), ) diff --git a/robot-server/tests/runs/test_run_controller.py b/robot-server/tests/runs/test_run_controller.py index 7dbdf827012..1aa17ba9932 100644 --- a/robot-server/tests/runs/test_run_controller.py +++ b/robot-server/tests/runs/test_run_controller.py @@ -11,7 +11,12 @@ commands as pe_commands, errors as pe_errors, ) -from opentrons.protocol_engine.types import RunTimeParameter, BooleanParameter +from opentrons.protocol_engine.types import ( + RunTimeParameter, + BooleanParameter, + CommandAnnotation, + SecondOrderCommandAnnotation, +) from opentrons.protocol_runner import RunResult from robot_server.service.notifications import RunsPublisher, MaintenanceRunsPublisher @@ -77,7 +82,7 @@ def engine_state_summary() -> StateSummary: ) -@pytest.fixture() +@pytest.fixture def run_time_parameters() -> List[RunTimeParameter]: """Get a RunTimeParameter list.""" return [ @@ -90,6 +95,18 @@ def run_time_parameters() -> List[RunTimeParameter]: ] +@pytest.fixture +def command_annotations() -> List[CommandAnnotation]: + """Get a CommandAnnotation list.""" + return [ + SecondOrderCommandAnnotation( + commandKeys=["abc"], + params={"abc": "123"}, + machineReadableName="hello world", + ) + ] + + @pytest.fixture def protocol_commands() -> List[pe_commands.Command]: """Get a StateSummary value object.""" @@ -157,6 +174,7 @@ async def test_create_play_action_to_start( mock_maintenance_runs_publisher: MaintenanceRunsPublisher, engine_state_summary: StateSummary, run_time_parameters: List[RunTimeParameter], + command_annotations: List[CommandAnnotation], protocol_commands: List[pe_commands.Command], run_id: str, subject: RunController, @@ -189,6 +207,7 @@ async def test_create_play_action_to_start( commands=protocol_commands, state_summary=engine_state_summary, parameters=run_time_parameters, + command_annotations=command_annotations, ) ) diff --git a/robot-server/tests/runs/test_run_data_manager.py b/robot-server/tests/runs/test_run_data_manager.py index a78a7585c52..a56c8dbc705 100644 --- a/robot-server/tests/runs/test_run_data_manager.py +++ b/robot-server/tests/runs/test_run_data_manager.py @@ -124,7 +124,7 @@ def patch_error_recovery_mapping(decoy: Decoy, monkeypatch: pytest.MonkeyPatch) ) -@pytest.fixture() +@pytest.fixture def run_time_parameters() -> List[pe_types.RunTimeParameter]: """Get a RunTimeParameter list.""" return [ @@ -137,6 +137,18 @@ def run_time_parameters() -> List[pe_types.RunTimeParameter]: ] +@pytest.fixture +def command_annotations() -> List[pe_types.CommandAnnotation]: + """Get a CommandAnnotation list.""" + return [ + pe_types.SecondOrderCommandAnnotation( + commandKeys=["abc"], + params={"abc": "123"}, + machineReadableName="hello world", + ) + ] + + @pytest.fixture def mock_nozzle_maps(decoy: Decoy) -> Dict[str, NozzleMap]: """Get a mock NozzleMap.""" @@ -654,6 +666,7 @@ async def test_update_current( decoy: Decoy, engine_state_summary: StateSummary, run_time_parameters: List[pe_types.RunTimeParameter], + command_annotations: List[pe_types.CommandAnnotation], run_resource: RunResource, run_command: commands.Command, mock_run_orchestrator_store: RunOrchestratorStore, @@ -669,6 +682,7 @@ async def test_update_current( commands=[run_command], state_summary=engine_state_summary, parameters=run_time_parameters, + command_annotations=command_annotations, ) ) @@ -794,6 +808,7 @@ async def test_create_archives_existing( decoy: Decoy, engine_state_summary: StateSummary, run_time_parameters: List[pe_types.RunTimeParameter], + command_annotations: List[pe_types.CommandAnnotation], run_resource: RunResource, run_command: commands.Command, mock_run_orchestrator_store: RunOrchestratorStore, @@ -812,6 +827,7 @@ async def test_create_archives_existing( commands=[run_command], state_summary=engine_state_summary, parameters=run_time_parameters, + command_annotations=command_annotations, ) ) diff --git a/shared-data/js/types.ts b/shared-data/js/types.ts index 720f422cb87..71c932a35d4 100644 --- a/shared-data/js/types.ts +++ b/shared-data/js/types.ts @@ -31,6 +31,7 @@ import type { import type { RunTimeCommand, LabwareLocation } from '../command/types' import type { AddressableAreaName, CutoutFixtureId, CutoutId } from '../deck' import type { PipetteName } from './pipettes' +import type { CommandAnnotation } from '../commandAnnotation/types' export type RobotType = 'OT-2 Standard' | 'OT-3 Standard' @@ -802,6 +803,7 @@ export interface CompletedProtocolAnalysis { errors: AnalysisError[] robotType?: RobotType | null runTimeParameters?: RunTimeParameter[] + commandAnnotations?: CommandAnnotation[] } export interface ResourceFile { diff --git a/shared-data/protocol/types/schemaV8/index.ts b/shared-data/protocol/types/schemaV8/index.ts index 7755837b14f..bc891d88d99 100644 --- a/shared-data/protocol/types/schemaV8/index.ts +++ b/shared-data/protocol/types/schemaV8/index.ts @@ -144,6 +144,7 @@ export interface ProtocolAnalysisOutput { errors: AnalysisError[] runTimeParameters: RunTimeParameter[] robotType?: RobotType + commandAnnotations?: CommandAnnotation[] result: 'ok' | 'not-ok' | 'error' | 'parameter-value-required' } From 96fc13e49149ea8130dcab0b72171bbdfb62fd96 Mon Sep 17 00:00:00 2001 From: koji Date: Wed, 11 Dec 2024 13:01:57 -0500 Subject: [PATCH 14/23] fix(protocol-designer,app): use dynamic import for react-scan to avoid build issue (#17087) * fix(protocol-designer,app): use dynamic import for react-scan to avoid build issue --- app/src/App/DesktopApp.tsx | 18 ++++++++++++------ protocol-designer/src/ProtocolEditor.tsx | 18 ++++++++++++------ 2 files changed, 24 insertions(+), 12 deletions(-) diff --git a/app/src/App/DesktopApp.tsx b/app/src/App/DesktopApp.tsx index 7004acf9723..029ec99ee26 100644 --- a/app/src/App/DesktopApp.tsx +++ b/app/src/App/DesktopApp.tsx @@ -1,4 +1,3 @@ -import { scan } from 'react-scan' import { useState, Fragment } from 'react' import { Navigate, Route, Routes, useMatch } from 'react-router-dom' import { ErrorBoundary } from 'react-error-boundary' @@ -52,11 +51,18 @@ export const DesktopApp = (): JSX.Element => { // note for react-scan const enableReactScan = useFeatureFlag('reactScan') - if (typeof window !== 'undefined') { - scan({ - enabled: enableReactScan, - log: true, - }) + // Dynamically import `react-scan` to avoid build errors + if (typeof window !== 'undefined' && enableReactScan) { + import('react-scan') + .then(({ scan }) => { + scan({ + enabled: enableReactScan, + log: true, + }) + }) + .catch(error => { + console.error('Failed to load react-scan:', error) + }) } const desktopRoutes: RouteProps[] = [ diff --git a/protocol-designer/src/ProtocolEditor.tsx b/protocol-designer/src/ProtocolEditor.tsx index d322bd9fb09..ec0a130abd5 100644 --- a/protocol-designer/src/ProtocolEditor.tsx +++ b/protocol-designer/src/ProtocolEditor.tsx @@ -1,4 +1,3 @@ -import { scan } from 'react-scan' import { DndProvider } from 'react-dnd' import { HashRouter } from 'react-router-dom' import { HTML5Backend } from 'react-dnd-html5-backend' @@ -16,11 +15,18 @@ import { getEnableReactScan } from './feature-flags/selectors' export function ProtocolEditor(): JSX.Element { // note for react-scan const enableReactScan = useSelector(getEnableReactScan) - if (typeof window !== 'undefined') { - scan({ - enabled: enableReactScan, - log: true, - }) + // Dynamically import `react-scan` to avoid build errors + if (typeof window !== 'undefined' && enableReactScan) { + import('react-scan') + .then(({ scan }) => { + scan({ + enabled: enableReactScan, + log: true, + }) + }) + .catch(error => { + console.error('Failed to load react-scan:', error) + }) } return ( From 89941eaa81390d9713f7f9b055c652d89a5e11f1 Mon Sep 17 00:00:00 2001 From: David Chau <46395074+ddcc4@users.noreply.github.com> Date: Wed, 11 Dec 2024 13:50:18 -0500 Subject: [PATCH 15/23] feat(protocol-designer): indent generated JSON file to make it readable (#17086) # Overview I have to stare at JSON protocols a lot. Indenting them makes them easier to read, and saves me the trouble of using a separate tool just to reformat the JSON. `JSON.stringify()` has a built-in option for indentation; we just have to call it. ## Test Plan and Hands on Testing I edited a protocol in PD and examined the generated JSON file by hand. I confirmed that the indented JSON files can be successfully re-imported. All the CI tests pass. ## Risk assessment Low risk. The indented JSON files should be entirely semantically equivalent to the unindented ones. --- protocol-designer/src/load-file/utils.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/protocol-designer/src/load-file/utils.ts b/protocol-designer/src/load-file/utils.ts index 47c4ddd2331..0d90087a4dd 100644 --- a/protocol-designer/src/load-file/utils.ts +++ b/protocol-designer/src/load-file/utils.ts @@ -1,7 +1,7 @@ import { saveAs } from 'file-saver' import type { ProtocolFile } from '@opentrons/shared-data' export const saveFile = (fileData: ProtocolFile, fileName: string): void => { - const blob = new Blob([JSON.stringify(fileData)], { + const blob = new Blob([JSON.stringify(fileData, null, 2)], { type: 'application/json', }) saveAs(blob, fileName) From c932ab35e131585b62cfd1dc49fd814ab6a47eb8 Mon Sep 17 00:00:00 2001 From: Andy Sigler Date: Wed, 11 Dec 2024 15:47:39 -0500 Subject: [PATCH 16/23] chore(hardware-testing): Adds protocols for testing inner-well geometry meniscus positions w/ Ethanol (#17073) # Overview ## Test Plan and Hands on Testing ## Changelog ## Review requests ## Risk assessment --------- Co-authored-by: rclarke0 Co-authored-by: caila-marashaj Co-authored-by: Rhyann Clarke <146747548+rclarke0@users.noreply.github.com> --- .../hardware_testing/protocols/__init__.py | 130 +++++ .../liquid_sense/lld_test_liquid_height.py | 404 +++++++++++++ .../lld_test_liquid_height_3mm.py | 540 ++++++++++++++++++ 3 files changed, 1074 insertions(+) create mode 100644 hardware-testing/hardware_testing/protocols/liquid_sense/lld_test_liquid_height.py create mode 100644 hardware-testing/hardware_testing/protocols/liquid_sense/lld_test_liquid_height_3mm.py diff --git a/hardware-testing/hardware_testing/protocols/__init__.py b/hardware-testing/hardware_testing/protocols/__init__.py index 0e3933fe74f..011cdaf9509 100644 --- a/hardware-testing/hardware_testing/protocols/__init__.py +++ b/hardware-testing/hardware_testing/protocols/__init__.py @@ -1 +1,131 @@ """Protocols.""" +from opentrons.protocol_api import ParameterContext + +from opentrons.protocols.labware import get_all_labware_definitions +from typing import List +from opentrons.protocols.parameters.types import ParameterChoice + + +def create_trials_parameter(parameters: ParameterContext) -> None: + """Create parameter for number of trials.""" + # NOTE: Place function inside def add_parameters(parameters) in protocol. + # NOTE: Copy ctx.params.num_of_trials, ctx.params.right_mount # type: ignore[attr-defined] + parameters.add_int( + variable_name="num_of_trials", + display_name="Number of Trials", + minimum=1, + maximum=100, + default=3, + ) + + +def create_pipette_parameters(parameters: ParameterContext) -> None: + """Create parameter for pipettes.""" + # NOTE: Place function inside def add_parameters(parameters) in protocol. + # NOTE: Copy ctx.params.left mount, ctx.params.right_mount # type: ignore[attr-defined] + # to get result + # Left Mount + parameters.add_str( + variable_name="left_mount", + display_name="Left Mount", + description="Pipette Type on Left Mount.", + choices=[ + {"display_name": "8ch 50ul", "value": "flex_8channel_50"}, + {"display_name": "8ch 1000ul", "value": "flex_8channel_1000"}, + {"display_name": "1ch 50ul", "value": "flex_1channel_50"}, + {"display_name": "1ch 1000ul", "value": "flex_1channel_1000"}, + {"display_name": "96ch 1000ul", "value": "flex_96channel_1000"}, + {"display_name": "None", "value": "none"}, + ], + default="flex_1channel_50", + ) + # Right Mount + parameters.add_str( + variable_name="right_mount", + display_name="Right Mount", + description="Pipette Type on Right Mount.", + choices=[ + {"display_name": "8ch 50ul", "value": "flex_8channel_50"}, + {"display_name": "8ch 1000ul", "value": "flex_8channel_1000"}, + {"display_name": "1ch 50ul", "value": "flex_1channel_50"}, + {"display_name": "1ch 1000ul", "value": "flex_1channel_1000"}, + {"display_name": "None", "value": "none"}, + ], + default="flex_1channel_1000", + ) + + +def create_labware_parameters(parameters: ParameterContext) -> None: + """Create parameters for Labware Type.""" + # NOTE: Place function inside def add_parameters(parameters) in protocol. + # NOTE: Copy ctx.params.labware_type # type: ignore[attr-defined] to get result + + labware_list = get_all_labware_definitions() + available_labware_choices: List[ParameterChoice] = [] + # Filter out labwaer containing the following strings + # TODO: change get_all_labware_definitions function to one + # that can filter labware by type and not by string + labware_filter_words = [ + "trash", + "adapter", + "tiprack", + "etips", + "lid", + "calibrationblock", + ] + filtered_labware = [ + labware + for labware in labware_list + if not any(filter_word in labware for filter_word in labware_filter_words) + ] + + # Add labware to choices list + filtered_labware.sort() + for labware in filtered_labware: + shorten_opentrons_str = labware.replace("opentrons", "opt") + available_labware_choices.append( + { + "display_name": shorten_opentrons_str.replace("_", "").title()[:30], + "value": labware, + } + ) + + # Create Parameter + parameters.add_str( + variable_name="labware_type", + display_name="Labware", + description="Labware to probe.", + choices=available_labware_choices, + default="opentrons_10_tuberack_nest_4x50ml_6x15ml_conical", + ) + + +def create_liquid_parameter(parameters: ParameterContext) -> None: + """Create parameter to specify liquid type.""" + # NOTE: Place function inside def add_parameters(parameters) in protocol. + # NOTE: Copy ctx.params.liquid_type # type: ignore[attr-defined] to get result + + parameters.add_str( + variable_name="liquid_type", + display_name="Liquid Type", + description="Liquid being tested.", + choices=[ + {"display_name": "Water", "value": "water"}, + {"display_name": "Ethanol", "value": "ethanol"}, + ], + default="water", + ) + + +def create_tube_volume_parameter(parameters: ParameterContext) -> None: + """Select if reagent tube should be 15 ml or 50 ml.""" + # NOTE: Place function inside def add_parameters(parameters) in protocol. + # NOTE: Copy ctx.params.tube_volume # type: ignore[attr-defined] to get result + parameters.add_int( + variable_name="tube_volume", + display_name="Tube Volume", + default=15, + minimum=15, + maximum=50, + unit="mL", + ) diff --git a/hardware-testing/hardware_testing/protocols/liquid_sense/lld_test_liquid_height.py b/hardware-testing/hardware_testing/protocols/liquid_sense/lld_test_liquid_height.py new file mode 100644 index 00000000000..ada7ce4e50b --- /dev/null +++ b/hardware-testing/hardware_testing/protocols/liquid_sense/lld_test_liquid_height.py @@ -0,0 +1,404 @@ +"""Measure Liquid Height.""" +from typing import List, Tuple, Optional +from opentrons.protocol_api import ( + ProtocolContext, + Labware, + Well, + InstrumentContext, + ParameterContext, +) +from opentrons.types import Point + + +########################################### +# VARIABLES - START +########################################### +# TODO: use runtime-variables instead of constants + +NUM_TRIALS = 12 + +ASPIRATE_MM_FROM_BOTTOM = 5 +RESERVOIR = "nest_1_reservoir_195ml" + +LIQUID_MOUNT = "right" +LIQUID_TIP_SIZE = 1000 +LIQUID_PIPETTE_SIZE = 1000 + +PROBING_MOUNT = "left" +PROBING_TIP_SIZE = 50 +PROBING_PIPETTE_SIZE = 50 + +SLOT_LIQUID_TIPRACK = "C3" +SLOT_PROBING_TIPRACK = "D3" +SLOT_LABWARE = "D1" +SLOT_RESERVOIR = "C1" +SLOT_DIAL = "B3" + + +def add_parameters(parameters: ParameterContext) -> None: + """Add parameters.""" + from hardware_testing import protocols + + protocols.create_liquid_parameter(parameters) + parameters.add_str( + variable_name="probe_yes_or_no", + display_name="Probe (Y/N)", + description="Find Liquid height?", + choices=[ + {"display_name": "Yes", "value": "yes"}, + {"display_name": "No", "value": "no"}, + ], + default="yes", + ) + protocols.create_labware_parameters(parameters) + + +########################################### +# VARIABLES - END +########################################### + +metadata = {"protocolName": "lld-test-liquid-height"} +requirements = {"robotType": "Flex", "apiLevel": "2.20"} + +_all_96_well_names = [f"{r}{c + 1}" for c in range(12) for r in "ABCDEFGH"] +_first_row_well_names = [f"A{c + 1}" for c in range(12)] +_tube_names = ["A3", "A4", "B3", "B4"] * 8 +TEST_WELLS = { + 1: { # channel count + "corning_96_wellplate_360ul_flat": _all_96_well_names, + "armadillo_96_wellplate_200ul_pcr_full_skirt": _all_96_well_names, + "nest_96_wellplate_2ml_deep": _all_96_well_names, + "corning_96_wellplate_360ul_flat": _all_96_well_names, + "opentrons_10_tuberack_nest_4x50ml_6x15ml_conical": _tube_names, + }, + 8: {"nest_12_reservoir_15ml": _first_row_well_names}, +} + +DIAL_POS_WITHOUT_TIP: List[Optional[float]] = [None, None] +DIAL_PORT_NAME = "/dev/ttyUSB0" +DIAL_PORT = None +RUN_ID = "" +FILE_NAME = "" +CSV_HEADER = ["trial", "volume", "height", "tip-z-error", "corrected-height"] +CSV_SEPARATOR = "," +LABWARE_TYPE = "" +LIQUID_TYPE = "" +VOLUMES = [] + + +def _setup( + ctx: ProtocolContext, +) -> Tuple[ + InstrumentContext, + Labware, + InstrumentContext, + Labware, + Labware, + Labware, + Labware, +]: + global DIAL_PORT, RUN_ID, FILE_NAME, LABWARE_TYPE, VOLUMES, LIQUID_TYPE, NUM_TRIALS + # TODO: use runtime-variables instead of constants + ctx.load_trash_bin("A3") + LABWARE_TYPE = ctx.params.labware_type # type: ignore[attr-defined] + LIQUID_TYPE = ctx.params.liquid_type # type: ignore[attr-defined] + liquid_rack_name = f"opentrons_flex_96_tiprack_{LIQUID_TIP_SIZE}uL" + liquid_rack = ctx.load_labware(liquid_rack_name, SLOT_LIQUID_TIPRACK) + probing_rack_name = f"opentrons_flex_96_tiprack_{PROBING_TIP_SIZE}uL" + probing_rack = ctx.load_labware(probing_rack_name, SLOT_PROBING_TIPRACK) + if LABWARE_TYPE == "nest_12_reservoir_15ml": + liquid_pip_name = f"flex_8channel_{LIQUID_PIPETTE_SIZE}" + else: + liquid_pip_name = f"flex_1channel_{LIQUID_PIPETTE_SIZE}" + liquid_pipette = ctx.load_instrument(liquid_pip_name, LIQUID_MOUNT) + probing_pip_name = f"flex_1channel_{PROBING_PIPETTE_SIZE}" + probing_pipette = ctx.load_instrument(probing_pip_name, PROBING_MOUNT) + + reservoir = ctx.load_labware(RESERVOIR, SLOT_RESERVOIR) + labware = ctx.load_labware(LABWARE_TYPE, SLOT_LABWARE) + dial = ctx.load_labware("dial_indicator", SLOT_DIAL) + + # DETERMINE VOLUME LIST + if ( + LABWARE_TYPE == "armadillo_96_wellplate_200ul_pcr_full_skirt" + or LABWARE_TYPE == "corning_96_wellplate_360ul_flat" + ): + VOLUMES = [7, 10, 15, 25, 40, 60, 100, 200] + elif LABWARE_TYPE == "nest_96_wellplate_2ml_deep": + VOLUMES = [40, 50, 175, 200, 225, 275, 400, 1000] + elif LABWARE_TYPE == "opentrons_10_tuberack_nest_4x50ml_6x15ml_conical": + VOLUMES = [250, 250, 500, 1000, 1000, 1000, 1000, 1000] + NUM_TRIALS = 4 + # Actual Volumes = 250, 500, 1000, 2000, 3000, 4000, 5000, 6000 + elif LABWARE_TYPE == "nest_12_reservoir_15ml": + VOLUMES = [200, 300, 400, 500, 600, 700, 800, 1000] + + if not ctx.is_simulating() and DIAL_PORT is None: + from hardware_testing.data import create_file_name, create_run_id + from hardware_testing.drivers.mitutoyo_digimatic_indicator import ( + Mitutoyo_Digimatic_Indicator, + ) + + DIAL_PORT = Mitutoyo_Digimatic_Indicator(port=DIAL_PORT_NAME) + DIAL_PORT.connect() + RUN_ID = create_run_id() + FILE_NAME = create_file_name( + metadata["protocolName"], RUN_ID, f"{liquid_pip_name}-{liquid_rack_name}" + ) + _write_line_to_csv(ctx, [RUN_ID]) + _write_line_to_csv(ctx, [liquid_pip_name]) + _write_line_to_csv(ctx, [liquid_rack_name]) + _write_line_to_csv(ctx, [LABWARE_TYPE]) + + return ( + liquid_pipette, + liquid_rack, + probing_pipette, + probing_rack, + labware, + reservoir, + dial, + ) + + +def _write_line_to_csv(ctx: ProtocolContext, line: List[str]) -> None: + if ctx.is_simulating(): + return + from hardware_testing.data import append_data_to_file + + line_str = f"{CSV_SEPARATOR.join(line)}\n" + append_data_to_file(metadata["protocolName"], RUN_ID, FILE_NAME, line_str) + + +def _get_test_wells(labware: Labware, channels: int) -> List[Well]: + return [labware[w] for w in TEST_WELLS[channels][labware.load_name]] + + +def _get_test_tips(rack: Labware, channels: int) -> List[Well]: + if channels == 96: + test_tips = [rack["A1"]] + elif channels == 8: + test_tips = rack.rows()[0] + else: + test_tips = rack.wells() + return test_tips + + +def _read_dial_indicator( + ctx: ProtocolContext, + pipette: InstrumentContext, + dial: Labware, + front_channel: bool = False, +) -> float: + target = dial["A1"].top() + if front_channel: + target = target.move(Point(y=9 * 7)) + if pipette.channels == 96: + target = target.move(Point(x=9 * -11)) + pipette.move_to(target.move(Point(z=10))) + pipette.move_to(target) + ctx.delay(seconds=2) + if ctx.is_simulating(): + return 0.0 + dial_port = DIAL_PORT.read() # type: ignore[union-attr] + pipette.move_to(target.move(Point(z=10))) + return dial_port + + +def _store_dial_baseline( + ctx: ProtocolContext, + pipette: InstrumentContext, + dial: Labware, + front_channel: bool = False, +) -> None: + global DIAL_POS_WITHOUT_TIP + idx = 0 if not front_channel else 1 + if DIAL_POS_WITHOUT_TIP[idx] is not None: + return + DIAL_POS_WITHOUT_TIP[idx] = _read_dial_indicator(ctx, pipette, dial, front_channel) + tag = f"DIAL-BASELINE-{idx}" + _write_line_to_csv(ctx, [tag, str(DIAL_POS_WITHOUT_TIP[idx])]) + + +def _get_tip_z_error( + ctx: ProtocolContext, + pipette: InstrumentContext, + dial: Labware, + front_channel: bool = False, +) -> float: + idx = 0 if not front_channel else 1 + dial_baseline_for_this_channel = DIAL_POS_WITHOUT_TIP[idx] + assert dial_baseline_for_this_channel is not None + new_val = _read_dial_indicator(ctx, pipette, dial, front_channel) + z_error = new_val - dial_baseline_for_this_channel + # NOTE: dial-indicators are upside-down, so we need to flip the values + return z_error * -1.0 + + +def _get_height_of_liquid_in_well( + pipette: InstrumentContext, + well: Well, +) -> float: + if pipette.detect_liquid_presence(well): + height = pipette.measure_liquid_height(well) - well.bottom().point.z + else: + height = 0.0 + return height + + +def _test_for_finding_liquid_height( + ctx: ProtocolContext, + volume: float, + liquid_pipette: InstrumentContext, + probing_pipette: InstrumentContext, + dial: Labware, + liquid_tips: List[Well], + probing_tips: List[Well], + src_well: Well, + wells: List[Well], + dispense_from_bottom: float, + probe_yes_or_no: str, +) -> None: + assert len(liquid_tips) == len( + probing_tips + ), f"{len(liquid_tips)},{len(probing_tips)}" + assert len(liquid_tips) == len(wells), f"{len(liquid_tips)},{len(wells)}" + trial_counter = 0 + if probe_yes_or_no == "yes": + _store_dial_baseline(ctx, probing_pipette, dial) + _write_line_to_csv(ctx, CSV_HEADER) + all_corrected_heights = [] + corrected_height_list = [] + volume_to_record = volume + if LABWARE_TYPE == "opentrons_10_tuberack_nest_4x50ml_6x15ml_conical": + prev_vol = 0.0 + for liq_tip, probe_tip, well in zip(liquid_tips, probing_tips, wells): + trial_counter += 1 + if trial_counter == 1: + corrected_height_list.append(str(RUN_ID)) + if ( + LABWARE_TYPE == "opentrons_10_tuberack_nest_4x50ml_6x15ml_conical" + and prev_vol == 0.0 + ): + prev_vol = volume + elif ( + LABWARE_TYPE == "opentrons_10_tuberack_nest_4x50ml_6x15ml_conical" + and prev_vol > 0.0 + ): + volume_to_record += prev_vol + corrected_height_list.append(str(volume_to_record)) + # pickup probing tip, then measure Z-error + if probe_yes_or_no == "yes": + probing_pipette.pick_up_tip(probe_tip) + tip_z_error = _get_tip_z_error(ctx, probing_pipette, dial) + else: + tip_z_error = 0 + # pickup liquid tip, then immediately transfer liquid + liquid_pipette.pick_up_tip(liq_tip) + if volume < 1000: + liquid_pipette.aspirate(volume, src_well.bottom(ASPIRATE_MM_FROM_BOTTOM)) + liquid_pipette.dispense(volume, well.bottom(dispense_from_bottom)) + else: + volume_divide_by_2 = volume / 2 + liquid_pipette.aspirate( + volume_divide_by_2, src_well.bottom(ASPIRATE_MM_FROM_BOTTOM) + ) + liquid_pipette.dispense( + volume_divide_by_2, well.bottom(dispense_from_bottom) + ) + liquid_pipette.aspirate( + volume_divide_by_2, src_well.bottom(ASPIRATE_MM_FROM_BOTTOM) + ) + liquid_pipette.dispense( + volume_divide_by_2, well.bottom(dispense_from_bottom) + ) + + liquid_pipette.blow_out(well.top(z=-9)).prepare_to_aspirate() + # get height of liquid + if probe_yes_or_no == "yes": + height = _get_height_of_liquid_in_well(probing_pipette, well) + else: + height = 0 + corrected_height = height + tip_z_error + all_corrected_heights.append(corrected_height) + # drop all tips + liquid_pipette.return_tip() + if probe_yes_or_no == "yes": + probing_pipette.return_tip() + # save data + trial_data = [ + trial_counter, + volume_to_record, + height, + tip_z_error, + corrected_height, + ] + corrected_height_list.append(corrected_height) # type: ignore[arg-type] + _write_line_to_csv(ctx, [str(d) for d in trial_data]) + + avg = sum(all_corrected_heights) / len(all_corrected_heights) + error_mm = (max(all_corrected_heights) - min(all_corrected_heights)) * 0.5 + corrected_height_list.append(avg) # type: ignore[arg-type] + corrected_height_list.append(error_mm) # type: ignore[arg-type] + error_percent = error_mm / avg if avg else 0.0 + corrected_height_list.append(str(error_percent * 100)) + _write_line_to_csv(ctx, ["average", str(round(avg, 3))]) + _write_line_to_csv(ctx, ["error (mm)", str(round(error_mm, 3))]) + _write_line_to_csv(ctx, ["error (%)", str(round(error_percent * 100, 1))]) + _write_line_to_csv(ctx, ["Liquid Type", LIQUID_TYPE]) + + +def run(ctx: ProtocolContext) -> None: + """Run.""" + ( + liq_pipette, + liq_rack, + probe_pipette, + probe_rack, + labware, + reservoir, + dial, + ) = _setup(ctx) + # Parameters + liq_pipette.flow_rate.blow_out = 800 + probe_yes_or_no = ctx.params.probe_yes_or_no # type: ignore[attr-defined] + dispense_from_bottom = 2 + test_wells = _get_test_wells(labware, channels=8) + test_tips_liquid = _get_test_tips(liq_rack, channels=8) + test_tips_probe = _get_test_tips(probe_rack, channels=8) + stuff_lengths = len(test_tips_liquid), len(test_tips_probe), len(test_wells) + assert min(stuff_lengths) >= NUM_TRIALS * len(VOLUMES), f"{stuff_lengths}" + + for _vol in VOLUMES: + if LABWARE_TYPE == "nest_12_reservoir_15ml": + _test_for_finding_liquid_height( + ctx, + _vol, + liq_pipette, + probe_pipette, + dial, + liquid_tips=test_tips_liquid[:NUM_TRIALS], + probing_tips=test_tips_probe[:NUM_TRIALS], + src_well=reservoir["A1"], + wells=test_wells[:NUM_TRIALS], + dispense_from_bottom=dispense_from_bottom, + probe_yes_or_no=probe_yes_or_no, + ) + ctx.pause("Reset labware and tipracks.") + else: + _test_for_finding_liquid_height( + ctx, + _vol, + liq_pipette, + probe_pipette, + dial, + liquid_tips=test_tips_liquid[:NUM_TRIALS], + probing_tips=test_tips_probe[:NUM_TRIALS], + src_well=reservoir["A1"], + wells=test_wells[:NUM_TRIALS], + dispense_from_bottom=dispense_from_bottom, + probe_yes_or_no=probe_yes_or_no, + ) + test_wells = test_wells[NUM_TRIALS:] + test_tips_liquid = test_tips_liquid[NUM_TRIALS:] + test_tips_probe = test_tips_probe[NUM_TRIALS:] diff --git a/hardware-testing/hardware_testing/protocols/liquid_sense/lld_test_liquid_height_3mm.py b/hardware-testing/hardware_testing/protocols/liquid_sense/lld_test_liquid_height_3mm.py new file mode 100644 index 00000000000..d4f8ab7ecb4 --- /dev/null +++ b/hardware-testing/hardware_testing/protocols/liquid_sense/lld_test_liquid_height_3mm.py @@ -0,0 +1,540 @@ +"""Measure Liquid Height 3mm.""" +import math +from typing import List, Tuple, Optional +from opentrons.protocol_api import ( + ProtocolContext, + Labware, + Well, + InstrumentContext, + ParameterContext, +) +from opentrons.types import Point + + +########################################### +# VARIABLES - START +########################################### +# TODO: use runtime-variables instead of constants + +# NOTE: The volumes below were calculated using Solidworks +# models, they are the nominal volume inside the well +# at both 3mm from bottom and 3mm from top. +# FIXME: replace this with actual Opentrons API software +# volume estimations. No need for us to include Solidworks +# in this testing loop. + +# Default tube volumes are for 50 ml +VOLUMES_3MM_TOP_BOTTOM = { + "corning_96_wellplate_360ul_flat": [257.1, 97.2, 0.0], + "nest_96_wellplate_200ul_flat": [259.8, 96.3, 0.0], + "opentrons_96_wellplate_200ul_pcr_full_skirt": [150.2, 14.3, 0.0], + "nest_96_wellplate_2ml_deep": [2060.4, 118.3, 0.0], + "nest_12_reservoir_15ml": [13236.1, 1219.0, 0.0], + "nest_96_wellplate_100ul_pcr_full_skirt": [150.8, 15.5, 0.0], + "appliedbiosystemsmicroamp_384_wellplate_40ul": [26.2, 7.44, 0.0], + "thermoscientificnunc_96_wellplate_1300ul": [1155.1, 73.5, 0.0], + "thermoscientificnunc_96_wellplate_2000ul": [1768.0, 73.5, 0.0], + "biorad_96_wellplate_200ul_pcr": [161.2, 71.32, 17.9, 0.0], + "nest_1_reservoir_290ml": [16570.4, 271690.5, 0.0], + "corning_12_wellplate_6.9ml_flat": [5654.8, 1156.3, 0.0], + "corning_24_wellplate_3.4ml_flat": [2853.4, 1701.37, 579.0, 0.0], + "corning_6_wellplate_16.8ml_flat": [13901.9, 2862.1, 0.0], + "corning_48_wellplate_1.6ml_flat": [1327.0, 790.63, 268.9, 0.0], + "opentrons_24_tuberack_nest_0.5ml_screwcap": [795.4, 21.95, 0.0], + "opentrons_24_tuberack_nest_1.5ml_screwcap": [19.5, 735.89, 1750.8, 0.0], + "opentrons_24_tuberack_nest_1.5ml_snapcap": [28.7, 1739.7, 658.2, 0.0], + "opentrons_24_tuberack_nest_2ml_screwcap": [2104.9, 66.6, 0.0], + "opentrons_24_tuberack_nest_2ml_snapcap": [2148.5, 69.6, 0.0], + "opentrons_10_tuberack_nest_4x50ml_6x15ml_conical": [115.0, 26117.4, 56110.3, 0.0], + "opentrons_10_tuberack_falcon_4x50ml_6x15ml_conical": [169.5, 57720.5, 0.0], + "nest_1_reservoir_195ml": [14513.1, 178181.9, 0.0], + "axygen_1_reservoir_90ml": [23136.9, 72854.8, 0.0], + "agilent_1_reservoir_290ml": [15652.9, 141945.59, 268813.8], + "opentrons_24_tuberack_eppendorf_1.5ml_safelock_snapcap": [26.6, 593.7, 1629.9], + "corning_384_wellplate_112ul_flat": [23.2, 50.1, 80.0], + "biorad_384_wellplate_50ul": [28.7, 8.0, 0.0], + "usascientific_12_reservoir_22ml": [68.4, 11356.9, 19797.4], + "usascientific_96_wellplate_2.4ml_deep": [74.7, 1151.9, 2317.8], + "opentrons_24_tuberack_eppendorf_2ml_safelock_snapcap": [63.0, 2237.8, 0.0], +} + +SAME_TIP = True # this is fine when using Ethanol (b/c it evaporates) +RETURN_TIP = False +DISPENSE_MM_FROM_MENISCUS = -0.5 + +ASPIRATE_MM_FROM_MENISCUS = -2.0 + +LIQUID_MOUNT = "right" +LIQUID_PIPETTE_SIZE = 1000 +LIQUID_CHANNELS = 1 + +PROBING_MOUNT = "left" +PROBING_TIP_SIZE = 50 +PROBING_PIPETTE_SIZE = 50 + +SLOT_LIQUID_TIPRACK = "C3" +SLOT_PROBING_TIPRACK = "D3" +SLOT_LABWARE = "D1" +SLOT_RESERVOIR = "C1" +SLOT_DIAL = "B3" + +########################################### +# VARIABLES - END +########################################### + + +metadata = {"protocolName": "lld-test-liquid-height-3mm-06dec"} +requirements = {"robotType": "Flex", "apiLevel": "2.20"} + + +def add_parameters(parameters: ParameterContext) -> None: + """Add parameters.""" + from hardware_testing import protocols + + protocols.create_pipette_parameters(parameters) + protocols.create_labware_parameters(parameters) + protocols.create_tube_volume_parameter(parameters) + protocols.create_trials_parameter(parameters) + + +_src_meniscus_height: Optional[float] = None +_first_row_well_names = [f"A{c + 1}" for c in range(12)] +_50_ml_tubes = ["A3", "B3", "A4", "B4"] + +TEST_WELLS = { + 1: { # channel count + "opentrons_10_tuberack_nest_4x50ml_6x15ml_conical": _50_ml_tubes, + "opentrons_10_tuberack_falcon_4x50ml_6x15ml_conical": _50_ml_tubes, + "nest_12_reservoir_15ml": _first_row_well_names, + }, + 8: { + "nest_1_reservoir_290ml": ["A1"] * 9, + "nest_1_reservoir_195ml": ["A1"] * 9, + }, +} + +DIAL_POS_WITHOUT_TIP: List[Optional[float]] = [None, None] +DIAL_PORT_NAME = "/dev/ttyUSB0" +DIAL_PORT = None +RUN_ID = "" +FILE_NAME = "" +CSV_HEADER = ["trial", "volume", "height", "tip-z-error", "corrected-height"] +CSV_SEPARATOR = "," + + +def _setup( + ctx: ProtocolContext, +) -> Tuple[ + InstrumentContext, + Labware, + InstrumentContext, + Labware, + Labware, + Labware, + Labware, + int, + int, +]: + global DIAL_PORT, RUN_ID, FILE_NAME + # TODO: use runtime-variables instead of constants + # Variables + # Pipette Types + left_mount = ctx.params.left_mount # type: ignore[attr-defined] + right_mount = ctx.params.right_mount # type: ignore[attr-defined] + num_trials = ctx.params.num_of_trials # type: ignore[attr-defined] + if left_mount != "None": + probing_pipette = ctx.load_instrument(left_mount, "left") + if right_mount != "None": + liquid_pipette = ctx.load_instrument(right_mount, "right") + liquid_pip_name = right_mount + + ctx.load_trash_bin("A3") + + probing_rack_name = f"opentrons_flex_96_tiprack_{PROBING_TIP_SIZE}uL" + probing_rack = ctx.load_labware(probing_rack_name, SLOT_PROBING_TIPRACK) + + LABWARE = ctx.params.labware_type # type: ignore[attr-defined] + tube_volume = ctx.params.tube_volume # type: ignore[attr-defined] + + labware: Labware = ctx.load_labware(LABWARE, SLOT_LABWARE) + labware_max_volume = labware["A1"].max_volume + print(f"Labware max volume: {labware_max_volume}") + if labware_max_volume < 50: + LIQUID_TIP_SIZE = 50 + else: + LIQUID_TIP_SIZE = 1000 + liquid_pip_channels = liquid_pipette.channels + + if tube_volume == 15: + # Replace volumes with 15 ml volumes + VOLUMES_3MM_TOP_BOTTOM["opentrons_10_tuberack_nest_4x50ml_6x15ml_conical"] = [ + 17.3, + 7090.6, + 16077.5, + 0.0, + ] + VOLUMES_3MM_TOP_BOTTOM["opentrons_10_tuberack_falcon_4x50ml_6x15ml_conical"] = [ + 42.2, + 15956.6, + 0.0, + ] + volumes = VOLUMES_3MM_TOP_BOTTOM[labware.load_name] + total_volume_to_aspirate = 0.0 + for one_vols in volumes: + total_volume_to_aspirate += one_vols * num_trials + if liquid_pip_channels == 1 and total_volume_to_aspirate < 1000: + RESERVOIR = "opentrons_15_tuberack_nest_15ml_conical" + else: + RESERVOIR = "nest_1_reservoir_195ml" + + reservoir = ctx.load_labware(RESERVOIR, SLOT_RESERVOIR) + if len(labware.wells()) > 96: + LIQUID_TIP_SIZE = 50 + liquid_rack_name = f"opentrons_flex_96_tiprack_{LIQUID_TIP_SIZE}uL" + liquid_rack = ctx.load_labware(liquid_rack_name, SLOT_LIQUID_TIPRACK) + + dial = ctx.load_labware("dial_indicator", SLOT_DIAL) + + if not ctx.is_simulating() and DIAL_PORT is None: + from hardware_testing.data import create_file_name, create_run_id + from hardware_testing.drivers.mitutoyo_digimatic_indicator import ( + Mitutoyo_Digimatic_Indicator, + ) + + DIAL_PORT = Mitutoyo_Digimatic_Indicator(port=DIAL_PORT_NAME) + DIAL_PORT.connect() + RUN_ID = create_run_id() + FILE_NAME = create_file_name( + metadata["protocolName"], RUN_ID, f"{liquid_pip_name}-{liquid_rack_name}" + ) + _write_line_to_csv(ctx, [RUN_ID]) + _write_line_to_csv(ctx, [liquid_pip_name]) + _write_line_to_csv(ctx, [liquid_rack_name]) + _write_line_to_csv(ctx, [LABWARE]) + _write_line_to_csv(ctx, ["depth", str(labware["A1"].depth)]) + return ( + liquid_pipette, + liquid_rack, + probing_pipette, + probing_rack, + labware, + reservoir, + dial, + tube_volume, + num_trials, + ) + + +def _write_line_to_csv(ctx: ProtocolContext, line: List[str]) -> None: + if ctx.is_simulating(): + return + from hardware_testing.data import append_data_to_file + + line_str = f"{CSV_SEPARATOR.join(line)}\n" + append_data_to_file(metadata["protocolName"], RUN_ID, FILE_NAME, line_str) + + +def _get_test_wells( + labware: Labware, channels: int, tube_volume: int, total_test_wells: int +) -> List[Well]: + well_names = [] + try: + if tube_volume == 15: + print("cHANGING LABWARE WELLS") + + TEST_WELLS[channels]["opentrons_10_tuberack_nest_4x50ml_6x15ml_conical"] = [ + "A1", + "B1", + "C1", + "A2", + "B2", + "C2", + ] + TEST_WELLS[channels][ + "opentrons_10_tuberack_falcon_4x50ml_6x15ml_conical" + ] = ["A1", "B1", "C1", "A2", "B2", "C2"] + well_names = TEST_WELLS[channels][labware.load_name] + print(TEST_WELLS[channels][labware.load_name]) + else: + well_names = TEST_WELLS[channels][labware.load_name] + except KeyError: + well_names = [ + str(well_name).split(" ")[0].replace(" ", "") + for well_name in labware.wells() + ] + print(len(well_names)) + print(well_names) + amount_of_well_names = len(well_names) + if amount_of_well_names < total_test_wells: + wells_needed = total_test_wells - amount_of_well_names + repeat_times = ( + wells_needed // len(well_names) + ) + 1 # Calculate how many times to repeat + # Extend well_names by repeating it, then trim any excess elements + well_names.extend(well_names * repeat_times) + diff_after_extension = len(well_names) - total_test_wells + well_names = well_names[:-diff_after_extension] + return [labware[w] for w in well_names] + + +def _get_test_tips(rack: Labware, channels: int) -> List[Well]: + if channels == 96: + test_tips = [rack["A1"]] + elif channels == 8: + test_tips = rack.rows()[0] + else: + test_tips = rack.wells() + return test_tips + + +def _read_dial_indicator( + ctx: ProtocolContext, + pipette: InstrumentContext, + dial: Labware, + front_channel: bool = False, +) -> float: + target = dial["A1"].top() + if front_channel: + target = target.move(Point(y=9 * 7)) + if pipette.channels == 96: + target = target.move(Point(x=9 * -11)) + pipette.move_to(target.move(Point(z=10))) + pipette.move_to(target) + ctx.delay(seconds=2) + if ctx.is_simulating(): + return 0.0 + dial_port = DIAL_PORT.read() # type: ignore[union-attr] + pipette.move_to(target.move(Point(z=10))) + return dial_port + + +def _store_dial_baseline( + ctx: ProtocolContext, + pipette: InstrumentContext, + dial: Labware, + front_channel: bool = False, +) -> None: + global DIAL_POS_WITHOUT_TIP + idx = 0 if not front_channel else 1 + if DIAL_POS_WITHOUT_TIP[idx] is not None: + return + DIAL_POS_WITHOUT_TIP[idx] = _read_dial_indicator(ctx, pipette, dial, front_channel) + tag = f"DIAL-BASELINE-{idx}" + _write_line_to_csv(ctx, [tag, str(DIAL_POS_WITHOUT_TIP[idx])]) + + +def _get_tip_z_error( + ctx: ProtocolContext, + pipette: InstrumentContext, + dial: Labware, + front_channel: bool = False, +) -> float: + idx = 0 if not front_channel else 1 + dial_baseline_for_this_channel = DIAL_POS_WITHOUT_TIP[idx] + assert dial_baseline_for_this_channel is not None + new_val = _read_dial_indicator(ctx, pipette, dial, front_channel) + z_error = new_val - dial_baseline_for_this_channel + # NOTE: dial-indicators are upside-down, so we need to flip the values + return z_error * -1.0 + + +def _test_for_finding_liquid_height( # noqa: C901 + ctx: ProtocolContext, + volume: float, + liquid_pipette: InstrumentContext, + probing_pipette: InstrumentContext, + dial: Labware, + liquid_tips: List[Well], + probing_tips: List[Well], + src_well: Well, + wells: List[Well], +) -> None: + global _src_meniscus_height + assert len(liquid_tips) == len( + probing_tips + ), f"{len(liquid_tips)},{len(probing_tips)}" + assert len(liquid_tips) == len(wells), f"{len(liquid_tips)},{len(wells)}" + trial_counter = 0 + _store_dial_baseline(ctx, probing_pipette, dial) + _write_line_to_csv(ctx, CSV_HEADER) + all_corrected_heights: List[float] = [] + for liq_tip, probe_tip, well in zip(liquid_tips, probing_tips, wells): + trial_counter += 1 + # pickup probing tip, then measure Z-error + if not probing_pipette.has_tip: + probing_pipette.pick_up_tip(probe_tip) + else: + # try and get any remaining droplets out of the way + probing_pipette.aspirate().dispense().prepare_to_aspirate() + tip_z_error = _get_tip_z_error(ctx, probing_pipette, dial) + total_vol_in_tube = 0.0 + if volume: + # transfer over and over until all volume is moved + if volume < 15650: + need_to_transfer_per_ch = volume / liquid_pipette.channels + # set flow-rates + liquid_pipette.flow_rate.aspirate = min( + max(min(liquid_pipette.max_volume, need_to_transfer_per_ch), 10), + 200, + ) + liquid_pipette.flow_rate.dispense = min( + liquid_pipette.flow_rate.aspirate, 50 + ) + liquid_pipette.flow_rate.blow_out = 100 + if _src_meniscus_height is None: + _src_meniscus_height = src_well.depth - 1.0 + if src_well.diameter: + src_well_z_ul_per_mm = math.pi * math.pow( + src_well.diameter * 0.5, 2 + ) + elif src_well.width is not None and src_well.length is not None: + src_well_z_ul_per_mm = src_well.width * src_well.length + else: + src_well_z_ul_per_mm = 0.0 + + while need_to_transfer_per_ch > 0.001: + transfer_vol = min( + liquid_pipette.max_volume * 0.9, need_to_transfer_per_ch + ) + if not liquid_pipette.has_tip: + liquid_pipette.pick_up_tip(liq_tip) + # NOTE: only use new, dry tips to probe + if not ctx.is_simulating(): + _src_meniscus_height = ( + liquid_pipette.measure_liquid_height(src_well) + - src_well.bottom().point.z + ) + else: + # try and get any remaining droplets out of the way + liquid_pipette.move_to(src_well.top(10)) + liquid_pipette.aspirate().blow_out().prepare_to_aspirate() + # aspirate + meniscus_shift_mm = transfer_vol / src_well_z_ul_per_mm + draft_multiplier = 1.2 if src_well.diameter else 1.5 + _src_meniscus_height -= draft_multiplier * meniscus_shift_mm + asp_mm = max(_src_meniscus_height + -2, 2) + liquid_pipette.aspirate(transfer_vol, src_well.bottom(asp_mm)) + need_to_transfer_per_ch -= transfer_vol + ctx.comment( + f"Aspirated {round(transfer_vol, 2)} from src, " + f"removed {round(meniscus_shift_mm, 2)} mm, " + f"now is {round(_src_meniscus_height, 2)} mm tall," + f"aspirating from {round(asp_mm, 2)} from bottom." + ) + liquid_pipette.move_to(src_well.bottom(_src_meniscus_height + 5)) + ctx.delay(seconds=1.5) + liquid_pipette.touch_tip(src_well, speed=30) + did_air_gap = False + if transfer_vol <= liquid_pipette.max_volume - 5: + liquid_pipette.aspirate(5, src_well.top(2)) + did_air_gap = True + # dispense + if did_air_gap: + liquid_pipette.dispense(5, well.top(5)) + # default will be to dispense from top + if volume > well.max_volume * 0.5: + dispense_loc = well.top(-3 + DISPENSE_MM_FROM_MENISCUS) + else: + dispense_loc = well.bottom(3 + DISPENSE_MM_FROM_MENISCUS) + liquid_pipette.dispense(transfer_vol, dispense_loc) + total_vol_in_tube += transfer_vol + ctx.delay(seconds=1.5) + liquid_pipette.move_to(well.top()) + ctx.delay(seconds=1.5) + liquid_pipette.blow_out(well.top()) + ctx.delay(seconds=1.5) + liquid_pipette.prepare_to_aspirate() + # get height of liquid + else: + ctx.pause("Fill well.") + height = probing_pipette.measure_liquid_height(well) - well.bottom().point.z + else: + is_empty = not probing_pipette.detect_liquid_presence(well) + height = ( + 0.0 if is_empty else -9999 + ) # some obviously fake number so we know it failed + corrected_height = height + tip_z_error + all_corrected_heights.append(corrected_height) + ctx.pause("CHECK LABWARE") + # drop tips + if not SAME_TIP: + if liquid_pipette.has_tip: + if RETURN_TIP: + liquid_pipette.return_tip() + else: + liquid_pipette.drop_tip() + # NOTE: always return probing tip, b/c it must be dry + if RETURN_TIP: + probing_pipette.return_tip() + else: + probing_pipette.drop_tip() + # save data + trial_data = [trial_counter, volume, height, tip_z_error, corrected_height] + _write_line_to_csv(ctx, [str(d) for d in trial_data]) + + avg = sum(all_corrected_heights) / len(all_corrected_heights) + error_mm = (max(all_corrected_heights) - min(all_corrected_heights)) * 0.5 + error_percent = error_mm / avg if avg else 0.0 + _write_line_to_csv(ctx, ["average", str(round(avg, 3))]) + _write_line_to_csv(ctx, ["error (mm)", str(round(error_mm, 3))]) + _write_line_to_csv(ctx, ["error (%)", str(round(error_percent * 100, 1))]) + + +def run(ctx: ProtocolContext) -> None: + """Run.""" + ( + liq_pipette, + liq_rack, + probe_pipette, + probe_rack, + labware, + reservoir, + dial, + tube_volume, + num_trials, + ) = _setup(ctx) + channels_liquid = liq_pipette.channels + channels_probe = probe_pipette.channels + test_tips_liquid = _get_test_tips(liq_rack, channels=channels_liquid) + test_tips_probe = _get_test_tips(probe_rack, channels=channels_probe) + # FIXME: calculate nominal volumes at +3mm from bottom and -3mm from top + # using Opentrons API (not Solidworks) + try: + if tube_volume == 15: + # Replace volumes with 15 ml volumes + VOLUMES_3MM_TOP_BOTTOM[ + "opentrons_10_tuberack_nest_4x50ml_6x15ml_conical" + ] = [17.3, 7090.6, 16077.5, 0.0] + VOLUMES_3MM_TOP_BOTTOM[ + "opentrons_10_tuberack_falcon_4x50ml_6x15ml_conical" + ] = [42.2, 15956.6, 0.0] + volumes = VOLUMES_3MM_TOP_BOTTOM[labware.load_name] + except KeyError: + volumes = [0.0, 0.0, 0.0] + ctx.comment(f"No volumes loaded for labware {labware.load_name}") + total_test_wells = len(volumes) * num_trials + test_wells = _get_test_wells( + labware, channels=1, tube_volume=tube_volume, total_test_wells=total_test_wells + ) + stuff_lengths = len(test_tips_liquid), len(test_tips_probe), len(test_wells) + + assert min(stuff_lengths) >= num_trials * len(volumes), f"{stuff_lengths}" + for _vol in volumes: + _test_for_finding_liquid_height( + ctx, + _vol, + liq_pipette, + probe_pipette, + dial, + liquid_tips=test_tips_liquid[:num_trials], + probing_tips=test_tips_probe[:num_trials], + src_well=reservoir["A1"], + wells=test_wells[:num_trials], + ) + test_wells = test_wells[num_trials:] + test_tips_liquid = test_tips_liquid[num_trials:] + test_tips_probe = test_tips_probe[num_trials:] + if liq_pipette.has_tip: + liq_pipette.return_tip() if RETURN_TIP else liq_pipette.drop_tip() + if probe_pipette.has_tip: + probe_pipette.return_tip() if RETURN_TIP else probe_pipette.drop_tip() From 62a6ff3100b7c75bf9092a8eec7aab03b6990f47 Mon Sep 17 00:00:00 2001 From: Nick Diehl <47604184+ncdiehl11@users.noreply.github.com> Date: Wed, 11 Dec 2024 17:16:11 -0500 Subject: [PATCH 17/23] fix(protocol-designer): handle duplicate labware with a full deck (#17083) If a slot overflow is opened and duplicate labware is clicked, the action will fail silently if no room is left on the robot deck. Here, we use the `getNextAvailableDeckSlot` util to determine whether or not we can dispatch a labware duplication on the deck. If not, we keep the menu open, but render a snackbar letting the user know the reason for the failure. Note that according to new design paradigms, the button remains enabled in every case. --- .../localization/en/starting_deck_state.json | 1 + .../Designer/DeckSetup/SlotOverflowMenu.tsx | 59 ++++++++++++------- .../__tests__/SlotOverflowMenu.test.tsx | 19 ++++++ 3 files changed, 59 insertions(+), 20 deletions(-) diff --git a/protocol-designer/src/assets/localization/en/starting_deck_state.json b/protocol-designer/src/assets/localization/en/starting_deck_state.json index 7e0ba531843..fd77cb95dd8 100644 --- a/protocol-designer/src/assets/localization/en/starting_deck_state.json +++ b/protocol-designer/src/assets/localization/en/starting_deck_state.json @@ -22,6 +22,7 @@ "custom": "Custom labware definitions", "customize_slot": "Customize slot", "deck_hardware": "Deck hardware", + "deck_slots_full": "Deck slots are full", "define_liquid": "Define a liquid", "done": "Done", "double_click_to_edit": "Double-click to edit", diff --git a/protocol-designer/src/pages/Designer/DeckSetup/SlotOverflowMenu.tsx b/protocol-designer/src/pages/Designer/DeckSetup/SlotOverflowMenu.tsx index c6c37c5be31..6cf595a0d97 100644 --- a/protocol-designer/src/pages/Designer/DeckSetup/SlotOverflowMenu.tsx +++ b/protocol-designer/src/pages/Designer/DeckSetup/SlotOverflowMenu.tsx @@ -21,21 +21,26 @@ import { getCutoutIdFromAddressableArea, getDeckDefFromRobotType, } from '@opentrons/shared-data' -import { getDeckSetupForActiveItem } from '../../../top-selectors/labware-locations' +import { getRobotType } from '../../../file-data/selectors' +import { + deleteContainer, + duplicateLabware, + openIngredientSelector, +} from '../../../labware-ingred/actions' +import { getNextAvailableDeckSlot } from '../../../labware-ingred/utils' import { deleteModule } from '../../../step-forms/actions' import { ConfirmDeleteStagingAreaModal, EditNickNameModal, } from '../../../organisms' +import { useKitchen } from '../../../organisms/Kitchen/hooks' import { deleteDeckFixture } from '../../../step-forms/actions/additionalItems' -import { - deleteContainer, - duplicateLabware, - openIngredientSelector, -} from '../../../labware-ingred/actions' +import { getDeckSetupForActiveItem } from '../../../top-selectors/labware-locations' + import { getStagingAreaAddressableAreas } from '../../../utils' import { selectors as labwareIngredSelectors } from '../../../labware-ingred/selectors' + import type { MouseEvent, SetStateAction } from 'react' import type { AddressableAreaName, @@ -68,6 +73,7 @@ const TOP_SLOT_Y_POSITION = 50 const TOP_SLOT_Y_POSITION_ALL_BUTTONS = 110 const TOP_SLOT_Y_POSITION_2_BUTTONS = 35 const STAGING_AREA_SLOTS = ['A4', 'B4', 'C4', 'D4'] + interface SlotOverflowMenuProps { // can be off-deck id or deck slot location: DeckSlotId | string @@ -105,11 +111,16 @@ export function SlotOverflowMenu( labwareIngredSelectors.getLiquidsByLabwareId ) + const robotType = useSelector(getRobotType) + + const { makeSnackbar } = useKitchen() + const { labware: deckSetupLabware, modules: deckSetupModules, additionalEquipmentOnDeck, } = deckSetup + const isOffDeckLocation = deckSetupLabware[location] != null const moduleOnSlot = Object.values(deckSetupModules).find( @@ -120,6 +131,9 @@ export function SlotOverflowMenu( ? lw.id === location : lw.slot === location || lw.slot === moduleOnSlot?.id ) + const isSpace = + getNextAvailableDeckSlot(deckSetup, robotType, labwareOnSlot?.def) != null + const isLabwareTiprack = labwareOnSlot?.def.parameters.isTiprack ?? false const isLabwareAnAdapter = labwareOnSlot?.def.allowedRoles?.includes('adapter') ?? false @@ -158,6 +172,24 @@ export function SlotOverflowMenu( location as AddressableAreaName ) + const handleDuplicate = (): void => { + if (!isSpace) { + makeSnackbar(t('deck_slots_full') as string) + return + } + + if ( + labwareOnSlot != null && + !isLabwareAnAdapter && + nestedLabwareOnSlot == null + ) { + dispatch(duplicateLabware(labwareOnSlot.id)) + } else if (nestedLabwareOnSlot != null) { + dispatch(duplicateLabware(nestedLabwareOnSlot.id)) + } + setShowMenuList(false) + } + const handleClear = (): void => { // clear module from slot if (moduleOnSlot != null) { @@ -309,20 +341,7 @@ export function SlotOverflowMenu( {showDuplicateBtn ? ( - { - if ( - labwareOnSlot != null && - !isLabwareAnAdapter && - nestedLabwareOnSlot == null - ) { - dispatch(duplicateLabware(labwareOnSlot.id)) - } else if (nestedLabwareOnSlot != null) { - dispatch(duplicateLabware(nestedLabwareOnSlot.id)) - } - setShowMenuList(false) - }} - > + {t('duplicate')} diff --git a/protocol-designer/src/pages/Designer/DeckSetup/__tests__/SlotOverflowMenu.test.tsx b/protocol-designer/src/pages/Designer/DeckSetup/__tests__/SlotOverflowMenu.test.tsx index 56d5af2f806..3fc9f65f8ea 100644 --- a/protocol-designer/src/pages/Designer/DeckSetup/__tests__/SlotOverflowMenu.test.tsx +++ b/protocol-designer/src/pages/Designer/DeckSetup/__tests__/SlotOverflowMenu.test.tsx @@ -11,10 +11,12 @@ import { openIngredientSelector, } from '../../../../labware-ingred/actions' import { EditNickNameModal } from '../../../../organisms' +import { useKitchen } from '../../../../organisms/Kitchen/hooks' import { deleteModule } from '../../../../step-forms/actions' import { deleteDeckFixture } from '../../../../step-forms/actions/additionalItems' import { getDeckSetupForActiveItem } from '../../../../top-selectors/labware-locations' import { selectors as labwareIngredSelectors } from '../../../../labware-ingred/selectors' +import { getNextAvailableDeckSlot } from '../../../../labware-ingred/utils' import { SlotOverflowMenu } from '../SlotOverflowMenu' import type { NavigateFunction } from 'react-router-dom' @@ -28,6 +30,9 @@ vi.mock('../../../../labware-ingred/actions') vi.mock('../../../../labware-ingred/selectors') vi.mock('../../../../step-forms/actions/additionalItems') vi.mock('../../../../organisms') +vi.mock('../../../../file-data/selectors') +vi.mock('../../../../labware-ingred/utils') +vi.mock('../../../../organisms/Kitchen/hooks') vi.mock('react-router-dom', async importOriginal => { const actual = await importOriginal() return { @@ -43,6 +48,7 @@ const render = (props: React.ComponentProps) => { } const MOCK_STAGING_AREA_ID = 'MOCK_STAGING_AREA_ID' +const MOCK_MAKE_SNACKBAR = vi.fn() describe('SlotOverflowMenu', () => { let props: React.ComponentProps @@ -91,6 +97,12 @@ describe('SlotOverflowMenu', () => {
mockEditNickNameModal
) vi.mocked(labwareIngredSelectors.getLiquidsByLabwareId).mockReturnValue({}) + vi.mocked(getNextAvailableDeckSlot).mockReturnValue('A1') + vi.mocked(useKitchen).mockReturnValue({ + makeSnackbar: MOCK_MAKE_SNACKBAR, + eatToast: vi.fn(), + bakeToast: vi.fn(), + }) }) afterEach(() => { @@ -165,4 +177,11 @@ describe('SlotOverflowMenu', () => { expect(vi.mocked(deleteModule)).toHaveBeenCalledOnce() expect(vi.mocked(deleteModule)).toHaveBeenCalledWith('modId') }) + + it('renders snackbar if duplicate is clicked and the deck is full', () => { + vi.mocked(getNextAvailableDeckSlot).mockReturnValue(null) + render(props) + fireEvent.click(screen.getByRole('button', { name: 'Duplicate labware' })) + expect(MOCK_MAKE_SNACKBAR).toHaveBeenCalled() + }) }) From 3809a7982db6836fae7b2db1b3d01b5e9f14c062 Mon Sep 17 00:00:00 2001 From: Nick Diehl <47604184+ncdiehl11@users.noreply.github.com> Date: Wed, 11 Dec 2024 18:13:08 -0500 Subject: [PATCH 18/23] fix(protocol-designer): fix logic for terminal step icon (#17089) This fixes a bug where the starting deck terminal step icon was being incorrectly determined as the end icon, because we were checking the title text of the step, which is subject to change. To fix this, we determine the icon based on step ID. --- .../ProtocolSteps/Timeline/TerminalItemStep.tsx | 10 ++++++---- .../ProtocolSteps/Timeline/TimelineToolbox.tsx | 7 ++----- 2 files changed, 8 insertions(+), 9 deletions(-) diff --git a/protocol-designer/src/pages/Designer/ProtocolSteps/Timeline/TerminalItemStep.tsx b/protocol-designer/src/pages/Designer/ProtocolSteps/Timeline/TerminalItemStep.tsx index fc808579af4..39fd70a9f78 100644 --- a/protocol-designer/src/pages/Designer/ProtocolSteps/Timeline/TerminalItemStep.tsx +++ b/protocol-designer/src/pages/Designer/ProtocolSteps/Timeline/TerminalItemStep.tsx @@ -28,14 +28,15 @@ import type { } from '../../../../ui/steps' import type { TerminalItemId } from '../../../../steplist' import type { ThunkDispatch } from '../../../../types' +import { useTranslation } from 'react-i18next' export interface TerminalItemStepProps { id: TerminalItemId - title: string } export function TerminalItemStep(props: TerminalItemStepProps): JSX.Element { - const { id, title } = props + const { id } = props + const { t } = useTranslation('protocol_steps') const hovered = useSelector(getHoveredTerminalItemId) === id const selected = useSelector(getSelectedTerminalItemId) === id const currentFormIsPresaved = useSelector(getCurrentFormIsPresaved) @@ -83,10 +84,11 @@ export function TerminalItemStep(props: TerminalItemStepProps): JSX.Element { { gridGap={SPACING.spacing4} width="100%" > - + { @@ -89,7 +86,7 @@ export const TimelineToolbox = (): JSX.Element => { }} /> - + ) From 28fa8ba11ab95cc168ec9d350ec238af8da65cea Mon Sep 17 00:00:00 2001 From: koji Date: Thu, 12 Dec 2024 11:24:20 -0500 Subject: [PATCH 19/23] chore: add jsx-curly-brace-presence (#17078) * chore: add jsx-curly-brace-presence --- .eslintrc.js | 1 + .../AlphanumericKeyboard/index.tsx | 2 +- .../SoftwareKeyboard/FullKeyboard/index.tsx | 2 +- .../SoftwareKeyboard/IndividualKey/index.tsx | 2 +- .../NumericalKeyboard/index.tsx | 2 +- app/src/molecules/InstrumentCard/index.tsx | 2 +- .../InterventionModal/ModalContentMixed.tsx | 2 +- .../InterventionModal/TwoColumn.stories.tsx | 2 +- .../ModalContentOneColSimpleButtons.test.tsx | 14 +++++++------- .../InterventionModal/story-utils/StandIn.tsx | 2 +- .../__tests__/CalibrationTaskList.test.tsx | 18 +++++++++--------- .../Desktop/ChooseProtocolSlideout/index.tsx | 2 +- .../AddFixtureModal.tsx | 4 ++-- .../ODD/NetworkSettings/FailedToConnect.tsx | 6 +++--- .../__tests__/LongPressModal.test.tsx | 2 +- .../__tests__/LongPressModal.test.tsx | 2 +- .../src/molecules/Accordion/index.tsx | 2 +- .../src/molecules/ChatDisplay/index.tsx | 6 +++--- .../ControlledRadioButtonGroup/index.tsx | 2 +- .../PromptPreview/PromptPreview.stories.tsx | 2 +- .../molecules/PromptPreviewSection/index.tsx | 2 +- .../organisms/LabwareLiquidsSection/index.tsx | 4 ++-- .../src/organisms/LabwareModal/index.tsx | 4 ++-- .../src/organisms/StepsSection/index.tsx | 2 +- .../src/pages/UpdateProtocol/index.tsx | 4 ++-- .../CreateNewProtocolWizard/AddMetadata.tsx | 8 ++++---- .../StepForm/StepTools/MixTools/index.tsx | 4 ++-- protocol-designer/src/pages/Landing/index.tsx | 2 +- 28 files changed, 54 insertions(+), 53 deletions(-) diff --git a/.eslintrc.js b/.eslintrc.js index 7de339ebde5..aee75238df0 100644 --- a/.eslintrc.js +++ b/.eslintrc.js @@ -39,6 +39,7 @@ module.exports = { 'no-case-declarations': 'warn', 'prefer-regex-literals': 'warn', 'react/prop-types': 'warn', + 'react/jsx-curly-brace-presence': 'warn', // Enforce notification hooks 'no-restricted-imports': [ diff --git a/app/src/atoms/SoftwareKeyboard/AlphanumericKeyboard/index.tsx b/app/src/atoms/SoftwareKeyboard/AlphanumericKeyboard/index.tsx index 73ec9306fee..3b3bb3ab48c 100644 --- a/app/src/atoms/SoftwareKeyboard/AlphanumericKeyboard/index.tsx +++ b/app/src/atoms/SoftwareKeyboard/AlphanumericKeyboard/index.tsx @@ -49,7 +49,7 @@ export function AlphanumericKeyboard({ return ( (keyboardRef.current = r)} - theme={'hg-theme-default oddTheme1 alphanumericKeyboard'} + theme="hg-theme-default oddTheme1 alphanumericKeyboard" onChange={onChange} onKeyPress={onKeyPress} layoutName={layoutName} diff --git a/app/src/atoms/SoftwareKeyboard/FullKeyboard/index.tsx b/app/src/atoms/SoftwareKeyboard/FullKeyboard/index.tsx index 2846930ad1e..f1f9a962da6 100644 --- a/app/src/atoms/SoftwareKeyboard/FullKeyboard/index.tsx +++ b/app/src/atoms/SoftwareKeyboard/FullKeyboard/index.tsx @@ -60,7 +60,7 @@ export function FullKeyboard({ return ( (keyboardRef.current = r)} - theme={'hg-theme-default oddTheme1'} + theme="hg-theme-default oddTheme1" onChange={onChange} onKeyPress={onKeyPress} layoutName={layoutName} diff --git a/app/src/atoms/SoftwareKeyboard/IndividualKey/index.tsx b/app/src/atoms/SoftwareKeyboard/IndividualKey/index.tsx index 1ba1ec5e150..1cc2668d788 100644 --- a/app/src/atoms/SoftwareKeyboard/IndividualKey/index.tsx +++ b/app/src/atoms/SoftwareKeyboard/IndividualKey/index.tsx @@ -34,7 +34,7 @@ export function IndividualKey({ */ (keyboardRef.current = r)} - theme={'hg-theme-default oddTheme1 individual-key'} + theme="hg-theme-default oddTheme1 individual-key" onChange={onChange} layoutName="default" display={customDisplay} diff --git a/app/src/atoms/SoftwareKeyboard/NumericalKeyboard/index.tsx b/app/src/atoms/SoftwareKeyboard/NumericalKeyboard/index.tsx index f0025b6c972..4d3959eb9c3 100644 --- a/app/src/atoms/SoftwareKeyboard/NumericalKeyboard/index.tsx +++ b/app/src/atoms/SoftwareKeyboard/NumericalKeyboard/index.tsx @@ -36,7 +36,7 @@ export function NumericalKeyboard({ */ (keyboardRef.current = r)} - theme={'hg-theme-default oddTheme1 numerical-keyboard'} + theme="hg-theme-default oddTheme1 numerical-keyboard" onInit={keyboard => { keyboard.setInput(initialValue) }} diff --git a/app/src/molecules/InstrumentCard/index.tsx b/app/src/molecules/InstrumentCard/index.tsx index bcb2ccb47ac..edcee546c32 100644 --- a/app/src/molecules/InstrumentCard/index.tsx +++ b/app/src/molecules/InstrumentCard/index.tsx @@ -91,7 +91,7 @@ export function InstrumentCard(props: InstrumentCardProps): JSX.Element { pipetteSpecs={instrumentDiagramProps.pipetteSpecs} mount={instrumentDiagramProps.mount} transform="scale(0.3)" - transformOrigin={'-5% 52%'} + transformOrigin="-5% 52%" /> ) : null} diff --git a/app/src/molecules/InterventionModal/ModalContentMixed.tsx b/app/src/molecules/InterventionModal/ModalContentMixed.tsx index 4c41003c3d8..c7f4a43ea6e 100644 --- a/app/src/molecules/InterventionModal/ModalContentMixed.tsx +++ b/app/src/molecules/InterventionModal/ModalContentMixed.tsx @@ -152,7 +152,7 @@ function ModalContentMixedSpinner( return ( 0 && imageUrl[0].length > 0 return hasComponent ? ( - + ) : null } diff --git a/app/src/molecules/InterventionModal/__tests__/ModalContentOneColSimpleButtons.test.tsx b/app/src/molecules/InterventionModal/__tests__/ModalContentOneColSimpleButtons.test.tsx index 27a40d82ad4..b68e8a379a0 100644 --- a/app/src/molecules/InterventionModal/__tests__/ModalContentOneColSimpleButtons.test.tsx +++ b/app/src/molecules/InterventionModal/__tests__/ModalContentOneColSimpleButtons.test.tsx @@ -17,7 +17,7 @@ describe('InterventionModal', () => { it('renders headline', () => { render( @@ -27,7 +27,7 @@ describe('InterventionModal', () => { it('renders buttons', () => { render( { it('enforces single-item selection', () => { render( { it('can start with a button selected', () => { render( ) expect(inputElForButtonFromButtonText('first button').checked).toBeFalsy() @@ -84,7 +84,7 @@ describe('InterventionModal', () => { const onChange = vi.fn() render( { const onSelect = vi.fn() render( { rerender( { rerender( { rerender( { rerender( { rerender( { rerender( { rerender( { rerender( { rerender( ), }} diff --git a/app/src/organisms/DeviceDetailsDeckConfiguration/AddFixtureModal.tsx b/app/src/organisms/DeviceDetailsDeckConfiguration/AddFixtureModal.tsx index bf3be7e788e..b4b8f462d7f 100644 --- a/app/src/organisms/DeviceDetailsDeckConfiguration/AddFixtureModal.tsx +++ b/app/src/organisms/DeviceDetailsDeckConfiguration/AddFixtureModal.tsx @@ -369,8 +369,8 @@ export function AddFixtureModal({ }} aria-label="back" paddingX={SPACING.spacing16} - marginTop={'1.44rem'} - marginBottom={'0.56rem'} + marginTop="1.44rem" + marginBottom="0.56rem" > {t('shared:go_back')} diff --git a/app/src/organisms/ODD/NetworkSettings/FailedToConnect.tsx b/app/src/organisms/ODD/NetworkSettings/FailedToConnect.tsx index e3859e4ed29..22358b922bc 100644 --- a/app/src/organisms/ODD/NetworkSettings/FailedToConnect.tsx +++ b/app/src/organisms/ODD/NetworkSettings/FailedToConnect.tsx @@ -51,7 +51,7 @@ export function FailedToConnect({ name="ot-alert" size="3rem" color={COLORS.red50} - aria-label={'failed_to_connect_invalidPassword'} + aria-label="failed_to_connect_invalidPassword" /> diff --git a/app/src/pages/ODD/ProtocolDashboard/__tests__/LongPressModal.test.tsx b/app/src/pages/ODD/ProtocolDashboard/__tests__/LongPressModal.test.tsx index 777e8d92a39..68ff6dcc9bf 100644 --- a/app/src/pages/ODD/ProtocolDashboard/__tests__/LongPressModal.test.tsx +++ b/app/src/pages/ODD/ProtocolDashboard/__tests__/LongPressModal.test.tsx @@ -26,7 +26,7 @@ const render = (longPress: UseLongPressResult) => { diff --git a/app/src/pages/ODD/QuickTransferDashboard/__tests__/LongPressModal.test.tsx b/app/src/pages/ODD/QuickTransferDashboard/__tests__/LongPressModal.test.tsx index 2c55020d32a..e7e743e19ae 100644 --- a/app/src/pages/ODD/QuickTransferDashboard/__tests__/LongPressModal.test.tsx +++ b/app/src/pages/ODD/QuickTransferDashboard/__tests__/LongPressModal.test.tsx @@ -26,7 +26,7 @@ const render = (longPress: UseLongPressResult) => { diff --git a/opentrons-ai-client/src/molecules/Accordion/index.tsx b/opentrons-ai-client/src/molecules/Accordion/index.tsx index 4bb611d618d..f45294faa70 100644 --- a/opentrons-ai-client/src/molecules/Accordion/index.tsx +++ b/opentrons-ai-client/src/molecules/Accordion/index.tsx @@ -79,7 +79,7 @@ export function Accordion({ )} diff --git a/opentrons-ai-client/src/molecules/ChatDisplay/index.tsx b/opentrons-ai-client/src/molecules/ChatDisplay/index.tsx index b1b1e9df98a..833596829f8 100644 --- a/opentrons-ai-client/src/molecules/ChatDisplay/index.tsx +++ b/opentrons-ai-client/src/molecules/ChatDisplay/index.tsx @@ -205,14 +205,14 @@ export function ChatDisplay({ chat, chatId }: ChatDisplayProps): JSX.Element { setInputFieldToCorrespondingRequest() }} > - + { setShowFeedbackModal(true) }} > - + { @@ -229,7 +229,7 @@ export function ChatDisplay({ chat, chatId }: ChatDisplayProps): JSX.Element { handleFileDownload() }} > - + ) : null} diff --git a/opentrons-ai-client/src/molecules/ControlledRadioButtonGroup/index.tsx b/opentrons-ai-client/src/molecules/ControlledRadioButtonGroup/index.tsx index 9245c3a1a1a..0b28a6721f4 100644 --- a/opentrons-ai-client/src/molecules/ControlledRadioButtonGroup/index.tsx +++ b/opentrons-ai-client/src/molecules/ControlledRadioButtonGroup/index.tsx @@ -48,7 +48,7 @@ export function ControlledRadioButtonGroup({ { field.onChange(e) diff --git a/opentrons-ai-client/src/molecules/PromptPreview/PromptPreview.stories.tsx b/opentrons-ai-client/src/molecules/PromptPreview/PromptPreview.stories.tsx index 79e7b822dcc..233af454bc5 100644 --- a/opentrons-ai-client/src/molecules/PromptPreview/PromptPreview.stories.tsx +++ b/opentrons-ai-client/src/molecules/PromptPreview/PromptPreview.stories.tsx @@ -13,7 +13,7 @@ const meta: Meta = { diff --git a/opentrons-ai-client/src/molecules/PromptPreviewSection/index.tsx b/opentrons-ai-client/src/molecules/PromptPreviewSection/index.tsx index 34c986a865d..25b20037064 100644 --- a/opentrons-ai-client/src/molecules/PromptPreviewSection/index.tsx +++ b/opentrons-ai-client/src/molecules/PromptPreviewSection/index.tsx @@ -72,7 +72,7 @@ export function PromptPreviewSection({ key={`item-tag-${index}`} itemMaxWidth={itemMaxWidth} > - + ) )} diff --git a/opentrons-ai-client/src/organisms/LabwareLiquidsSection/index.tsx b/opentrons-ai-client/src/organisms/LabwareLiquidsSection/index.tsx index 24d50e32f21..a3bc15abbbb 100644 --- a/opentrons-ai-client/src/organisms/LabwareLiquidsSection/index.tsx +++ b/opentrons-ai-client/src/organisms/LabwareLiquidsSection/index.tsx @@ -48,7 +48,7 @@ export function LabwareLiquidsSection(): JSX.Element | null { setDisplayLabwareModal(true) }} text={t('add_opentrons_labware')} - textAlignment={'left'} + textAlignment="left" iconName="plus" /> @@ -77,7 +77,7 @@ export function LabwareLiquidsSection(): JSX.Element | null { setValue(LIQUIDS_FIELD_NAME, [...liquids, '']) }} text={t('add_opentrons_liquid')} - textAlignment={'left'} + textAlignment="left" iconName="plus" /> diff --git a/opentrons-ai-client/src/organisms/LabwareModal/index.tsx b/opentrons-ai-client/src/organisms/LabwareModal/index.tsx index 0fcb6b17de1..d677f6fc14e 100644 --- a/opentrons-ai-client/src/organisms/LabwareModal/index.tsx +++ b/opentrons-ai-client/src/organisms/LabwareModal/index.tsx @@ -144,12 +144,12 @@ export function LabwareModal({ { handleCategoryClick(category) }} > - + diff --git a/opentrons-ai-client/src/pages/UpdateProtocol/index.tsx b/opentrons-ai-client/src/pages/UpdateProtocol/index.tsx index 6d12c3f700a..4538e8b063c 100644 --- a/opentrons-ai-client/src/pages/UpdateProtocol/index.tsx +++ b/opentrons-ai-client/src/pages/UpdateProtocol/index.tsx @@ -285,7 +285,7 @@ export function UpdateProtocol(): JSX.Element { ), }} @@ -304,7 +304,7 @@ export function UpdateProtocol(): JSX.Element { - + @@ -86,8 +86,8 @@ export function AddMetadata(props: AddMetadataProps): JSX.Element | null { {...register('fields.organizationOrAuthor')} type="text" value={watch('fields.organizationOrAuthor')} - min={''} - max={''} + min="" + max="" /> diff --git a/protocol-designer/src/pages/Designer/ProtocolSteps/StepForm/StepTools/MixTools/index.tsx b/protocol-designer/src/pages/Designer/ProtocolSteps/StepForm/StepTools/MixTools/index.tsx index 826b76ab453..981ff980660 100644 --- a/protocol-designer/src/pages/Designer/ProtocolSteps/StepForm/StepTools/MixTools/index.tsx +++ b/protocol-designer/src/pages/Designer/ProtocolSteps/StepForm/StepTools/MixTools/index.tsx @@ -200,8 +200,8 @@ export function MixTools(props: StepFormProps): JSX.Element { } firstValue={formData.mix_wellOrder_first} secondValue={formData.mix_wellOrder_second} - firstName={'mix_wellOrder_first'} - secondName={'mix_wellOrder_second'} + firstName="mix_wellOrder_first" + secondName="mix_wellOrder_second" /> - + { dispatch(toggleNewProtocolModal(true)) From 0104760271deee3a730e86a987abcfef953a0d9f Mon Sep 17 00:00:00 2001 From: Jamey Huffnagle Date: Thu, 12 Dec 2024 11:41:12 -0500 Subject: [PATCH 20/23] fix(actions): use project id in memory analytics (#17076) --- .github/actions/odd-resource-analysis/action/index.js | 8 +++++--- .../odd-resource-analysis/action/lib/helpers/mixpanel.js | 2 +- .github/workflows/odd-memory-usage-test.yaml | 2 +- 3 files changed, 7 insertions(+), 5 deletions(-) diff --git a/.github/actions/odd-resource-analysis/action/index.js b/.github/actions/odd-resource-analysis/action/index.js index 9ccd2f48e5a..7941e1a2b25 100644 --- a/.github/actions/odd-resource-analysis/action/index.js +++ b/.github/actions/odd-resource-analysis/action/index.js @@ -5,9 +5,11 @@ async function run() { try { const mixpanelUser = core.getInput('mixpanel-user', { required: true }) const mixpanelSecret = core.getInput('mixpanel-secret', { required: true }) - const mixpanelProjectId = core.getInput('mixpanel-project-id', { - required: true, - }) + const mixpanelProjectId = parseInt( + core.getInput('mixpanel-project-id', { + required: true, + }) + ) const previousVersionCount = parseInt( core.getInput('previous-version-count') || '2' ) diff --git a/.github/actions/odd-resource-analysis/action/lib/helpers/mixpanel.js b/.github/actions/odd-resource-analysis/action/lib/helpers/mixpanel.js index 50013d9ffd6..a518d1f4b40 100644 --- a/.github/actions/odd-resource-analysis/action/lib/helpers/mixpanel.js +++ b/.github/actions/odd-resource-analysis/action/lib/helpers/mixpanel.js @@ -33,7 +33,7 @@ async function getMixpanelResourceMonitorDataFor({ where, }) { const params = new URLSearchParams({ - project_id: parseInt(projectId), + project_id: projectId, from_date: fromDate, to_date: toDate, event: '["resourceMonitorReport"]', diff --git a/.github/workflows/odd-memory-usage-test.yaml b/.github/workflows/odd-memory-usage-test.yaml index 3302ec0203a..15b78fc79a3 100644 --- a/.github/workflows/odd-memory-usage-test.yaml +++ b/.github/workflows/odd-memory-usage-test.yaml @@ -20,5 +20,5 @@ jobs: with: mixpanel-user: ${{ secrets.MIXPANEL_INGEST_USER }} mixpanel-secret: ${{ secrets.MIXPANEL_INGEST_SECRET }} - mixpanel-project-id: ${{ secrets.OT_APP_MIXPANEL_ID }} + mixpanel-project-id: ${{ secrets.OT_MIXPANEL_PROJECT_ID }} previous-version-count: '2' \ No newline at end of file From 7ff5e27ead5b96448444c4618bc8f7480b7deffd Mon Sep 17 00:00:00 2001 From: Jethary Alcid <66035149+jerader@users.noreply.github.com> Date: Thu, 12 Dec 2024 12:35:36 -0500 Subject: [PATCH 21/23] fix(protocol-designer): resolve console error by adding null protection (#17094) --- .../StepForm/StepTools/MoveLiquidTools/index.tsx | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) diff --git a/protocol-designer/src/pages/Designer/ProtocolSteps/StepForm/StepTools/MoveLiquidTools/index.tsx b/protocol-designer/src/pages/Designer/ProtocolSteps/StepForm/StepTools/MoveLiquidTools/index.tsx index fcb64ff8834..f2c99c24087 100644 --- a/protocol-designer/src/pages/Designer/ProtocolSteps/StepForm/StepTools/MoveLiquidTools/index.tsx +++ b/protocol-designer/src/pages/Designer/ProtocolSteps/StepForm/StepTools/MoveLiquidTools/index.tsx @@ -98,11 +98,14 @@ export function MoveLiquidTools(props: StepFormProps): JSX.Element { additionalEquipmentEntities[String(propsForFields.dispense_labware.value)] ?.name === 'trashBin' - const destinationLabwareType = getTrashOrLabware( - labwares, - additionalEquipmentEntities, - formData.dispense_labware as string - ) + const destinationLabwareType = + formData.dispense_labware != null + ? getTrashOrLabware( + labwares, + additionalEquipmentEntities, + formData.dispense_labware as string + ) + : null const isDestinationTrash = destinationLabwareType != null ? ['trashBin', 'wasteChute'].includes(destinationLabwareType) From 09febe7da84a171bb63021a65b1abee5747072f2 Mon Sep 17 00:00:00 2001 From: Elyor Kodirov Date: Thu, 12 Dec 2024 23:18:25 +0500 Subject: [PATCH 22/23] set temperature-0.0 to improve consistency [AUTH-1184] (#17096) # Overview Set temperature parameter to 0.0 to reduce hallucination. Closes AUTH-1184 ## Test Plan and Hands on Testing CI handles testing. ## Changelog only temperature parameter ## Review requests Open UI and try to generate. All should be normal. ## Risk assessment Low --- opentrons-ai-server/api/domain/anthropic_predict.py | 1 + 1 file changed, 1 insertion(+) diff --git a/opentrons-ai-server/api/domain/anthropic_predict.py b/opentrons-ai-server/api/domain/anthropic_predict.py index d8028d883e6..f0818774d57 100644 --- a/opentrons-ai-server/api/domain/anthropic_predict.py +++ b/opentrons-ai-server/api/domain/anthropic_predict.py @@ -95,6 +95,7 @@ def _process_message( tools=self.tools, # type: ignore extra_headers={"anthropic-beta": "prompt-caching-2024-07-31"}, metadata={"user_id": user_id}, + temperature=0.0, ) logger.info( From 071356319648917c31514036f3d5afc0e57361cb Mon Sep 17 00:00:00 2001 From: Jamey Huffnagle Date: Thu, 12 Dec 2024 16:24:26 -0500 Subject: [PATCH 23/23] feat(app): add renderer source maps (#17062) Closes EXEC-1046 Currently, whenever browser layer errors occur in an electron app production build, renderer process debugging is difficult, because production builds are minified. Enter source maps, which, when utilized alongside a library that provides stack trace support for V8, make error messaging much more useful. --- app/package.json | 2 ++ app/src/App/index.tsx | 1 + app/tsconfig.json | 3 ++- app/vite.config.mts | 1 + yarn.lock | 16 ++++++++++++++++ 5 files changed, 22 insertions(+), 1 deletion(-) diff --git a/app/package.json b/app/package.json index 33ae6252d1a..5528120de1f 100644 --- a/app/package.json +++ b/app/package.json @@ -64,6 +64,7 @@ "rxjs": "^6.5.1", "semver": "5.7.2", "simple-keyboard-layouts": "3.4.41", + "source-map-support": "0.5.10", "styled-components": "5.3.6", "typeface-open-sans": "0.0.75", "uuid": "3.2.1" @@ -75,6 +76,7 @@ "@types/jszip": "3.1.7", "@types/mixpanel-browser": "^2.35.6", "@types/node-fetch": "2.6.11", + "@types/source-map-support": "0.5.10", "@types/styled-components": "^5.1.26", "axios": "^0.21.1", "electron-updater": "6.3.9", diff --git a/app/src/App/index.tsx b/app/src/App/index.tsx index f0ba1de0304..2e05c91359e 100644 --- a/app/src/App/index.tsx +++ b/app/src/App/index.tsx @@ -1,5 +1,6 @@ import type * as React from 'react' import { useSelector } from 'react-redux' +import 'source-map-support/register' import { Flex, POSITION_FIXED, DIRECTION_ROW } from '@opentrons/components' diff --git a/app/tsconfig.json b/app/tsconfig.json index 92921aa2b1c..db9d81301e0 100644 --- a/app/tsconfig.json +++ b/app/tsconfig.json @@ -35,7 +35,8 @@ "outDir": "lib", "paths": { "/app/*": ["./src/*"] - } + }, + "sourceMap": true, }, "include": ["typings", "src"], "exclude": ["**/*.stories.tsx"] diff --git a/app/vite.config.mts b/app/vite.config.mts index f10fedf4f7e..4828283b107 100644 --- a/app/vite.config.mts +++ b/app/vite.config.mts @@ -19,6 +19,7 @@ export default defineConfig( build: { // Relative to the root outDir: 'dist', + sourcemap: true }, plugins: [ react({ diff --git a/yarn.lock b/yarn.lock index d788db962fd..98619e9a945 100644 --- a/yarn.lock +++ b/yarn.lock @@ -3684,6 +3684,7 @@ rxjs "^6.5.1" semver "5.7.2" simple-keyboard-layouts "3.4.41" + source-map-support "0.5.10" styled-components "5.3.6" typeface-open-sans "0.0.75" uuid "3.2.1" @@ -6122,6 +6123,13 @@ resolved "https://registry.yarnpkg.com/@types/sizzle/-/sizzle-2.3.8.tgz#518609aefb797da19bf222feb199e8f653ff7627" integrity sha512-0vWLNK2D5MT9dg0iOo8GlKguPAU02QjmZitPEsXRuJXU/OGIOt9vT9Fc26wtYuavLxtO45v9PGleoL9Z0k1LHg== +"@types/source-map-support@0.5.10": + version "0.5.10" + resolved "https://registry.yarnpkg.com/@types/source-map-support/-/source-map-support-0.5.10.tgz#824dcef989496bae98e9d04c8dc1ac1d70e1bd39" + integrity sha512-tgVP2H469x9zq34Z0m/fgPewGhg/MLClalNOiPIzQlXrSS2YrKu/xCdSCKnEDwkFha51VKEKB6A9wW26/ZNwzA== + dependencies: + source-map "^0.6.0" + "@types/styled-components@^5.1.26": version "5.1.34" resolved "https://registry.yarnpkg.com/@types/styled-components/-/styled-components-5.1.34.tgz#4107df8ef8a7eaba4fa6b05f78f93fba4daf0300" @@ -20718,6 +20726,14 @@ source-map-resolve@^0.5.0: source-map-url "^0.4.0" urix "^0.1.0" +source-map-support@0.5.10: + version "0.5.10" + resolved "https://registry.yarnpkg.com/source-map-support/-/source-map-support-0.5.10.tgz#2214080bc9d51832511ee2bab96e3c2f9353120c" + integrity sha512-YfQ3tQFTK/yzlGJuX8pTwa4tifQj4QS2Mj7UegOu8jAz59MqIiMGPXxQhVQiIMNzayuUSF/jEuVnfFF5JqybmQ== + dependencies: + buffer-from "^1.0.0" + source-map "^0.6.0" + source-map-support@^0.5.16, source-map-support@^0.5.19, source-map-support@^0.5.6, source-map-support@~0.5.12, source-map-support@~0.5.20: version "0.5.21" resolved "https://registry.yarnpkg.com/source-map-support/-/source-map-support-0.5.21.tgz#04fe7c7f9e1ed2d662233c28cb2b35b9f63f6e4f"