ClientRPCExecutionConfigurationCollectionTests.swift 3.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. /*
  2. * Copyright 2023, gRPC Authors All rights reserved.
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License");
  5. * you may not use this file except in compliance with the License.
  6. * You may obtain a copy of the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS,
  12. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. * See the License for the specific language governing permissions and
  14. * limitations under the License.
  15. */
  16. import GRPCCore
  17. import XCTest
  18. @available(macOS 13.0, iOS 16.0, watchOS 9.0, tvOS 16.0, *)
  19. final class ClientRPCExecutionConfigurationCollectionTests: XCTestCase {
  20. func testGetConfigurationForKnownMethod() {
  21. let policy = HedgingPolicy(
  22. maximumAttempts: 10,
  23. hedgingDelay: .seconds(1),
  24. nonFatalStatusCodes: []
  25. )
  26. let defaultConfiguration = ClientRPCExecutionConfiguration(hedgingPolicy: policy)
  27. var configurations = ClientRPCExecutionConfigurationCollection(
  28. defaultConfiguration: defaultConfiguration
  29. )
  30. let descriptor = MethodDescriptor(service: "test", method: "first")
  31. let retryPolicy = RetryPolicy(
  32. maximumAttempts: 10,
  33. initialBackoff: .seconds(1),
  34. maximumBackoff: .seconds(1),
  35. backoffMultiplier: 1.0,
  36. retryableStatusCodes: [.unavailable]
  37. )
  38. let overrideConfiguration = ClientRPCExecutionConfiguration(retryPolicy: retryPolicy)
  39. configurations[descriptor] = overrideConfiguration
  40. XCTAssertEqual(configurations[descriptor], overrideConfiguration)
  41. }
  42. func testGetConfigurationForUnknownMethodButServiceOverride() {
  43. let policy = HedgingPolicy(
  44. maximumAttempts: 10,
  45. hedgingDelay: .seconds(1),
  46. nonFatalStatusCodes: []
  47. )
  48. let defaultConfiguration = ClientRPCExecutionConfiguration(hedgingPolicy: policy)
  49. var configurations = ClientRPCExecutionConfigurationCollection(
  50. defaultConfiguration: defaultConfiguration
  51. )
  52. let firstDescriptor = MethodDescriptor(service: "test", method: "")
  53. let retryPolicy = RetryPolicy(
  54. maximumAttempts: 10,
  55. initialBackoff: .seconds(1),
  56. maximumBackoff: .seconds(1),
  57. backoffMultiplier: 1.0,
  58. retryableStatusCodes: [.unavailable]
  59. )
  60. let overrideConfiguration = ClientRPCExecutionConfiguration(retryPolicy: retryPolicy)
  61. configurations[firstDescriptor] = overrideConfiguration
  62. let secondDescriptor = MethodDescriptor(service: "test", method: "second")
  63. XCTAssertEqual(configurations[secondDescriptor], overrideConfiguration)
  64. }
  65. func testGetConfigurationForUnknownMethodDefaultValue() {
  66. let policy = HedgingPolicy(
  67. maximumAttempts: 10,
  68. hedgingDelay: .seconds(1),
  69. nonFatalStatusCodes: []
  70. )
  71. let defaultConfiguration = ClientRPCExecutionConfiguration(hedgingPolicy: policy)
  72. var configurations = ClientRPCExecutionConfigurationCollection(
  73. defaultConfiguration: defaultConfiguration
  74. )
  75. let firstDescriptor = MethodDescriptor(service: "test1", method: "first")
  76. let retryPolicy = RetryPolicy(
  77. maximumAttempts: 10,
  78. initialBackoff: .seconds(1),
  79. maximumBackoff: .seconds(1),
  80. backoffMultiplier: 1.0,
  81. retryableStatusCodes: [.unavailable]
  82. )
  83. let overrideConfiguration = ClientRPCExecutionConfiguration(retryPolicy: retryPolicy)
  84. configurations[firstDescriptor] = overrideConfiguration
  85. let secondDescriptor = MethodDescriptor(service: "test2", method: "second")
  86. XCTAssertEqual(configurations[secondDescriptor], defaultConfiguration)
  87. }
  88. }