Skip to content

Commit

Permalink
Update retry policy validation with additional conditions (cadence-wo…
Browse files Browse the repository at this point in the history
  • Loading branch information
sankari165 authored Nov 27, 2024
1 parent f799577 commit 1fcd7d5
Show file tree
Hide file tree
Showing 2 changed files with 28 additions and 10 deletions.
6 changes: 6 additions & 0 deletions common/util.go
Original file line number Diff line number Diff line change
Expand Up @@ -547,6 +547,12 @@ func ValidateRetryPolicy(policy *types.RetryPolicy) error {
if policy.GetMaximumAttempts() == 0 && policy.GetExpirationIntervalInSeconds() == 0 {
return &types.BadRequestError{Message: "MaximumAttempts and ExpirationIntervalInSeconds are both 0. At least one of them must be specified."}
}
if policy.GetExpirationIntervalInSeconds() == 0 && policy.GetMaximumAttempts() == 1 {
return &types.BadRequestError{Message: "MaximumAttempts set to 1 will not retry since maximum attempts includes the first attempt."}
}
if policy.GetMaximumAttempts() == 0 && policy.GetExpirationIntervalInSeconds() < policy.GetInitialIntervalInSeconds() {
return &types.BadRequestError{Message: "ExpirationIntervalInSeconds less than InitialIntervalInSeconds will not retry."}
}
return nil
}

Expand Down
32 changes: 22 additions & 10 deletions common/util_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -718,29 +718,22 @@ func TestValidateRetryPolicy_Success(t *testing.T) {
InitialIntervalInSeconds: 2,
BackoffCoefficient: 1,
MaximumIntervalInSeconds: 0,
MaximumAttempts: 1,
MaximumAttempts: 2,
ExpirationIntervalInSeconds: 0,
},
"ExpirationIntervalInSeconds is no zero": &types.RetryPolicy{
InitialIntervalInSeconds: 2,
BackoffCoefficient: 1,
MaximumIntervalInSeconds: 0,
MaximumAttempts: 0,
ExpirationIntervalInSeconds: 1,
ExpirationIntervalInSeconds: 3,
},
"MaximumIntervalInSeconds is greater than InitialIntervalInSeconds": &types.RetryPolicy{
InitialIntervalInSeconds: 2,
BackoffCoefficient: 1,
MaximumIntervalInSeconds: 0,
MaximumAttempts: 0,
ExpirationIntervalInSeconds: 1,
},
"MaximumIntervalInSeconds equals InitialIntervalInSeconds": &types.RetryPolicy{
InitialIntervalInSeconds: 2,
BackoffCoefficient: 1,
MaximumIntervalInSeconds: 2,
MaximumAttempts: 0,
ExpirationIntervalInSeconds: 1,
ExpirationIntervalInSeconds: 3,
},
} {
t.Run(name, func(t *testing.T) {
Expand Down Expand Up @@ -798,6 +791,25 @@ func TestValidateRetryPolicy_Error(t *testing.T) {
},
wantErr: &types.BadRequestError{Message: "MaximumAttempts cannot be less than 0 on retry policy."},
},
"MaximumAttempts equals 1": {
policy: &types.RetryPolicy{
InitialIntervalInSeconds: 2,
BackoffCoefficient: 1,
MaximumIntervalInSeconds: 0,
MaximumAttempts: 1,
},
wantErr: &types.BadRequestError{Message: "MaximumAttempts set to 1 will not retry since maximum attempts includes the first attempt."},
},
"ExpirationIntervalInSeconds less than InitialIntervalInSeconds": {
policy: &types.RetryPolicy{
InitialIntervalInSeconds: 2,
BackoffCoefficient: 1,
MaximumIntervalInSeconds: 0,
MaximumAttempts: 0,
ExpirationIntervalInSeconds: 1,
},
wantErr: &types.BadRequestError{Message: "ExpirationIntervalInSeconds less than InitialIntervalInSeconds will not retry."},
},
"ExpirationIntervalInSeconds equals -1": {
policy: &types.RetryPolicy{
InitialIntervalInSeconds: 2,
Expand Down

0 comments on commit 1fcd7d5

Please sign in to comment.