Control the Cloud C++ client library behavior with respect to polling on long running operations.
Some operations in Cloud services return a google.longrunning.Operation object. As their name implies, these objects represent requests that may take a long time to complete, in some cases operations may take tens of seconds or even 30 minutes to complete.
The Cloud C++ client libraries models these long running operations as a google::cloud::future<StatusOr<T>>, where T represents the final result of the operation. In the background, the library polls the service until the operation completes (or fails) and then satisfies the future.
This class defines the interface for policies that control the behavior of this polling loop.
This function is called at the beginning of the polling loop. Policies that are based on relative time should restart their timers when this function is called.
Returns
Type
Description
std::unique_ptr< PollingPolicy >
OnFailure
A callback to indicate that a polling attempt failed.
This is called when a polling request fails. Note that this callback is not invoked when the polling request succeeds with "operation not done".
Parameter
Name
Description
status
Status const &
Returns
Type
Description
bool
true if the failure should be treated as transient and the polling loop should continue.
WaitPeriod
How long should the polling loop wait before trying again.
[[["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-03-05 UTC."],[[["The webpage documents different versions of the `PollingPolicy` class in the Google Cloud C++ client library, ranging from version 2.10.1 to the latest release candidate 2.37.0-rc."],["The `PollingPolicy` class manages the polling behavior for long-running operations in Cloud services that may take a while to complete, represented by `google.longrunning.Operation` objects."],["This class uses `google::cloud::future\u003cStatusOr\u003cT\u003e\u003e` to model long running operations, polling the service until the operation completes or fails."],["The `PollingPolicy` interface includes functions like `clone`, `OnFailure`, and `WaitPeriod` to customize how the library manages retries and timing during polling loops."],["`OnFailure` callback is invoked when a polling request fails, allowing determination of whether the failure should be treated as transient, while `WaitPeriod` determines how long the polling loop should wait between attempts."]]],[]]