From d557854a8f03763197c19387c2e88ef4f4641f75 Mon Sep 17 00:00:00 2001 From: George Barnett Date: Fri, 26 Jul 2024 10:16:37 +0100 Subject: [PATCH] Shutdown server gracefully in h2 transport tests Motivation: The h2 transport tests cancel the task group running them when the test has completed. Cancelling the server makes https://github.com/apple/swift-nio/issues/2813 more likely to occur. Modifications: - Tell the server to stop listening and let the test stop gracefully Result: Fewer runtime issues --- .../HTTP2TransportTests.swift | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) diff --git a/Tests/GRPCHTTP2TransportTests/HTTP2TransportTests.swift b/Tests/GRPCHTTP2TransportTests/HTTP2TransportTests.swift index cf4cd16d7..7ffeee209 100644 --- a/Tests/GRPCHTTP2TransportTests/HTTP2TransportTests.swift +++ b/Tests/GRPCHTTP2TransportTests/HTTP2TransportTests.swift @@ -57,7 +57,7 @@ final class HTTP2TransportTests: XCTestCase { ) async throws { for pair in transport { try await withThrowingTaskGroup(of: Void.self) { group in - let address = try await self.runServer( + let (server, address) = try await self.runServer( in: &group, kind: pair.server, enableControlService: enableControlService, @@ -94,8 +94,8 @@ final class HTTP2TransportTests: XCTestCase { XCTFail("Unexpected error: '\(error)' (\(pair))") } + server.stopListening() client.close() - group.cancelAll() } } } @@ -139,7 +139,7 @@ final class HTTP2TransportTests: XCTestCase { kind: Transport.Kind, enableControlService: Bool, compression: CompressionAlgorithmSet - ) async throws -> GRPCHTTP2Core.SocketAddress { + ) async throws -> (GRPCServer, GRPCHTTP2Core.SocketAddress) { let services = enableControlService ? [ControlService()] : [] switch kind { @@ -156,7 +156,8 @@ final class HTTP2TransportTests: XCTestCase { try await server.run() } - return try await transport.listeningAddress + let address = try await transport.listeningAddress + return (server, address) case .niots: #if canImport(Network) @@ -172,7 +173,8 @@ final class HTTP2TransportTests: XCTestCase { try await server.run() } - return try await transport.listeningAddress + let address = try await transport.listeningAddress + return (server, address) #else throw XCTSkip("Transport not supported on this platform") #endif