The marker exception thrown when a timeout is exceeded.
This error can be thrown under 2 circumstances:
A wait timeout has exceeded, which means that the client timed out waiting for the next
message from the server. In this case, #isRetryable() will be true.
An idle timeout has exceeded, which means that the stream is using manual flow control and
the caller has not called StreamController#request(int) (in case of callback api)
or next on ServerStream#iterator() (in case of blocking api).
[[["Easy to understand","easyToUnderstand","thumb-up"],["Solved my problem","solvedMyProblem","thumb-up"],["Other","otherUp","thumb-up"]],[["Hard to understand","hardToUnderstand","thumb-down"],["Incorrect information or sample code","incorrectInformationOrSampleCode","thumb-down"],["Missing the information/samples I need","missingTheInformationSamplesINeed","thumb-down"],["Other","otherDown","thumb-down"]],["Last updated 2025-04-02 UTC."],[[["The `WatchdogTimeoutException` is a marker exception that occurs when a timeout is exceeded, specifically related to waiting for a message from the server or due to idle timeout with manual flow control."],["This exception can arise from either a wait timeout, where the client is waiting for a server message, or an idle timeout, when manual flow control is in use and the appropriate method hasn't been called."],["The `isRetryable()` method on `WatchdogTimeoutException` will return true in the case of a wait timeout, indicating that a retry might be appropriate."],["The documentation provides a comprehensive history of versions for `WatchdogTimeoutException`, ranging from version 2.63.1 down to version 2.7.1."],["This class extends `ApiException`, inheriting methods like `getStatusCode()` and `isRetryable()`, and it includes a static field `LOCAL_ABORTED_STATUS_CODE` of type `StatusCode`."]]],[]]