InvokeAI/invokeai/app/services/session_processor
psychedelicious 50dd569411 fix(processor): race condition that could result in node errors not getting reported
I had set the cancel event at some point during troubleshooting an unrelated issue. It seemed logical that it should be set there, and didn't seem to break anything. However, this is not correct.

The cancel event should not be set in response to a queue status change event. Doing so can cause a race condition when nodes are executed very quickly.

It's possible that a previously-executed session's queue item status change event is handled after the next session starts executing. The cancel event is set and the session runner sees it aborting the session run early.

In hindsight, it doesn't make sense to set the cancel event here either. It should be set in response to user action, e.g. the user cancelled the session or cleared the queue (which implicitly cancels the current session). These events actually trigger the queue item status changed event, so if we set the cancel event here, we'd be setting it twice per cancellation.
2024-05-24 20:02:24 +10:00
..
__init__.py feat: queued generation (#4502) 2023-09-20 15:09:24 +10:00
session_processor_base.py docs(processor): update docstrings, comments 2024-05-24 20:02:24 +10:00
session_processor_common.py refactor(nodes): merge processors 2024-03-01 10:42:33 +11:00
session_processor_default.py fix(processor): race condition that could result in node errors not getting reported 2024-05-24 20:02:24 +10:00