Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Chore Release v8.3.0 #17186

Open
wants to merge 443 commits into
base: release
Choose a base branch
from
Open

Chore Release v8.3.0 #17186

wants to merge 443 commits into from

Conversation

y3rsh
Copy link
Member

@y3rsh y3rsh commented Jan 6, 2025

v8.3.0

TamarZanzouri and others added 30 commits November 20, 2024 16:50
# Overview

Updating versioning page and API reference for changes to mix behavior 

<!--
Describe your PR at a high level. State acceptance criteria and how this
PR fits into other work. Link issues, PRs, and other relevant resources.
-->

## Test Plan and Hands on Testing

http://sandbox.docs.opentrons.com/docs-lld-mix/v2/
<!--
Describe your testing of the PR. Emphasize testing not reflected in the
code. Attach protocols, logs, screenshots and any other assets that
support your testing.
-->

## Changelog

4 lines in versioning.rst to provide description of changes to mix
behavior in version 2.21
2 lines in instrument_context.py to provide description of changes to
mix behavior in version 2.21


<!--
List changes introduced by this PR considering future developers and the
end user. Give careful thought and clear documentation to breaking
changes.
-->

## Review requests

no special requests
<!--
- What do you need from reviewers to feel confident this PR is ready to
merge?
- Ask questions.
-->

## Risk assessment

low

<!--
- Indicate the level of attention this PR needs.
- Provide context to guide reviewers.
- Discuss trade-offs, coupling, and side effects.
- Look for the possibility, even if you think it's small, that your
change may affect some other part of the system.
- For instance, changing return tip behavior may also change the
behavior of labware calibration.
- How do your unit tests and on hands on testing mitigate this PR's
risks and the risk of future regressions?
- Especially in high risk PRs, explain how you know your testing is
enough.
-->
…16922)

# Overview

Ensures data collection scripts can all use the same IPs.json file when
connecting to robots

---------

Co-authored-by: rclarke0 <[email protected]>
…s to list of robot ips (#16909)

# Overview
Adds the ability to push one or more folders to one or more roots at
once

## Test Plan and Hands on Testing
Manually tested functionality of command

## Changelog
Added push-folder definition to opentrons makefile

---------

Co-authored-by: rclarke0 <[email protected]>
Co-authored-by: Rhyann Clarke <[email protected]>
# Overview
Fixes the issue of make-simulate not simulating liquid setups in
protocols folder

---------

Co-authored-by: rclarke0 <[email protected]>
…ties (#16878)

Modifies the schema from ticket AUTH-832, removes `default` key and refactors `byVolume` property schema

---------

Co-authored-by: jbleon95 <[email protected]>
# Overview

Documents how to use the Opentrons Tough PCR Auto-sealing Lids and
Opentrons Flex Deck Riser in a Python protocol.

## Test Plan and Hands on Testing

-
[Sandbox](http://sandbox.docs.opentrons.com/docs-tc-lids/v2/modules/thermocycler.html#auto-sealing-lids)
- all new code samples pass simulation

## Changelog

- New section on auto-sealing lids
- Change load statement at top of article to use Opentrons PCR plate
instead of NEST

## Review requests

- Completeness, clarity, etc.
- Double-check code
- There is some deliberate vagueness around lid loading that is meant to
future-proof against labware schema and API changes

## Risk assessment

none, docs.
# Overview

AUTH-851

Export the liquid classes we loaded into the Protocol Engine to the
`StateSummary`, which will let clients see what liquid classes we
loaded.

The liquid classes are stored internally as a map of
`{liquid_class_id -> LiquidClassRecords}`, but following the convention
for the other fields in the `StateSummary`, we want to export the liquid
classes as a list, so this PR defines a new `LiquidClassRecordWithId`
class for the summary.

The fields in the `StateSummary` in turn are propagated to the CLI
`AnalyzeResults`, and are mirrored to the robot-server
`CompletedAnalysis`, `Run`, and `MaintenanceRun` models. So every
call-site that uses those classes had to be updated, as well as every
test that checks those classes, as well as 200 snapshot tests -- which
was kind of painful.

## Test Plan and Hands on Testing

I'm relying on the CI tests to make sure I found all the call-sites that
are affected.

(We don't yet have any protocols that load liquid classes, but when we
do, we can probably add integration tests to show that the liquid
classes end up in the summaries.)

## Review requests

I recommend collapsing the `analyses-snapshot-testing/` when looking at
this PR in Github. There are so many snapshot changes that Github
sometimes errors out when trying to render the diff.

The primary files with code changes are:
- `api/src/opentrons/protocol_engine/types.py`
- `api/src/opentrons/protocol_engine/state/state.py`
- `api/src/opentrons/protocol_engine/state/state_summary.py`
- `api/src/opentrons/cli/analyze.py`
- `robot-server/robot_server/runs/run_models.py`
- `robot-server/robot_server/protocols/analysis_models.py`
- `robot-server/robot_server/maintenance_runs/maintenance_run_models.py`

The other files are pretty mechanical changes.

## Risk assessment

Low risk, should affect dev only.

---------

Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Co-authored-by: y3rsh <[email protected]>
Add hover state and fix border radius for EmptySelectorButton component

Closes RQA-3659
…16939)

* fix(protocol-designer): fix Incorrect copy in IncompatibleTipsModal
… tag (#16938)

* fix(protocol-designer): switch back textarea from component to styled tag
…onent and StyledLabel (#16942)

Fix enabled and hover state background color for both checked and
unchecked states of Checkbox component, and add hover state for
StyledLabel one-off in SelectPipettes component.

Closes RQA-3655
<!--
Thanks for taking the time to open a Pull Request (PR)! Please make sure
you've read the "Opening Pull Requests" section of our Contributing
Guide:


https://github.com/Opentrons/opentrons/blob/edge/CONTRIBUTING.md#opening-pull-requests

GitHub provides robust markdown to format your PR. Links, diagrams,
pictures, and videos along with text formatting make it possible to
create a rich and informative PR. For more information on GitHub
markdown, see:


https://docs.github.com/en/get-started/writing-on-github/getting-started-with-writing-and-formatting-on-github/basic-writing-and-formatting-syntax

To ensure your code is reviewed quickly and thoroughly, please fill out
the sections below to the best of your ability!
-->

# Overview
Add an option for skipping pressure, we won't actually need this
apparently since they changed their mind about skipping the step of
drilling out the back vent of the diaphragm but if they change that in
the future we can use this.
<!--
Describe your PR at a high level. State acceptance criteria and how this
PR fits into other work. Link issues, PRs, and other relevant resources.
-->

## Test Plan and Hands on Testing

<!--
Describe your testing of the PR. Emphasize testing not reflected in the
code. Attach protocols, logs, screenshots and any other assets that
support your testing.
-->

## Changelog

<!--
List changes introduced by this PR considering future developers and the
end user. Give careful thought and clear documentation to breaking
changes.
-->

## Review requests

<!--
- What do you need from reviewers to feel confident this PR is ready to
merge?
- Ask questions.
-->

## Risk assessment

<!--
- Indicate the level of attention this PR needs.
- Provide context to guide reviewers.
- Discuss trade-offs, coupling, and side effects.
- Look for the possibility, even if you think it's small, that your
change may affect some other part of the system.
- For instance, changing return tip behavior may also change the
behavior of labware calibration.
- How do your unit tests and on hands on testing mitigate this PR's
risks and the risk of future regressions?
- Especially in high risk PRs, explain how you know your testing is
enough.
-->
<!--
Thanks for taking the time to open a Pull Request (PR)! Please make sure
you've read the "Opening Pull Requests" section of our Contributing
Guide:


https://github.com/Opentrons/opentrons/blob/edge/CONTRIBUTING.md#opening-pull-requests

GitHub provides robust markdown to format your PR. Links, diagrams,
pictures, and videos along with text formatting make it possible to
create a rich and informative PR. For more information on GitHub
markdown, see:


https://docs.github.com/en/get-started/writing-on-github/getting-started-with-writing-and-formatting-on-github/basic-writing-and-formatting-syntax

To ensure your code is reviewed quickly and thoroughly, please fill out
the sections below to the best of your ability!
-->

# Overview

Adds protocol that uses tartrazine and takes plate reader measurements

## Test Plan and Hands on Testing

- passed simulate test and runs on robot

## Changelog

- removed OT3 ABR Normalize with Tubes protocol
- added plate reader + tartrazine protocol

## Review requests

<!--
- What do you need from reviewers to feel confident this PR is ready to
merge?
- Ask questions.
-->

## Risk assessment

<!--
- Indicate the level of attention this PR needs.
- Provide context to guide reviewers.
- Discuss trade-offs, coupling, and side effects.
- Look for the possibility, even if you think it's small, that your
change may affect some other part of the system.
- For instance, changing return tip behavior may also change the
behavior of labware calibration.
- How do your unit tests and on hands on testing mitigate this PR's
risks and the risk of future regressions?
- Especially in high risk PRs, explain how you know your testing is
enough.
-->

---------

Co-authored-by: CaseyBatten <[email protected]>
Selectively ignore or otherwise fix all Decoy related warnings in api tests
Resolve conflicts in:
* api/src/opentrons/hardware_control/ot3api.py
* api/src/opentrons/protocol_engine/commands/drop_tip.py
…update settings page to match design (#16937)

fix RQA-3656, RQA-3650
<!--
Thanks for taking the time to open a Pull Request (PR)! Please make sure
you've read the "Opening Pull Requests" section of our Contributing
Guide:


https://github.com/Opentrons/opentrons/blob/edge/CONTRIBUTING.md#opening-pull-requests

GitHub provides robust markdown to format your PR. Links, diagrams,
pictures, and videos along with text formatting make it possible to
create a rich and informative PR. For more information on GitHub
markdown, see:


https://docs.github.com/en/get-started/writing-on-github/getting-started-with-writing-and-formatting-on-github/basic-writing-and-formatting-syntax

To ensure your code is reviewed quickly and thoroughly, please fill out
the sections below to the best of your ability!
-->

# Overview

<!--
Describe your PR at a high level. State acceptance criteria and how this
PR fits into other work. Link issues, PRs, and other relevant resources.
-->

1. updated copy of incompatible file type modal to match with design
2. updated `Settings` to match with design

## Test Plan and Hands on Testing

<!--
Describe your testing of the PR. Emphasize testing not reflected in the
code. Attach protocols, logs, screenshots and any other assets that
support your testing.
-->

## Changelog

<!--
List changes introduced by this PR considering future developers and the
end user. Give careful thought and clear documentation to breaking
changes.
-->

## Review requests

<!--
- What do you need from reviewers to feel confident this PR is ready to
merge?
- Ask questions.
-->

## Risk assessment

<!--
- Indicate the level of attention this PR needs.
- Provide context to guide reviewers.
- Discuss trade-offs, coupling, and side effects.
- Look for the possibility, even if you think it's small, that your
change may affect some other part of the system.
- For instance, changing return tip behavior may also change the
behavior of labware calibration.
- How do your unit tests and on hands on testing mitigate this PR's
risks and the risk of future regressions?
- Especially in high risk PRs, explain how you know your testing is
enough.
-->

---------

Co-authored-by: shiyaochen <[email protected]>
Co-authored-by: shiyaochen <[email protected]>
For both mix and move liquid batch edit toolboxes, fix padding for each
field

Closes RQA-3679
This fixes a case where in batch edit move liquid toolbox, well order
was set to null, displaying an
unknown translation in the WellOrder component. This PR refactors the
util used to set the first and
second well order values, providing a fallback if the value is null.
Closes EXEC-1027

After completing a run or during Error Recovery, the app runs tip detection logic to determine whether or not to pop the drop tip wizard. It does so by iterating through protocol analysis, keeping track of attached pipettes, and looking at specific tip exchange commands to determine whether a not a pipette has tips attached. While this approach works, it's both brittle (any changes to tip exchange commands breaks the logic) and also a command scanning operation.

Now that we have tip status on our new /runs/:runId/currentState endpoint, we have a more robust option for determining tip status. There's one caveat: the robot and this util do have ideas of when a tip should be considered attached. On the app, because we want to show drop tip wizard when there might be a tip attached, such as during a failed pick up tip command, we assume there is a tip attached. In this instance however, the robot server does not think a tip is attached. Unfortunately, there's no way around manually accounting for these differences, but luckily they are few, and it's still a significant improvement over tracking every tip exchange command.

There's another optimization we can make too: we don't actually need to poll /instruments for pipette data, because now, the only place we use that data is during the tip detection util. Instead, we can fetch it along with the other necessary resources when determineTipStatus is invoked.

In short, these changes give us:

* Much easier to reason about tip detection logic.
* Significantly less brittle.
* No command scanning.
* No /instruments polling.
sfoster1 and others added 5 commits January 7, 2025 16:47
We pipe errors from nmcli straight to the display when we get them.
NMCLI has famously awful errors. We don't want to always squash them,
because they could be useful, but in the case of a mis-entered WPA2 PSK,
we can be pretty sure that's the problem.

This will now say "check your wifi credentials" 
<img width="607" alt="Screenshot 2025-01-07 at 4 46 15 PM"
src="https://github.com/user-attachments/assets/d9006f01-37e8-4221-812a-900ffcb61960"
/>


## Testing
- [x] Connect to a wifi network and purposefully enter the wrong
password; you should get a less awful message. Note that this only
actually works if you're disconnected from wifi when you try to connect;
if you're connected to wifi and then try and connect to a network and
use the wrong password, you just don't get a result because the request
went out over the original wifi network which got disconnected.

It's the same code on the flex, ot-2 on the desktop (the ODD has a
different message).
Closes RSQ-3
…ids (#17195)

Covers RQA-3819
Adds in missing valid labware parents for the TC lid
Fix a flaky test by running filesystem commands sequentially instead of in parallel.
This is very odd and I'm not sure when it would have changed but this is
the thing the error message says to do.

## Testing
- [x] does the apple build work
- [x] does the apple build run
…rotocol (#17216)

<!--
Thanks for taking the time to open a Pull Request (PR)! Please make sure
you've read the "Opening Pull Requests" section of our Contributing
Guide:


https://github.com/Opentrons/opentrons/blob/edge/CONTRIBUTING.md#opening-pull-requests

GitHub provides robust markdown to format your PR. Links, diagrams,
pictures, and videos along with text formatting make it possible to
create a rich and informative PR. For more information on GitHub
markdown, see:


https://docs.github.com/en/get-started/writing-on-github/getting-started-with-writing-and-formatting-on-github/basic-writing-and-formatting-syntax

To ensure your code is reviewed quickly and thoroughly, please fill out
the sections below to the best of your ability!
-->

# Overview

We're doing a direct "load_definintion" call in this protocol so we need
to update it to have the new OEM arg added in 8.3
<!--
Describe your PR at a high level. State acceptance criteria and how this
PR fits into other work. Link issues, PRs, and other relevant resources.
-->

## Test Plan and Hands on Testing

<!--
Describe your testing of the PR. Emphasize testing not reflected in the
code. Attach protocols, logs, screenshots and any other assets that
support your testing.
-->

## Changelog

<!--
List changes introduced by this PR considering future developers and the
end user. Give careful thought and clear documentation to breaking
changes.
-->

## Review requests

<!--
- What do you need from reviewers to feel confident this PR is ready to
merge?
- Ask questions.
-->

## Risk assessment

<!--
- Indicate the level of attention this PR needs.
- Provide context to guide reviewers.
- Discuss trade-offs, coupling, and side effects.
- Look for the possibility, even if you think it's small, that your
change may affect some other part of the system.
- For instance, changing return tip behavior may also change the
behavior of labware calibration.
- How do your unit tests and on hands on testing mitigate this PR's
risks and the risk of future regressions?
- Especially in high risk PRs, explain how you know your testing is
enough.
-->
Copy link

codecov bot commented Jan 8, 2025

Codecov Report

All modified and coverable lines are covered by tests ✅

Project coverage is 68.03%. Comparing base (9d9c360) to head (63cba42).
Report is 573 commits behind head on release.

Additional details and impacted files

Impacted file tree graph

@@             Coverage Diff             @@
##           release   #17186      +/-   ##
===========================================
+ Coverage    63.28%   68.03%   +4.75%     
===========================================
  Files          300       75     -225     
  Lines        15786     4965   -10821     
===========================================
- Hits          9990     3378    -6612     
+ Misses        5796     1587    -4209     
Flag Coverage Δ
g-code-testing ?
hardware ?
shared-data 74.08% <ø> (+0.75%) ⬆️
system-server ?

Flags with carried forward coverage won't be shown. Click here to find out more.

see 248 files with indirect coverage changes

mjhuff and others added 24 commits January 8, 2025 14:40
Came up for PD ( #17229 ), probably will come up here too. Let's get
ahead of it. If the build passes this should be fine.
… can errors (#17117)

<!--
Thanks for taking the time to open a Pull Request (PR)! Please make sure
you've read the "Opening Pull Requests" section of our Contributing
Guide:


https://github.com/Opentrons/opentrons/blob/edge/CONTRIBUTING.md#opening-pull-requests

GitHub provides robust markdown to format your PR. Links, diagrams,
pictures, and videos along with text formatting make it possible to
create a rich and informative PR. For more information on GitHub
markdown, see:


https://docs.github.com/en/get-started/writing-on-github/getting-started-with-writing-and-formatting-on-github/basic-writing-and-formatting-syntax

To ensure your code is reviewed quickly and thoroughly, please fill out
the sections below to the best of your ability!
-->

# Overview

We occasionally get some ABR issues where the can bus says it's not
receiving ACKs or that a move group says it didn't get all expected
nodes, but reports [] as the missing nodes.

I think the second bug is because we're checking with `if not
self._moves[group_id]` instead of checking `if
len(self._moves[group_id]) == 0:` Which should be equivalent but I think
there may be some python cleanup bug that reports the list as true due
to a remnant that hasn't been garbage collected yet.
<!--
Describe your PR at a high level. State acceptance criteria and how this
PR fits into other work. Link issues, PRs, and other relevant resources.
-->

## Test Plan and Hands on Testing

<!--
Describe your testing of the PR. Emphasize testing not reflected in the
code. Attach protocols, logs, screenshots and any other assets that
support your testing.
-->

## Changelog

<!--
List changes introduced by this PR considering future developers and the
end user. Give careful thought and clear documentation to breaking
changes.
-->

## Review requests

<!--
- What do you need from reviewers to feel confident this PR is ready to
merge?
- Ask questions.
-->

## Risk assessment

<!--
- Indicate the level of attention this PR needs.
- Provide context to guide reviewers.
- Discuss trade-offs, coupling, and side effects.
- Look for the possibility, even if you think it's small, that your
change may affect some other part of the system.
- For instance, changing return tip behavior may also change the
behavior of labware calibration.
- How do your unit tests and on hands on testing mitigate this PR's
risks and the risk of future regressions?
- Especially in high risk PRs, explain how you know your testing is
enough.
-->
…ed (#17264)

robot-server sometimes stores, in its database, run commands that do not
have a `result`. For example, if a command failed, it has an `error`
instead of a `result`.

After the recent Pydantic v1->v2 upgrade, parsing these commands was
broken for about 1/3rd of our command types. The server would raise a
500 error. Their Pydantic models were defined like:

```
result: Optional[FooResult]
```

In Pydantic v1, that parses JSON where `result` is `null` or omitted,
but in Pydantic v2, it only parses JSON where `result` is `null`. We
need to change it to:

```
result: Optional[FooResult] = None
```
…ok" (#17261)

Closes RQA-3851

When protocol cards have not ok run data, we can't retrieve the completedAt timestamp, and the fallback has been the current date, which is confusing copy. After speaking with Design, the plan is to remove copy if we can't retrieve the completedAt timestamp.
This is used by the client to decide whether something is a lot when
it's rendering destinations, and if this doesn't exist then intervention
modals will show the labware moving off deck.

Closes RQA-3839
Closes RQA-3870 and RQA-3871

Brings the stall/collision recovery flow in-line with designs. See the tickets for details and fixes.
…ction (#17316)

This commit brings the `lastRunCommandPromptedErrorRecovery` util back and adds the new and improved behavior to also check if Error Recovery is enabled (in settings). If it's not enabled, we need to run tip detection even if the last run command was recoverable.
- the takeover modal for maintenance runs (RQA-3868)
- run start confirmation (not tagged yet)
- run cancel confirmation (RQA-3869)

Closes RQA-3868
Closes RQA-3869

<img width="1046" alt="Screenshot 2025-01-17 at 4 58 05 PM"
src="https://github.com/user-attachments/assets/66d00f4a-5e49-4f34-8049-ae74051f710e"
/>
<img width="1037" alt="Screenshot 2025-01-17 at 4 58 40 PM"
src="https://github.com/user-attachments/assets/b39ef8b7-77aa-4cfe-8452-e447e439460b"
/>
<img width="1035" alt="Screenshot 2025-01-17 at 5 05 22 PM"
src="https://github.com/user-attachments/assets/ffb47a09-0f02-4b26-b4e4-54fa43d7865c"
/>
That PR changed the stop behavior on OT-2 to fix some bugs but the tests
didn't get changed. Fix the tests.
<!--
Thanks for taking the time to open a Pull Request (PR)! Please make sure
you've read the "Opening Pull Requests" section of our Contributing
Guide:


https://github.com/Opentrons/opentrons/blob/edge/CONTRIBUTING.md#opening-pull-requests

GitHub provides robust markdown to format your PR. Links, diagrams,
pictures, and videos along with text formatting make it possible to
create a rich and informative PR. For more information on GitHub
markdown, see:


https://docs.github.com/en/get-started/writing-on-github/getting-started-with-writing-and-formatting-on-github/basic-writing-and-formatting-syntax

To ensure your code is reviewed quickly and thoroughly, please fill out
the sections below to the best of your ability!
-->

# Overview
This just copies the updated well geometry definitions from edge over to
chore_release.
<!--
Describe your PR at a high level. State acceptance criteria and how this
PR fits into other work. Link issues, PRs, and other relevant resources.
-->

## Test Plan and Hands on Testing

<!--
Describe your testing of the PR. Emphasize testing not reflected in the
code. Attach protocols, logs, screenshots and any other assets that
support your testing.
-->

## Changelog

<!--
List changes introduced by this PR considering future developers and the
end user. Give careful thought and clear documentation to breaking
changes.
-->

## Review requests

<!--
- What do you need from reviewers to feel confident this PR is ready to
merge?
- Ask questions.
-->

## Risk assessment

<!--
- Indicate the level of attention this PR needs.
- Provide context to guide reviewers.
- Discuss trade-offs, coupling, and side effects.
- Look for the possibility, even if you think it's small, that your
change may affect some other part of the system.
- For instance, changing return tip behavior may also change the
behavior of labware calibration.
- How do your unit tests and on hands on testing mitigate this PR's
risks and the risk of future regressions?
- Especially in high risk PRs, explain how you know your testing is
enough.
-->

Co-authored-by: Caila Marashaj <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
DO NOT MERGE Indicates a PR should not be merged, even if there's a shiny green merge button available
Projects
None yet
Development

Successfully merging this pull request may close these issues.