From 27d5404cda92577d4f380d84e1a358ddd0fee81a Mon Sep 17 00:00:00 2001 From: hilcj Date: Wed, 20 Apr 2022 13:47:54 -0700 Subject: [PATCH] feat(api): Update IR with RetryPolicy (#7581) --- api/v2alpha1/pipeline_spec.proto | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) diff --git a/api/v2alpha1/pipeline_spec.proto b/api/v2alpha1/pipeline_spec.proto index 1e6bf932201..c5c8f45f7f7 100644 --- a/api/v2alpha1/pipeline_spec.proto +++ b/api/v2alpha1/pipeline_spec.proto @@ -484,6 +484,29 @@ message PipelineTaskSpec { // Iterator to iterate over a parameter input. ParameterIteratorSpec parameter_iterator = 10; } + + // User-configured task-level retry. + message RetryPolicy { + // Number of retries before considering a task as failed. Set to 0 or + // unspecified to disallow retry." + int32 max_retry_count = 1; + + // The time interval between retries. Defaults to zero (an immediate retry). + google.protobuf.Duration backoff_duration = 2; + + // The exponential backoff factor applied to backoff_duration. If + // unspecified, will default to 2. + double backoff_factor = 3; + + // The maximum duration during which the task will be retried according to + // the backoff strategy. Max allowed is 1 hour - higher value will be capped + // to this limit. If unspecified, will set to 1 hour. + google.protobuf.Duration backoff_max_duration = 4; + } + + // User-configured task-level retry. + // Applicable only to component tasks. + RetryPolicy retry_policy = 11; } // The spec of an artifact iterator. It supports fan-out a workflow from a list