|
25 | 25 | import static software.amazon.awssdk.core.internal.useragent.UserAgentConstant.SPACE; |
26 | 26 |
|
27 | 27 | import java.util.Arrays; |
| 28 | +import java.util.LinkedHashMap; |
28 | 29 | import java.util.List; |
| 30 | +import java.util.Map; |
29 | 31 | import java.util.concurrent.CompletableFuture; |
30 | 32 | import org.junit.Test; |
31 | 33 | import org.junit.runner.RunWith; |
@@ -152,6 +154,94 @@ public void when_identityContainsProvider_authSourceIsPresent() throws Exception |
152 | 154 | assertThat(userAgentHeaders.get(0)).contains("m/w"); |
153 | 155 | } |
154 | 156 |
|
| 157 | + @Test |
| 158 | + public void when_userAgentHeaderAlreadyPresent_AndSdkOptionAdditionalHeaderNotPresent_doesNotOverwrite() throws Exception { |
| 159 | + ApplyUserAgentStage stage = new ApplyUserAgentStage(dependencies(clientUserAgent())); |
| 160 | + |
| 161 | + String existingUserAgent = "CustomUserAgent/1.0"; |
| 162 | + SdkHttpFullRequest.Builder requestWithExistingHeader = SdkHttpFullRequest.builder() |
| 163 | + .putHeader(HEADER_USER_AGENT, existingUserAgent); |
| 164 | + |
| 165 | + RequestExecutionContext ctx = requestExecutionContext(executionAttributes(IDENTITY_WITHOUT_SOURCE), noOpRequest()); |
| 166 | + SdkHttpFullRequest.Builder result = stage.execute(requestWithExistingHeader, ctx); |
| 167 | + |
| 168 | + List<String> userAgentHeaders = result.headers().get(HEADER_USER_AGENT); |
| 169 | + assertThat(userAgentHeaders).isNotNull().hasSize(1); |
| 170 | + assertThat(userAgentHeaders.get(0)).startsWith("aws-sdk-java"); |
| 171 | + } |
| 172 | + |
| 173 | + @Test |
| 174 | + public void when_userAgentHeaderPresentButEmpty_sdkAddsUserAgent() throws Exception { |
| 175 | + ApplyUserAgentStage stage = new ApplyUserAgentStage(dependencies(clientUserAgent())); |
| 176 | + |
| 177 | + SdkHttpFullRequest.Builder requestWithEmptyHeader = SdkHttpFullRequest.builder() |
| 178 | + .putHeader(HEADER_USER_AGENT, ""); |
| 179 | + |
| 180 | + RequestExecutionContext ctx = requestExecutionContext(executionAttributes(IDENTITY_WITHOUT_SOURCE), noOpRequest()); |
| 181 | + SdkHttpFullRequest.Builder result = stage.execute(requestWithEmptyHeader, ctx); |
| 182 | + |
| 183 | + List<String> userAgentHeaders = result.headers().get(HEADER_USER_AGENT); |
| 184 | + assertThat(userAgentHeaders).isNotNull().hasSize(1); |
| 185 | + assertThat(userAgentHeaders.get(0)).startsWith("aws-sdk-java"); |
| 186 | + } |
| 187 | + |
| 188 | + @Test |
| 189 | + public void when_userAgentHeaderPresentButNull_sdkAddsHeader() throws Exception { |
| 190 | + ApplyUserAgentStage stage = new ApplyUserAgentStage(dependencies(clientUserAgent())); |
| 191 | + String headerValue = null; |
| 192 | + SdkHttpFullRequest.Builder requestWithNullHeader = SdkHttpFullRequest.builder() |
| 193 | + .putHeader(HEADER_USER_AGENT, headerValue); |
| 194 | + |
| 195 | + RequestExecutionContext ctx = requestExecutionContext(executionAttributes(IDENTITY_WITHOUT_SOURCE), noOpRequest()); |
| 196 | + SdkHttpFullRequest.Builder result = stage.execute(requestWithNullHeader, ctx); |
| 197 | + |
| 198 | + List<String> userAgentHeaders = result.headers().get(HEADER_USER_AGENT); |
| 199 | + assertThat(userAgentHeaders).isNotNull().hasSize(1); |
| 200 | + assertThat(userAgentHeaders.get(0)).startsWith("aws-sdk-java"); |
| 201 | + } |
| 202 | + |
| 203 | + @Test |
| 204 | + public void when_userAgentHeaderAbsent_sdkAddsHeader() throws Exception { |
| 205 | + ApplyUserAgentStage stage = new ApplyUserAgentStage(dependencies(clientUserAgent())); |
| 206 | + |
| 207 | + SdkHttpFullRequest.Builder requestWithoutHeader = SdkHttpFullRequest.builder(); |
| 208 | + |
| 209 | + RequestExecutionContext ctx = requestExecutionContext(executionAttributes(IDENTITY_WITHOUT_SOURCE), noOpRequest()); |
| 210 | + SdkHttpFullRequest.Builder result = stage.execute(requestWithoutHeader, ctx); |
| 211 | + |
| 212 | + List<String> userAgentHeaders = result.headers().get(HEADER_USER_AGENT); |
| 213 | + assertThat(userAgentHeaders).isNotNull().hasSize(1); |
| 214 | + assertThat(userAgentHeaders.get(0)).startsWith("aws-sdk-java"); |
| 215 | + } |
| 216 | + |
| 217 | + @Test |
| 218 | + public void when_userAgentInAdditionalHeaders_doesNotOverwriteUserAgent() throws Exception { |
| 219 | + Map<String, List<String>> headerMap = new LinkedHashMap<>(); |
| 220 | + headerMap.put(HEADER_USER_AGENT, Arrays.asList("CustomAgent/1.0", "AnotherAgent/2.0")); |
| 221 | + |
| 222 | + SdkClientConfiguration clientConfiguration = |
| 223 | + SdkClientConfiguration.builder() |
| 224 | + .option(SdkClientOption.CLIENT_USER_AGENT, clientUserAgent()) |
| 225 | + .option(SdkClientOption.ADDITIONAL_HTTP_HEADERS, headerMap) |
| 226 | + .build(); |
| 227 | + HttpClientDependencies httpClientDependencies = HttpClientDependencies.builder() |
| 228 | + .clientConfiguration(clientConfiguration) |
| 229 | + .build(); |
| 230 | + |
| 231 | + ApplyUserAgentStage stage = new ApplyUserAgentStage(httpClientDependencies); |
| 232 | + |
| 233 | + SdkHttpFullRequest.Builder request = SdkHttpFullRequest.builder(); |
| 234 | + |
| 235 | + RequestExecutionContext ctx = requestExecutionContext(executionAttributes(IDENTITY_WITHOUT_SOURCE), noOpRequest()); |
| 236 | + SdkHttpFullRequest.Builder result = stage.execute(request, ctx); |
| 237 | + |
| 238 | + // ApplyUserAgentStage should skip adding User-Agent since it's in ADDITIONAL_HTTP_HEADERS |
| 239 | + // The actual merging happens in MergeCustomHeadersStage |
| 240 | + List<String> userAgentHeaders = result.headers().get(HEADER_USER_AGENT); |
| 241 | + assertThat(userAgentHeaders).isNull(); |
| 242 | + } |
| 243 | + |
| 244 | + |
155 | 245 | private static HttpClientDependencies dependencies(String clientUserAgent) { |
156 | 246 | return dependencies(clientUserAgent, null, null); |
157 | 247 | } |
@@ -219,6 +309,5 @@ private RequestExecutionContext requestExecutionContext(ExecutionAttributes exec |
219 | 309 | return RequestExecutionContext.builder() |
220 | 310 | .executionContext(executionContext) |
221 | 311 | .originalRequest(request).build(); |
222 | | - |
223 | 312 | } |
224 | 313 | } |
0 commit comments