use of org.wildfly.clustering.web.session.ImmutableSession in project wildfly by wildfly.
the class UndertowHttpSessionFactoryTestCase method getServletContext.
@Test
public void getServletContext() {
ImmutableSession session = mock(ImmutableSession.class);
ServletContext context = mock(ServletContext.class);
ServletContext result = this.factory.createHttpSession(session, context).getServletContext();
assertSame(context, result);
}
use of org.wildfly.clustering.web.session.ImmutableSession in project wildfly by wildfly.
the class UndertowHttpSessionFactoryTestCase method getAttributeNames.
@Test
public void getAttributeNames() {
ImmutableSession session = mock(ImmutableSession.class);
ServletContext context = mock(ServletContext.class);
SessionAttributes attributes = mock(SessionAttributes.class);
Set<String> expected = new TreeSet<>();
when(session.getAttributes()).thenReturn(attributes);
when(attributes.getAttributeNames()).thenReturn(expected);
Enumeration<String> result = this.factory.createHttpSession(session, context).getAttributeNames();
assertEquals(new ArrayList<>(expected), Collections.list(result));
}
use of org.wildfly.clustering.web.session.ImmutableSession in project wildfly by wildfly.
the class UndertowHttpSessionFactoryTestCase method getMaxInactiveInterval.
@Test
public void getMaxInactiveInterval() {
ImmutableSession session = mock(ImmutableSession.class);
ServletContext context = mock(ServletContext.class);
SessionMetaData metaData = mock(SessionMetaData.class);
Duration interval = Duration.of(100L, ChronoUnit.SECONDS);
when(session.getMetaData()).thenReturn(metaData);
when(metaData.getMaxInactiveInterval()).thenReturn(interval);
int result = this.factory.createHttpSession(session, context).getMaxInactiveInterval();
assertEquals(interval.getSeconds(), result);
}
use of org.wildfly.clustering.web.session.ImmutableSession in project wildfly by wildfly.
the class UndertowHttpSessionFactoryTestCase method getAttribute.
@Test
public void getAttribute() {
ImmutableSession session = mock(ImmutableSession.class);
ServletContext context = mock(ServletContext.class);
SessionAttributes attributes = mock(SessionAttributes.class);
String name = "name";
Object expected = new Object();
when(session.getAttributes()).thenReturn(attributes);
when(attributes.getAttribute(name)).thenReturn(expected);
Object result = this.factory.createHttpSession(session, context).getAttribute(name);
assertSame(expected, result);
}
use of org.wildfly.clustering.web.session.ImmutableSession in project wildfly by wildfly.
the class UndertowSessionExpirationListenerTestCase method sessionExpired.
@Test
public void sessionExpired() {
Deployment deployment = mock(Deployment.class);
UndertowSessionManager manager = mock(UndertowSessionManager.class);
SessionManager<Map<String, Object>, Batch> delegateManager = mock(SessionManager.class);
Batcher<Batch> batcher = mock(Batcher.class);
Batch batch = mock(Batch.class);
SessionListener listener = mock(SessionListener.class);
ImmutableSession session = mock(ImmutableSession.class);
ImmutableSessionAttributes attributes = mock(ImmutableSessionAttributes.class);
ImmutableSessionMetaData metaData = mock(ImmutableSessionMetaData.class);
ArgumentCaptor<Session> capturedSession = ArgumentCaptor.forClass(Session.class);
String expectedSessionId = "session";
SessionListeners listeners = new SessionListeners();
listeners.addSessionListener(listener);
SessionExpirationListener expirationListener = new UndertowSessionExpirationListener(deployment, listeners);
when(deployment.getSessionManager()).thenReturn(manager);
when(manager.getSessionManager()).thenReturn(delegateManager);
when(delegateManager.getBatcher()).thenReturn(batcher);
when(batcher.suspendBatch()).thenReturn(batch);
when(session.getId()).thenReturn(expectedSessionId);
when(session.getAttributes()).thenReturn(attributes);
when(attributes.getAttributeNames()).thenReturn(Collections.emptySet());
when(session.getMetaData()).thenReturn(metaData);
when(metaData.getCreationTime()).thenReturn(Instant.now());
when(metaData.getLastAccessStartTime()).thenReturn(Instant.now());
when(metaData.getMaxInactiveInterval()).thenReturn(Duration.ZERO);
expirationListener.sessionExpired(session);
verify(batcher).suspendBatch();
verify(listener).sessionDestroyed(capturedSession.capture(), isNull(), same(SessionListener.SessionDestroyedReason.TIMEOUT));
verify(batcher).resumeBatch(batch);
assertSame(expectedSessionId, capturedSession.getValue().getId());
assertSame(manager, capturedSession.getValue().getSessionManager());
}
Aggregations