fix(app): Fix persistent "run in progress" settings banner after run cancel #17235
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Closes RQA-3838
Overview
This PR addresses the underlying issue of the run not un-currenting when expected. This issue manifests in three separate bugs that have been a part of relatively recent refactors.
Cancelling a Run before Run Start
40d08aa
We implicitly close the run context if the run has been cancelled, and no tips are confirmed to be attached. Additionally, if you cancel a run before starting the run, no run commands have occurred.
On the desktop app, the tip detection logic currently runs only if there has been at least one command, meaning that we never implicitly close the run context when canceling a run before starting it. This results in the run always being current, which results in the bug mentioned in the ticket.
This "check the commands" logic is a holdover from when tip detection actually used the protocol record to do tip detection, which we removed after 8.2 now that we use the
currentState
endpoint for tip detection. This could should have been removed along with that refactor.Disabling Error Recovery in App Settings
9b10793
Doing so does not properly invoke the post-run tip detection logic, which is dependent on whether the run has entered error recovery. The
lastRunCommandPromptedErrorRecovery
is not a sufficient check for this condition, because the user can disable error recovery in settings, and this utility only looks at the previous non-fixit command.After giving the tip detection gating more thought: gating tip detection logic is no longer a hard requirement, because the app isn't doing any expensive compute like it did 8.2 and earlier. Simplifying the tip detection logic comes with the reasonable tradeoff of running a few network requests once post-run. That seems ok.
/runCommandErrors
Refactors4eb337b
Because the endpoint now supports historical errors, we can now implicitly uncurrent cancelled runs that have undergone error recovery and don't have tips attached and preserve the banner.
Test Plan and Hands on Testing
chore_release
, start protocol setup and then cancel the run (on the desktop app). Note on the robot settings page that the "run in progress" banner is present.Changelog
Risk assessment
low