|
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