ConnectivityStateMonitorTests.swift 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. /*
  2. * Copyright 2019, 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. @testable import GRPC
  17. import Logging
  18. import XCTest
  19. class ConnectivityStateMonitorTests: GRPCTestCase {
  20. // Ensure `.idle` isn't first since it is the initial state and we only trigger callbacks
  21. // when the state changes, not when the state is set.
  22. let states: [ConnectivityState] = [.connecting, .ready, .transientFailure, .shutdown, .idle]
  23. func testDelegateOnlyCalledForChanges() {
  24. let recorder = RecordingConnectivityDelegate()
  25. recorder.expectChanges(3) { changes in
  26. XCTAssertEqual(changes, [
  27. Change(from: .idle, to: .connecting),
  28. Change(from: .connecting, to: .ready),
  29. Change(from: .ready, to: .shutdown),
  30. ])
  31. }
  32. let monitor = ConnectivityStateMonitor(delegate: recorder, queue: nil)
  33. monitor.delegate = recorder
  34. monitor.updateState(to: .connecting, logger: self.logger)
  35. monitor.updateState(to: .ready, logger: self.logger)
  36. monitor.updateState(to: .ready, logger: self.logger)
  37. monitor.updateState(to: .shutdown, logger: self.logger)
  38. recorder.waitForExpectedChanges(timeout: .seconds(1))
  39. }
  40. func testHTTP2Delegate() {
  41. let http2Delegate = RecordingHTTP2Delegate()
  42. let queue = DispatchQueue(label: "io.grpc.testing")
  43. let monitor = ConnectivityStateMonitor(delegate: nil, queue: queue)
  44. monitor.http2Delegate = http2Delegate
  45. monitor.streamClosed()
  46. monitor.streamClosed()
  47. monitor.streamClosed()
  48. monitor.maxConcurrentStreamsChanged(31)
  49. monitor.maxConcurrentStreamsChanged(41)
  50. monitor.maxConcurrentStreamsChanged(49)
  51. XCTAssertEqual(queue.sync { http2Delegate.streamsClosed }, 3)
  52. XCTAssertEqual(queue.sync { http2Delegate.maxConcurrentStreamsChanges }, [31, 41, 49])
  53. }
  54. }
  55. internal final class RecordingHTTP2Delegate: HTTP2ConnectionDelegate {
  56. private(set) var streamsClosed = 0
  57. private(set) var maxConcurrentStreamsChanges: [Int] = []
  58. internal func streamClosed() {
  59. self.streamsClosed += 1
  60. }
  61. internal func maxConcurrentStreamsChanged(_ maxConcurrentStreams: Int) {
  62. self.maxConcurrentStreamsChanges.append(maxConcurrentStreams)
  63. }
  64. }