/** * Copyright 2010 Google Inc. * * Licensed under the Apache License, Version 2.0 (the "License"); you may not * use this file except in compliance with the License. You may obtain a copy of * the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the * License for the specific language governing permissions and limitations under * the License. * */ package org.waveprotocol.box.server.authentication; import static org.mockito.Mockito.mock; import static org.mockito.Mockito.when; import junit.framework.TestCase; import org.mockito.Mock; import org.mockito.Mockito; import org.mockito.MockitoAnnotations; import org.waveprotocol.box.server.account.HumanAccountData; import org.waveprotocol.box.server.account.HumanAccountDataImpl; import org.waveprotocol.box.server.persistence.AccountStore; import org.waveprotocol.box.server.persistence.memory.MemoryStore; import org.waveprotocol.wave.model.wave.ParticipantId; import javax.servlet.http.HttpSession; /** * Unit tests for {@link SessionManagerImpl}. * * @author josephg@gmail.com (Joseph Gentle) */ public class SessionManagerTest extends TestCase { @Mock private org.eclipse.jetty.server.SessionManager jettySessionManager; private SessionManager sessionManager; private HumanAccountData account; @Override protected void setUp() throws Exception { MockitoAnnotations.initMocks(this); AccountStore store = new MemoryStore(); account = new HumanAccountDataImpl(ParticipantId.ofUnsafe("tubes@example.com")); store.putAccount(account); sessionManager = new SessionManagerImpl(store, jettySessionManager); } public void testSessionFetchesAddress() { HttpSession session = mock(HttpSession.class); ParticipantId id = ParticipantId.ofUnsafe("tubes@example.com"); when(session.getAttribute("user")).thenReturn(id); assertEquals(id, sessionManager.getLoggedInUser(session)); assertSame(account, sessionManager.getLoggedInAccount(session)); } public void testUnknownUserReturnsNull() { HttpSession session = mock(HttpSession.class); when(session.getAttribute("user")).thenReturn(ParticipantId.ofUnsafe("missing@example.com")); assertNull(sessionManager.getLoggedInAccount(session)); } public void testNullSessionReturnsNull() { assertNull(sessionManager.getLoggedInUser(null)); assertNull(sessionManager.getLoggedInAccount(null)); } public void testGetLoginUrlWithNoArgument() { assertEquals(SessionManager.SIGN_IN_URL, sessionManager.getLoginUrl(null)); } public void testGetLoginUrlWithSimpleRedirect() { assertEquals(SessionManager.SIGN_IN_URL + "?r=/some/other/url", sessionManager.getLoginUrl("/some/other/url")); } public void testGetLoginUrlEncodesQueryParameters() { String url = "/abc123?nested=query&string"; String encoded_url = "/abc123?nested%3Dquery%26string"; assertEquals( SessionManager.SIGN_IN_URL + "?r=" + encoded_url, sessionManager.getLoginUrl(url)); } public void testGetSessionFromToken() { HttpSession session = mock(HttpSession.class); Mockito.when(jettySessionManager.getHttpSession("abc123")).thenReturn(session); assertSame(session, sessionManager.getSessionFromToken("abc123")); } public void testGetSessionFromUnknownToken() { HttpSession session = mock(HttpSession.class); Mockito.when(jettySessionManager.getHttpSession("abc123")).thenReturn(null); assertNull(sessionManager.getSessionFromToken("abc123")); } }