|
1 | 1 | /*
|
2 |
| - * Copyright 2002-2019 the original author or authors. |
| 2 | + * Copyright 2002-2021 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.
|
|
15 | 15 | */
|
16 | 16 | package org.springframework.web.server.session;
|
17 | 17 |
|
18 |
| -import java.util.Arrays; |
19 |
| -import java.util.Collections; |
20 |
| -import java.util.List; |
21 |
| - |
22 |
| -import org.junit.jupiter.api.BeforeEach; |
23 | 18 | import org.junit.jupiter.api.Test;
|
24 | 19 |
|
25 | 20 | import org.springframework.web.server.ServerWebExchange;
|
|
35 | 30 | * @author Greg Turnquist
|
36 | 31 | * @author Rob Winch
|
37 | 32 | */
|
38 |
| -public class HeaderWebSessionIdResolverTests { |
39 |
| - private HeaderWebSessionIdResolver idResolver; |
| 33 | +class HeaderWebSessionIdResolverTests { |
40 | 34 |
|
41 |
| - private ServerWebExchange exchange; |
| 35 | + private final HeaderWebSessionIdResolver idResolver = new HeaderWebSessionIdResolver(); |
| 36 | + |
| 37 | + private ServerWebExchange exchange = MockServerWebExchange.from(MockServerHttpRequest.get("/path")); |
42 | 38 |
|
43 |
| - @BeforeEach |
44 |
| - public void setUp() { |
45 |
| - this.idResolver = new HeaderWebSessionIdResolver(); |
46 |
| - this.exchange = MockServerWebExchange.from(MockServerHttpRequest.get("/path")); |
47 |
| - } |
48 | 39 |
|
49 | 40 | @Test
|
50 |
| - public void expireWhenValidThenSetsEmptyHeader() { |
| 41 | + void expireWhenValidThenSetsEmptyHeader() { |
51 | 42 | this.idResolver.expireSession(this.exchange);
|
52 | 43 |
|
53 |
| - assertThat(this.exchange.getResponse().getHeaders().get(HeaderWebSessionIdResolver.DEFAULT_HEADER_NAME)).isEqualTo(Collections.singletonList("")); |
| 44 | + assertThat(this.exchange.getResponse().getHeaders().get(HeaderWebSessionIdResolver.DEFAULT_HEADER_NAME)).containsExactly(""); |
54 | 45 | }
|
55 | 46 |
|
56 | 47 | @Test
|
57 |
| - public void expireWhenMultipleInvocationThenSetsSingleEmptyHeader() { |
| 48 | + void expireWhenMultipleInvocationThenSetsSingleEmptyHeader() { |
58 | 49 | this.idResolver.expireSession(this.exchange);
|
59 |
| - |
60 | 50 | this.idResolver.expireSession(this.exchange);
|
61 | 51 |
|
62 |
| - assertThat(this.exchange.getResponse().getHeaders().get(HeaderWebSessionIdResolver.DEFAULT_HEADER_NAME)).isEqualTo(Collections.singletonList("")); |
| 52 | + assertThat(this.exchange.getResponse().getHeaders().get(HeaderWebSessionIdResolver.DEFAULT_HEADER_NAME)).containsExactly(""); |
63 | 53 | }
|
64 | 54 |
|
65 | 55 | @Test
|
66 |
| - public void expireWhenAfterSetSessionIdThenSetsEmptyHeader() { |
| 56 | + void expireWhenAfterSetSessionIdThenSetsEmptyHeader() { |
67 | 57 | this.idResolver.setSessionId(this.exchange, "123");
|
68 |
| - |
69 | 58 | this.idResolver.expireSession(this.exchange);
|
70 | 59 |
|
71 |
| - assertThat(this.exchange.getResponse().getHeaders().get(HeaderWebSessionIdResolver.DEFAULT_HEADER_NAME)).isEqualTo(Collections.singletonList("")); |
| 60 | + assertThat(this.exchange.getResponse().getHeaders().get(HeaderWebSessionIdResolver.DEFAULT_HEADER_NAME)).containsExactly(""); |
72 | 61 | }
|
73 | 62 |
|
74 | 63 | @Test
|
75 |
| - public void setSessionIdWhenValidThenSetsHeader() { |
| 64 | + void setSessionIdWhenValidThenSetsHeader() { |
76 | 65 | String id = "123";
|
77 |
| - |
78 | 66 | this.idResolver.setSessionId(this.exchange, id);
|
79 | 67 |
|
80 |
| - assertThat(this.exchange.getResponse().getHeaders().get(HeaderWebSessionIdResolver.DEFAULT_HEADER_NAME)).isEqualTo(Collections.singletonList(id)); |
| 68 | + assertThat(this.exchange.getResponse().getHeaders().get(HeaderWebSessionIdResolver.DEFAULT_HEADER_NAME)).containsExactly(id); |
81 | 69 | }
|
82 | 70 |
|
83 | 71 | @Test
|
84 |
| - public void setSessionIdWhenMultipleThenSetsSingleHeader() { |
| 72 | + void setSessionIdWhenMultipleThenSetsSingleHeader() { |
85 | 73 | String id = "123";
|
86 | 74 | this.idResolver.setSessionId(this.exchange, "overriddenByNextInvocation");
|
87 |
| - |
88 | 75 | this.idResolver.setSessionId(this.exchange, id);
|
89 | 76 |
|
90 |
| - assertThat(this.exchange.getResponse().getHeaders().get(HeaderWebSessionIdResolver.DEFAULT_HEADER_NAME)).isEqualTo(Collections.singletonList(id)); |
| 77 | + assertThat(this.exchange.getResponse().getHeaders().get(HeaderWebSessionIdResolver.DEFAULT_HEADER_NAME)).containsExactly(id); |
91 | 78 | }
|
92 | 79 |
|
93 | 80 | @Test
|
94 |
| - public void setSessionIdWhenCustomHeaderNameThenSetsHeader() { |
| 81 | + void setSessionIdWhenCustomHeaderNameThenSetsHeader() { |
95 | 82 | String headerName = "x-auth";
|
96 | 83 | String id = "123";
|
97 | 84 | this.idResolver.setHeaderName(headerName);
|
98 |
| - |
99 | 85 | this.idResolver.setSessionId(this.exchange, id);
|
100 | 86 |
|
101 |
| - assertThat(this.exchange.getResponse().getHeaders().get(headerName)).isEqualTo(Collections.singletonList(id)); |
| 87 | + assertThat(this.exchange.getResponse().getHeaders().get(headerName)).containsExactly(id); |
102 | 88 | }
|
103 | 89 |
|
104 | 90 | @Test
|
105 |
| - public void setSessionIdWhenNullIdThenIllegalArgumentException() { |
| 91 | + void setSessionIdWhenNullIdThenIllegalArgumentException() { |
106 | 92 | assertThatIllegalArgumentException().isThrownBy(() ->
|
107 | 93 | this.idResolver.setSessionId(this.exchange, null));
|
108 | 94 | }
|
109 | 95 |
|
110 | 96 | @Test
|
111 |
| - public void resolveSessionIdsWhenNoIdsThenEmpty() { |
112 |
| - List<String> ids = this.idResolver.resolveSessionIds(this.exchange); |
113 |
| - |
114 |
| - assertThat(ids.isEmpty()).isTrue(); |
| 97 | + void resolveSessionIdsWhenNoIdsThenEmpty() { |
| 98 | + assertThat(this.idResolver.resolveSessionIds(this.exchange)).isEmpty(); |
115 | 99 | }
|
116 | 100 |
|
117 | 101 | @Test
|
118 |
| - public void resolveSessionIdsWhenIdThenIdFound() { |
| 102 | + void resolveSessionIdsWhenIdThenIdFound() { |
119 | 103 | String id = "123";
|
120 | 104 | this.exchange = MockServerWebExchange.from(MockServerHttpRequest.get("/path")
|
121 | 105 | .header(HeaderWebSessionIdResolver.DEFAULT_HEADER_NAME, id));
|
122 | 106 |
|
123 |
| - List<String> ids = this.idResolver.resolveSessionIds(this.exchange); |
124 |
| - |
125 |
| - assertThat(ids).isEqualTo(Collections.singletonList(id)); |
| 107 | + assertThat(this.idResolver.resolveSessionIds(this.exchange)).containsExactly(id); |
126 | 108 | }
|
127 | 109 |
|
128 | 110 | @Test
|
129 |
| - public void resolveSessionIdsWhenMultipleIdsThenIdsFound() { |
| 111 | + void resolveSessionIdsWhenMultipleIdsThenIdsFound() { |
130 | 112 | String id1 = "123";
|
131 | 113 | String id2 = "abc";
|
132 | 114 | this.exchange = MockServerWebExchange.from(
|
133 | 115 | MockServerHttpRequest.get("/path")
|
134 | 116 | .header(HeaderWebSessionIdResolver.DEFAULT_HEADER_NAME, id1, id2));
|
135 | 117 |
|
136 |
| - List<String> ids = this.idResolver.resolveSessionIds(this.exchange); |
137 |
| - |
138 |
| - assertThat(ids).isEqualTo(Arrays.asList(id1, id2)); |
| 118 | + assertThat(this.idResolver.resolveSessionIds(this.exchange)).containsExactly(id1, id2); |
139 | 119 | }
|
| 120 | + |
140 | 121 | }
|
0 commit comments