Skip to main content
Whenever messages are stored in Honcho, a background process kicks off to reason about the conversation and generate insights. Reasoning is an asynchronous process and, depending on load, may not immediately generate insights for the latest message you’ve sent. To help with this, Honcho provides several utilities to check the status of the queue.
from honcho import Honcho
honcho = Honcho()

status = honcho.get_queue_status()
honcho.poll_queue_status()
Output types
class QueueStatus(BaseModel):
    completed_work_units: int
    """Completed work units"""

    in_progress_work_units: int
    """Work units currently being processed"""

    pending_work_units: int
    """Work units waiting to be processed"""

    total_work_units: int
    """Total work units"""

    sessions: Optional[Dict[str, Sessions]] = None
    """Per-session status when not filtered by session"""
Whenever a message is sent it will generate several tasks. These could be tasks such as generating insights, cleaning up a representation, summarizing a conversation etc. These tasks are defined based on who is sending the message, what session the message is in, and potentially who is observing the message. We call the combination of these parameters a work_unit This has a few different implications.
  • tasks within the same work_unit are processed sequentially, but multiple work_units will be processed in parallel
  • If local representations are turned in a Session then a message will generate an additional work unit for every peer that has observe_others=True
The get_queue_status and poll_queue_status methods can take additional parameters to scope the status to a specific work unit
def get_queue_status(
        self,
        observer_id: str | None = None,
        sender_id: str | None = None,
        session_id: str | None = None,
    ) -> QueueStatus:
Additionally, there are queue status and polling queue status methods available on the session objects in each of the SDKs. Below are the function signatures for the session level queue status method
@validate_call
    def get_queue_status(
        self,
        observer_id: str | None = None,
        sender_id: str | None = None,
    ) -> QueueStatus: