|
1 | 1 | /* |
2 | | - * Copyright 2002-2022 the original author or authors. |
| 2 | + * Copyright 2002-2024 the original author or authors. |
3 | 3 | * |
4 | 4 | * Licensed under the Apache License, Version 2.0 (the "License"); |
5 | 5 | * you may not use this file except in compliance with the License. |
|
16 | 16 |
|
17 | 17 | package org.springframework.security.oauth2.core.endpoint; |
18 | 18 |
|
19 | | -import static org.assertj.core.api.Assertions.assertThat; |
20 | | -import static org.assertj.core.api.Assertions.assertThatIllegalArgumentException; |
21 | | - |
22 | 19 | import java.net.URI; |
23 | 20 | import java.util.Arrays; |
24 | 21 | import java.util.HashMap; |
| 22 | +import java.util.LinkedHashMap; |
25 | 23 | import java.util.LinkedHashSet; |
26 | 24 | import java.util.Map; |
27 | 25 | import java.util.Set; |
| 26 | + |
28 | 27 | import org.junit.jupiter.api.Test; |
| 28 | + |
29 | 29 | import org.springframework.security.oauth2.core.AuthorizationGrantType; |
30 | 30 |
|
| 31 | +import static org.assertj.core.api.Assertions.assertThat; |
| 32 | +import static org.assertj.core.api.Assertions.assertThatIllegalArgumentException; |
| 33 | + |
31 | 34 | /** |
32 | 35 | * Tests for {@link OAuth2AuthorizationRequest}. |
33 | 36 | * |
@@ -318,18 +321,48 @@ public void buildWhenNonAsciiAdditionalParametersThenProperlyEncoded() { |
318 | 321 | } |
319 | 322 |
|
320 | 323 | @Test |
321 | | - public void additionalParametersArrayValueOrIterableEncoded() { |
322 | | - Map<String, Object> additionalParameters = new HashMap<>(); |
323 | | - additionalParameters.put("item", new String[] { "1", "2" }); |
324 | | - additionalParameters.put("item2", Arrays.asList("H" + '\u00c5' + "M" + '\u00d6', "H" + '\u00c5' + "M" + '\u00d6')); |
| 324 | + public void buildWhenAdditionalParametersContainsArrayThenProperlyEncoded() { |
| 325 | + Map<String, Object> additionalParameters = new LinkedHashMap<>(); |
| 326 | + additionalParameters.put("item1", new String[] { "1", "2" }); |
| 327 | + additionalParameters.put("item2", "value2"); |
325 | 328 | OAuth2AuthorizationRequest authorizationRequest = TestOAuth2AuthorizationRequests.request() |
326 | | - .additionalParameters(additionalParameters) |
327 | | - .build(); |
| 329 | + .additionalParameters(additionalParameters) |
| 330 | + .build(); |
328 | 331 | assertThat(authorizationRequest.getAuthorizationRequestUri()).isNotNull(); |
329 | | - assertThat(authorizationRequest.getAuthorizationRequestUri()).isEqualTo( |
330 | | - "https://example.com/login/oauth/authorize?" + "response_type=code&client_id=client-id&state=state&" |
331 | | - + "redirect_uri=https://example.com/authorize/oauth2/code/registration-id&" |
332 | | - + "item=1&item=2&item2=H%C3%85M%C3%96&item2=H%C3%85M%C3%96"); |
| 332 | + assertThat(authorizationRequest.getAuthorizationRequestUri()) |
| 333 | + .isEqualTo("https://example.com/login/oauth/authorize?response_type=code&client_id=client-id&state=state&" |
| 334 | + + "redirect_uri=https://example.com/authorize/oauth2/code/registration-id&" |
| 335 | + + "item1=1&item1=2&item2=value2"); |
| 336 | + } |
| 337 | + |
| 338 | + @Test |
| 339 | + public void buildWhenAdditionalParametersContainsIterableThenProperlyEncoded() { |
| 340 | + Map<String, Object> additionalParameters = new LinkedHashMap<>(); |
| 341 | + additionalParameters.put("item1", Arrays.asList("1", "2")); |
| 342 | + additionalParameters.put("item2", "value2"); |
| 343 | + OAuth2AuthorizationRequest authorizationRequest = TestOAuth2AuthorizationRequests.request() |
| 344 | + .additionalParameters(additionalParameters) |
| 345 | + .build(); |
| 346 | + assertThat(authorizationRequest.getAuthorizationRequestUri()).isNotNull(); |
| 347 | + assertThat(authorizationRequest.getAuthorizationRequestUri()) |
| 348 | + .isEqualTo("https://example.com/login/oauth/authorize?response_type=code&client_id=client-id&state=state&" |
| 349 | + + "redirect_uri=https://example.com/authorize/oauth2/code/registration-id&" |
| 350 | + + "item1=1&item1=2&item2=value2"); |
| 351 | + } |
| 352 | + |
| 353 | + @Test |
| 354 | + public void buildWhenAdditionalParametersContainsNullThenAuthorizationRequestUriContainsNull() { |
| 355 | + Map<String, Object> additionalParameters = new LinkedHashMap<>(); |
| 356 | + additionalParameters.put("item1", null); |
| 357 | + additionalParameters.put("item2", "value2"); |
| 358 | + OAuth2AuthorizationRequest authorizationRequest = TestOAuth2AuthorizationRequests.request() |
| 359 | + .additionalParameters(additionalParameters) |
| 360 | + .build(); |
| 361 | + assertThat(authorizationRequest.getAuthorizationRequestUri()).isNotNull(); |
| 362 | + assertThat(authorizationRequest.getAuthorizationRequestUri()) |
| 363 | + .isEqualTo("https://example.com/login/oauth/authorize?response_type=code&client_id=client-id&state=state&" |
| 364 | + + "redirect_uri=https://example.com/authorize/oauth2/code/registration-id&" |
| 365 | + + "item1=null&item2=value2"); |
333 | 366 | } |
334 | 367 |
|
335 | 368 | } |
0 commit comments