|
1 | 1 | /*
|
2 |
| - * Copyright 2002-2020 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 | *
|
@@ -363,18 +366,48 @@ public void buildWhenNonAsciiAdditionalParametersThenProperlyEncoded() {
|
363 | 366 | }
|
364 | 367 |
|
365 | 368 | @Test
|
366 |
| - public void additionalParametersArrayValueOrIterableEncoded() { |
367 |
| - Map<String, Object> additionalParameters = new HashMap<>(); |
368 |
| - additionalParameters.put("item", new String[] { "1", "2" }); |
369 |
| - additionalParameters.put("item2", Arrays.asList("H" + '\u00c5' + "M" + '\u00d6', "H" + '\u00c5' + "M" + '\u00d6')); |
| 369 | + public void buildWhenAdditionalParametersContainsArrayThenProperlyEncoded() { |
| 370 | + Map<String, Object> additionalParameters = new LinkedHashMap<>(); |
| 371 | + additionalParameters.put("item1", new String[] { "1", "2" }); |
| 372 | + additionalParameters.put("item2", "value2"); |
370 | 373 | OAuth2AuthorizationRequest authorizationRequest = TestOAuth2AuthorizationRequests.request()
|
371 |
| - .additionalParameters(additionalParameters) |
372 |
| - .build(); |
| 374 | + .additionalParameters(additionalParameters) |
| 375 | + .build(); |
373 | 376 | assertThat(authorizationRequest.getAuthorizationRequestUri()).isNotNull();
|
374 |
| - assertThat(authorizationRequest.getAuthorizationRequestUri()).isEqualTo( |
375 |
| - "https://example.com/login/oauth/authorize?" + "response_type=code&client_id=client-id&state=state&" |
376 |
| - + "redirect_uri=https://example.com/authorize/oauth2/code/registration-id&" |
377 |
| - + "item=1&item=2&item2=H%C3%85M%C3%96&item2=H%C3%85M%C3%96"); |
| 377 | + assertThat(authorizationRequest.getAuthorizationRequestUri()) |
| 378 | + .isEqualTo("https://example.com/login/oauth/authorize?response_type=code&client_id=client-id&state=state&" |
| 379 | + + "redirect_uri=https://example.com/authorize/oauth2/code/registration-id&" |
| 380 | + + "item1=1&item1=2&item2=value2"); |
| 381 | + } |
| 382 | + |
| 383 | + @Test |
| 384 | + public void buildWhenAdditionalParametersContainsIterableThenProperlyEncoded() { |
| 385 | + Map<String, Object> additionalParameters = new LinkedHashMap<>(); |
| 386 | + additionalParameters.put("item1", Arrays.asList("1", "2")); |
| 387 | + additionalParameters.put("item2", "value2"); |
| 388 | + OAuth2AuthorizationRequest authorizationRequest = TestOAuth2AuthorizationRequests.request() |
| 389 | + .additionalParameters(additionalParameters) |
| 390 | + .build(); |
| 391 | + assertThat(authorizationRequest.getAuthorizationRequestUri()).isNotNull(); |
| 392 | + assertThat(authorizationRequest.getAuthorizationRequestUri()) |
| 393 | + .isEqualTo("https://example.com/login/oauth/authorize?response_type=code&client_id=client-id&state=state&" |
| 394 | + + "redirect_uri=https://example.com/authorize/oauth2/code/registration-id&" |
| 395 | + + "item1=1&item1=2&item2=value2"); |
| 396 | + } |
| 397 | + |
| 398 | + @Test |
| 399 | + public void buildWhenAdditionalParametersContainsNullThenAuthorizationRequestUriContainsNull() { |
| 400 | + Map<String, Object> additionalParameters = new LinkedHashMap<>(); |
| 401 | + additionalParameters.put("item1", null); |
| 402 | + additionalParameters.put("item2", "value2"); |
| 403 | + OAuth2AuthorizationRequest authorizationRequest = TestOAuth2AuthorizationRequests.request() |
| 404 | + .additionalParameters(additionalParameters) |
| 405 | + .build(); |
| 406 | + assertThat(authorizationRequest.getAuthorizationRequestUri()).isNotNull(); |
| 407 | + assertThat(authorizationRequest.getAuthorizationRequestUri()) |
| 408 | + .isEqualTo("https://example.com/login/oauth/authorize?response_type=code&client_id=client-id&state=state&" |
| 409 | + + "redirect_uri=https://example.com/authorize/oauth2/code/registration-id&" |
| 410 | + + "item1=null&item2=value2"); |
378 | 411 | }
|
379 | 412 |
|
380 | 413 | }
|
0 commit comments