Polish HeaderWebSessionIdResolver
Use constant for default header name and make getHeaderName private. Also switch HeaderWebSessionIdResolverTests to unit tests rather than testing with DefaultWebSessionManager. Issue: SPR-15917
This commit is contained in:
committed by
Rossen Stoyanchev
parent
dcdb0b416f
commit
167ddc7cfc
@@ -15,170 +15,131 @@
|
||||
*/
|
||||
package org.springframework.web.server.session;
|
||||
|
||||
import java.time.Clock;
|
||||
import java.time.Duration;
|
||||
import java.time.Instant;
|
||||
import java.time.ZoneId;
|
||||
import java.util.UUID;
|
||||
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
import reactor.core.publisher.Mono;
|
||||
|
||||
import org.springframework.http.codec.ServerCodecConfigurer;
|
||||
import org.springframework.mock.http.server.reactive.test.MockServerHttpRequest;
|
||||
import org.springframework.mock.http.server.reactive.test.MockServerHttpResponse;
|
||||
import org.springframework.web.server.ServerWebExchange;
|
||||
import org.springframework.web.server.WebSession;
|
||||
import org.springframework.web.server.adapter.DefaultServerWebExchange;
|
||||
import org.springframework.web.server.i18n.AcceptHeaderLocaleContextResolver;
|
||||
|
||||
import static org.hamcrest.collection.IsCollectionWithSize.hasSize;
|
||||
import static org.hamcrest.core.Is.is;
|
||||
import static org.hamcrest.core.IsCollectionContaining.hasItem;
|
||||
import java.util.Arrays;
|
||||
import java.util.List;
|
||||
|
||||
import static org.junit.Assert.assertEquals;
|
||||
import static org.junit.Assert.assertFalse;
|
||||
import static org.junit.Assert.assertNotNull;
|
||||
import static org.junit.Assert.assertNotSame;
|
||||
import static org.junit.Assert.assertNull;
|
||||
import static org.junit.Assert.assertThat;
|
||||
import static org.junit.Assert.assertTrue;
|
||||
|
||||
/**
|
||||
* Tests using {@link HeaderWebSessionIdResolver}.
|
||||
*
|
||||
* @author Greg Turnquist
|
||||
* @author Rob Winch
|
||||
*/
|
||||
public class HeaderWebSessionIdResolverTests {
|
||||
|
||||
private static final Clock CLOCK = Clock.system(ZoneId.of("GMT"));
|
||||
|
||||
|
||||
private HeaderWebSessionIdResolver idResolver;
|
||||
|
||||
private DefaultWebSessionManager manager;
|
||||
|
||||
private ServerWebExchange exchange;
|
||||
|
||||
|
||||
@Before
|
||||
public void setUp() {
|
||||
this.idResolver = new HeaderWebSessionIdResolver();
|
||||
this.manager = new DefaultWebSessionManager();
|
||||
this.manager.setSessionIdResolver(this.idResolver);
|
||||
|
||||
MockServerHttpRequest request = MockServerHttpRequest.get("/path").build();
|
||||
MockServerHttpResponse response = new MockServerHttpResponse();
|
||||
|
||||
this.exchange = new DefaultServerWebExchange(request, response, this.manager,
|
||||
ServerCodecConfigurer.create(), new AcceptHeaderLocaleContextResolver());
|
||||
this.exchange = MockServerHttpRequest.get("/path").toExchange();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void getSessionWithoutStarting() throws Exception {
|
||||
WebSession session = this.manager.getSession(this.exchange).block();
|
||||
session.save();
|
||||
public void expireWhenValidThenSetsEmptyHeader() {
|
||||
this.idResolver.expireSession(this.exchange);
|
||||
|
||||
assertFalse(session.isStarted());
|
||||
assertFalse(session.isExpired());
|
||||
assertNull(this.manager.getSessionStore().retrieveSession(session.getId()).block());
|
||||
assertEquals(Arrays.asList(""),
|
||||
this.exchange.getResponse().getHeaders().get(HeaderWebSessionIdResolver.DEFAULT_HEADER_NAME));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void startSessionExplicitly() throws Exception {
|
||||
WebSession session = this.manager.getSession(this.exchange).block();
|
||||
session.start();
|
||||
session.save().block();
|
||||
public void expireWhenMultipleInvocationThenSetsSingleEmptyHeader() {
|
||||
this.idResolver.expireSession(this.exchange);
|
||||
|
||||
assertThat(this.exchange.getResponse().getHeaders().containsKey("SESSION"), is(true));
|
||||
assertThat(this.exchange.getResponse().getHeaders().get("SESSION"), hasSize(1));
|
||||
assertThat(this.exchange.getResponse().getHeaders().get("SESSION"), hasItem(session.getId()));
|
||||
this.idResolver.expireSession(this.exchange);
|
||||
|
||||
assertEquals(Arrays.asList(""),
|
||||
this.exchange.getResponse().getHeaders().get(HeaderWebSessionIdResolver.DEFAULT_HEADER_NAME));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void startSessionImplicitly() throws Exception {
|
||||
WebSession session = this.manager.getSession(this.exchange).block();
|
||||
session.getAttributes().put("foo", "bar");
|
||||
session.save();
|
||||
public void expireWhenAfterSetSessionIdThenSetsEmptyHeader() {
|
||||
this.idResolver.setSessionId(this.exchange, "123");
|
||||
|
||||
assertNotNull(this.exchange.getResponse().getHeaders().get("SESSION"));
|
||||
this.idResolver.expireSession(this.exchange);
|
||||
|
||||
assertEquals(Arrays.asList(""),
|
||||
this.exchange.getResponse().getHeaders().get(HeaderWebSessionIdResolver.DEFAULT_HEADER_NAME));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void existingSession() throws Exception {
|
||||
UUID sessionId = UUID.randomUUID();
|
||||
DefaultWebSession existing = createDefaultWebSession(sessionId);
|
||||
this.manager.getSessionStore().storeSession(existing);
|
||||
public void setSessionIdWhenValidThenSetsHeader() {
|
||||
String id = "123";
|
||||
|
||||
this.exchange = this.exchange.mutate()
|
||||
.request(this.exchange.getRequest().mutate()
|
||||
.header("SESSION", sessionId.toString())
|
||||
.build())
|
||||
.build();
|
||||
this.idResolver.setSessionId(this.exchange, id);
|
||||
|
||||
WebSession actual = this.manager.getSession(this.exchange).block();
|
||||
assertNotNull(actual);
|
||||
assertEquals(existing.getId(), actual.getId());
|
||||
assertEquals(Arrays.asList(id),
|
||||
this.exchange.getResponse().getHeaders().get(HeaderWebSessionIdResolver.DEFAULT_HEADER_NAME));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void existingSessionIsExpired() throws Exception {
|
||||
UUID sessionId = UUID.randomUUID();
|
||||
DefaultWebSession existing = createDefaultWebSession(sessionId);
|
||||
existing.start();
|
||||
Instant lastAccessTime = Instant.now(CLOCK).minus(Duration.ofMinutes(31));
|
||||
existing = new DefaultWebSession(existing, lastAccessTime, s -> Mono.empty());
|
||||
this.manager.getSessionStore().storeSession(existing);
|
||||
public void setSessionIdWhenMultipleThenSetsSingleHeader() {
|
||||
String id = "123";
|
||||
this.idResolver.setSessionId(this.exchange, "overriddenByNextInvocation");
|
||||
|
||||
this.exchange = this.exchange.mutate()
|
||||
.request(this.exchange.getRequest().mutate()
|
||||
.header("SESSION", sessionId.toString())
|
||||
.build())
|
||||
.build();
|
||||
this.idResolver.setSessionId(this.exchange, id);
|
||||
|
||||
WebSession actual = this.manager.getSession(this.exchange).block();
|
||||
assertNotSame(existing, actual);
|
||||
assertEquals(Arrays.asList(id),
|
||||
this.exchange.getResponse().getHeaders().get(HeaderWebSessionIdResolver.DEFAULT_HEADER_NAME));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void multipleSessionIds() throws Exception {
|
||||
UUID sessionId = UUID.randomUUID();
|
||||
DefaultWebSession existing = createDefaultWebSession(sessionId);
|
||||
this.manager.getSessionStore().storeSession(existing);
|
||||
this.manager.getSessionStore().storeSession(createDefaultWebSession(UUID.randomUUID()));
|
||||
this.manager.getSessionStore().storeSession(createDefaultWebSession(UUID.randomUUID()));
|
||||
public void setSessionIdWhenCustomHeaderNameThenSetsHeader() {
|
||||
String headerName = "x-auth";
|
||||
String id = "123";
|
||||
this.idResolver.setHeaderName(headerName);
|
||||
|
||||
this.exchange = this.exchange.mutate()
|
||||
.request(this.exchange.getRequest().mutate()
|
||||
.header("SESSION", sessionId.toString())
|
||||
.build())
|
||||
.build();
|
||||
this.idResolver.setSessionId(this.exchange, id);
|
||||
|
||||
WebSession actual = this.manager.getSession(this.exchange).block();
|
||||
assertNotNull(actual);
|
||||
assertEquals(existing.getId(), actual.getId());
|
||||
assertEquals(Arrays.asList(id),
|
||||
this.exchange.getResponse().getHeaders().get(headerName));
|
||||
}
|
||||
|
||||
@Test(expected = IllegalArgumentException.class)
|
||||
public void setSessionIdWhenNullIdThenIllegalArgumentException() {
|
||||
String id = null;
|
||||
|
||||
this.idResolver.setSessionId(this.exchange, id);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void alternateHeaderName() throws Exception {
|
||||
this.idResolver.setHeaderName("alternateHeaderName");
|
||||
public void resolveSessionIdsWhenNoIdsThenEmpty() {
|
||||
List<String> ids = this.idResolver.resolveSessionIds(this.exchange);
|
||||
|
||||
UUID sessionId = UUID.randomUUID();
|
||||
DefaultWebSession existing = createDefaultWebSession(sessionId);
|
||||
this.manager.getSessionStore().storeSession(existing);
|
||||
|
||||
this.exchange = this.exchange.mutate()
|
||||
.request(this.exchange.getRequest().mutate()
|
||||
.header("alternateHeaderName", sessionId.toString())
|
||||
.build())
|
||||
.build();
|
||||
|
||||
WebSession actual = this.manager.getSession(this.exchange).block();
|
||||
assertNotNull(actual);
|
||||
assertEquals(existing.getId(), actual.getId());
|
||||
assertTrue(ids.isEmpty());
|
||||
}
|
||||
|
||||
private DefaultWebSession createDefaultWebSession(UUID sessionId) {
|
||||
return new DefaultWebSession(() -> sessionId, CLOCK, (s, session) -> Mono.empty(), s -> Mono.empty());
|
||||
@Test
|
||||
public void resolveSessionIdsWhenIdThenIdFound() {
|
||||
String id = "123";
|
||||
this.exchange = MockServerHttpRequest.get("/path")
|
||||
.header(HeaderWebSessionIdResolver.DEFAULT_HEADER_NAME, id)
|
||||
.toExchange();
|
||||
|
||||
List<String> ids = this.idResolver.resolveSessionIds(this.exchange);
|
||||
|
||||
assertEquals(Arrays.asList(id), ids);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void resolveSessionIdsWhenMultipleIdsThenIdsFound() {
|
||||
String id1 = "123";
|
||||
String id2 = "abc";
|
||||
this.exchange = MockServerHttpRequest.get("/path")
|
||||
.header(HeaderWebSessionIdResolver.DEFAULT_HEADER_NAME, id1, id2)
|
||||
.toExchange();
|
||||
|
||||
List<String> ids = this.idResolver.resolveSessionIds(this.exchange);
|
||||
|
||||
assertEquals(Arrays.asList(id1, id2), ids);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user