|
1 | 1 | // Licensed to the .NET Foundation under one or more agreements.
|
2 | 2 | // The .NET Foundation licenses this file to you under the MIT license.
|
3 | 3 |
|
4 |
| -using System.Linq; |
5 | 4 | using System.Net.Http;
|
6 | 5 | using System.Threading;
|
7 | 6 | using System.Threading.Tasks;
|
@@ -90,6 +89,81 @@ public async Task LoggingScopeHttpMessageHandler_LogsAbsoluteUri()
|
90 | 89 | Assert.Equal("HTTP GET http://api.example.com/search?term=Western%20Australia", message.Scope.ToString());
|
91 | 90 | }
|
92 | 91 |
|
| 92 | + [Fact] |
| 93 | + public void LoggingHttpMessageHandler_LogsAbsoluteUri_Sync() |
| 94 | + { |
| 95 | + // Arrange |
| 96 | + var sink = new TestSink(); |
| 97 | + |
| 98 | + var serviceCollection = new ServiceCollection(); |
| 99 | + serviceCollection.AddLogging(); |
| 100 | + serviceCollection.AddSingleton<ILoggerFactory>(new TestLoggerFactory(sink, enabled: true)); |
| 101 | + |
| 102 | + serviceCollection |
| 103 | + .AddHttpClient("test") |
| 104 | + .ConfigurePrimaryHttpMessageHandler(() => new TestMessageHandler()); |
| 105 | + |
| 106 | + var services = serviceCollection.BuildServiceProvider(); |
| 107 | + |
| 108 | + var client = services.GetRequiredService<IHttpClientFactory>().CreateClient("test"); |
| 109 | + |
| 110 | + |
| 111 | + // Act |
| 112 | + var request = new HttpRequestMessage(HttpMethod.Get, "http://api.example.com/search?term=Western%20Australia"); |
| 113 | + |
| 114 | + client.Send(request); |
| 115 | + |
| 116 | + // Assert |
| 117 | + var messages = sink.Writes.ToArray(); |
| 118 | + |
| 119 | + var message = Assert.Single(messages.Where(m => |
| 120 | + { |
| 121 | + return |
| 122 | + m.EventId == LoggingHttpMessageHandler.Log.EventIds.RequestStart && |
| 123 | + m.LoggerName == "System.Net.Http.HttpClient.test.ClientHandler"; |
| 124 | + })); |
| 125 | + |
| 126 | + Assert.Equal("Sending HTTP request GET http://api.example.com/search?term=Western%20Australia", message.Message); |
| 127 | + } |
| 128 | + |
| 129 | + [Fact] |
| 130 | + public void LoggingScopeHttpMessageHandler_LogsAbsoluteUri_Sync() |
| 131 | + { |
| 132 | + // Arrange |
| 133 | + var sink = new TestSink(); |
| 134 | + |
| 135 | + var serviceCollection = new ServiceCollection(); |
| 136 | + serviceCollection.AddLogging(); |
| 137 | + serviceCollection.AddSingleton<ILoggerFactory>(new TestLoggerFactory(sink, enabled: true)); |
| 138 | + |
| 139 | + serviceCollection |
| 140 | + .AddHttpClient("test") |
| 141 | + .ConfigurePrimaryHttpMessageHandler(() => new TestMessageHandler()); |
| 142 | + |
| 143 | + var services = serviceCollection.BuildServiceProvider(); |
| 144 | + |
| 145 | + var client = services.GetRequiredService<IHttpClientFactory>().CreateClient("test"); |
| 146 | + |
| 147 | + |
| 148 | + // Act |
| 149 | + var request = new HttpRequestMessage(HttpMethod.Get, "http://api.example.com/search?term=Western%20Australia"); |
| 150 | + |
| 151 | + client.Send(request); |
| 152 | + |
| 153 | + // Assert |
| 154 | + var messages = sink.Writes.ToArray(); |
| 155 | + |
| 156 | + var message = Assert.Single(messages.Where(m => |
| 157 | + { |
| 158 | + return |
| 159 | + m.EventId == LoggingScopeHttpMessageHandler.Log.EventIds.PipelineStart && |
| 160 | + m.LoggerName == "System.Net.Http.HttpClient.test.LogicalHandler"; |
| 161 | + })); |
| 162 | + |
| 163 | + Assert.Equal("Start processing HTTP request GET http://api.example.com/search?term=Western%20Australia", message.Message); |
| 164 | + Assert.Equal("HTTP GET http://api.example.com/search?term=Western%20Australia", message.Scope.ToString()); |
| 165 | + } |
| 166 | + |
93 | 167 | private class TestMessageHandler : HttpClientHandler
|
94 | 168 | {
|
95 | 169 | protected override Task<HttpResponseMessage> SendAsync(HttpRequestMessage request, CancellationToken cancellationToken)
|
|
0 commit comments