diff --git a/src/Polly/Wrap/IAsyncPolicyPolicyWrapExtensions.cs b/src/Polly/Wrap/IAsyncPolicyPolicyWrapExtensions.cs index 74a113e9cde..8700a14b6aa 100644 --- a/src/Polly/Wrap/IAsyncPolicyPolicyWrapExtensions.cs +++ b/src/Polly/Wrap/IAsyncPolicyPolicyWrapExtensions.cs @@ -3,7 +3,6 @@ /// /// Defines extensions for configuring instances on an or . /// -#pragma warning disable CA1062 // Validate arguments of public methods public static class IAsyncPolicyPolicyWrapExtensions { /// @@ -159,13 +158,20 @@ public partial class Policy /// The policies to place in the wrap, outermost (at left) to innermost (at right). /// The PolicyWrap. /// The enumerable of policies to form the wrap must contain at least two policies. - public static AsyncPolicyWrap WrapAsync(params IAsyncPolicy[] policies) => - policies.Length switch + public static AsyncPolicyWrap WrapAsync(params IAsyncPolicy[] policies) + { + if (policies is null) + { + throw new ArgumentNullException(nameof(policies)); + } + + return policies.Length switch { < MinimumPoliciesRequiredForWrap => throw new ArgumentException("The enumerable of policies to form the wrap must contain at least two policies.", nameof(policies)), MinimumPoliciesRequiredForWrap => new AsyncPolicyWrap((AsyncPolicy)policies[0], policies[1]), _ => WrapAsync(policies[0], WrapAsync(policies.Skip(1).ToArray())), }; + } /// /// Creates a of the given policies governing delegates returning values of type . @@ -174,11 +180,18 @@ public static AsyncPolicyWrap WrapAsync(params IAsyncPolicy[] policies) => /// The return type of delegates which may be executed through the policy. /// The PolicyWrap. /// The enumerable of policies to form the wrap must contain at least two policies. - public static AsyncPolicyWrap WrapAsync(params IAsyncPolicy[] policies) => - policies.Length switch + public static AsyncPolicyWrap WrapAsync(params IAsyncPolicy[] policies) + { + if (policies is null) + { + throw new ArgumentNullException(nameof(policies)); + } + + return policies.Length switch { < MinimumPoliciesRequiredForWrap => throw new ArgumentException("The enumerable of policies to form the wrap must contain at least two policies.", nameof(policies)), MinimumPoliciesRequiredForWrap => new AsyncPolicyWrap((AsyncPolicy)policies[0], policies[1]), _ => WrapAsync(policies[0], WrapAsync(policies.Skip(1).ToArray())), }; + } } diff --git a/test/Polly.Specs/Caching/CacheAsyncSpecs.cs b/test/Polly.Specs/Caching/CacheAsyncSpecs.cs index 92314aec7c3..fd2b12783f3 100644 --- a/test/Polly.Specs/Caching/CacheAsyncSpecs.cs +++ b/test/Polly.Specs/Caching/CacheAsyncSpecs.cs @@ -31,6 +31,18 @@ public void Should_throw_when_cache_key_strategy_is_null() action.Should().Throw().And.ParamName.Should().Be("cacheKeyStrategy"); } + [Fact] + public void Should_throw_when_policies_is_null() + { + IAsyncPolicy[] policies = null!; + IAsyncPolicy[] policiesGeneric = null!; + + Action action = () => Policy.WrapAsync(policies); + action.Should().Throw().And.ParamName.Should().Be("policies"); + + action = () => Policy.WrapAsync(policiesGeneric); + action.Should().Throw().And.ParamName.Should().Be("policies"); + } #endregion #region Caching behaviours