001package org.apache.turbine.pipeline;
002
003
004/*
005 * Licensed to the Apache Software Foundation (ASF) under one
006 * or more contributor license agreements.  See the NOTICE file
007 * distributed with this work for additional information
008 * regarding copyright ownership.  The ASF licenses this file
009 * to you under the Apache License, Version 2.0 (the
010 * "License"); you may not use this file except in compliance
011 * with the License.  You may obtain a copy of the License at
012 *
013 *   http://www.apache.org/licenses/LICENSE-2.0
014 *
015 * Unless required by applicable law or agreed to in writing,
016 * software distributed under the License is distributed on an
017 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
018 * KIND, either express or implied.  See the License for the
019 * specific language governing permissions and limitations
020 * under the License.
021 */
022
023
024import java.util.Vector;
025
026import javax.servlet.http.HttpServletResponse;
027
028import org.apache.fulcrum.security.model.turbine.entity.impl.TurbineUserImpl;
029import org.apache.turbine.TurbineConstants;
030import org.apache.turbine.modules.actions.LoginUser;
031import org.apache.turbine.om.security.DefaultUserImpl;
032import org.apache.turbine.om.security.User;
033import org.apache.turbine.test.BaseTestCase;
034import org.apache.turbine.test.EnhancedMockHttpServletRequest;
035import org.apache.turbine.test.EnhancedMockHttpSession;
036import org.apache.turbine.util.RunData;
037import org.apache.turbine.util.TurbineConfig;
038import org.junit.AfterClass;
039import org.junit.Before;
040import org.junit.BeforeClass;
041import org.junit.Test;
042
043import com.mockobjects.servlet.MockHttpServletResponse;
044import com.mockobjects.servlet.MockServletConfig;
045
046import static org.junit.Assert.*;
047
048/**
049 * Tests TurbinePipeline.
050 *
051 * @author <a href="mailto:epugh@opensourceConnections.com">Eric Pugh</a>
052 * @author <a href="mailto:peter@courcoux.biz">Peter Courcoux</a>
053 * @version $Id: DefaultSessionValidationValveTest.java 1606111 2014-06-27 14:46:47Z gk $
054 */
055public class DefaultSessionValidationValveTest extends BaseTestCase
056{
057    private static TurbineConfig tc = null;
058    private MockServletConfig config = null;
059    private EnhancedMockHttpServletRequest request = null;
060    private EnhancedMockHttpSession session = null;
061    private HttpServletResponse response = null;
062
063
064
065    @BeforeClass
066    public static void init() {
067        tc = new TurbineConfig(
068                            ".",
069                            "/conf/test/CompleteTurbineResources.properties");
070        tc.initialize();
071    }
072    
073    @Before
074    public void setUpBefore() throws Exception {
075        config = new MockServletConfig();
076        config.setupNoParameters();
077        request = new EnhancedMockHttpServletRequest();
078        request.setupServerName("bob");
079        request.setupGetProtocol("http");
080        request.setupScheme("scheme");
081        request.setupPathInfo("damn");
082        request.setupGetServletPath("damn2");
083        request.setupGetContextPath("wow");
084        request.setupGetContentType("html/text");
085        request.setupAddHeader("Content-type", "html/text");
086        request.setupAddHeader("Accept-Language", "en-US");
087
088        session = new EnhancedMockHttpSession();
089        response = new MockHttpServletResponse();
090
091        request.setSession(session);
092
093    }
094
095    /**
096     * Tests the Valve.
097     */
098    @Test public void testAnonymousUser() throws Exception
099    {
100        Vector<String> v = new Vector<String>();
101        v.add(LoginUser.CGI_USERNAME);
102        v.add(LoginUser.CGI_PASSWORD);
103        request.setupGetParameterNames(v.elements());
104
105        request.setupAddParameter(LoginUser.CGI_USERNAME,"username");
106        request.setupAddParameter(LoginUser.CGI_PASSWORD,"password");
107
108        RunData runData = getRunData(request,response,config);
109        runData.setAction(TurbineConstants.ACTION_LOGIN_DEFAULT);
110
111        Pipeline pipeline = new TurbinePipeline();
112        PipelineData pipelineData = runData;
113
114        DefaultSessionValidationValve valve = new DefaultSessionValidationValve();
115        pipeline.addValve(valve);
116        pipeline.initialize();
117
118        pipeline.invoke(pipelineData);
119        User user = runData.getUser();
120        assertNotNull(user);
121        assertEquals("",user.getName());
122        assertFalse(user.hasLoggedIn());
123    }
124
125    @Test public void testLoggedInUser() throws Exception
126    {
127        Vector<String> v = new Vector<String>();
128        v.add(LoginUser.CGI_USERNAME);
129        v.add(LoginUser.CGI_PASSWORD);
130        request.setupGetParameterNames(v.elements());
131
132        request.setupAddParameter(LoginUser.CGI_USERNAME,"username");
133        request.setupAddParameter(LoginUser.CGI_PASSWORD,"password");
134
135        RunData runData = getRunData(request,response,config);
136        User tu = new DefaultUserImpl(new TurbineUserImpl());
137        tu.setName("username");
138        tu.setHasLoggedIn(Boolean.TRUE);
139        runData.setAction("TestAction");
140
141        session.setupGetAttribute(User.SESSION_KEY, tu);
142
143        Pipeline pipeline = new TurbinePipeline();
144        PipelineData pipelineData = runData;
145
146        DefaultSessionValidationValve valve = new DefaultSessionValidationValve();
147        pipeline.addValve(valve);
148        pipeline.initialize();
149
150        pipeline.invoke(pipelineData);
151        User user = runData.getUser();
152        assertNotNull(user);
153        assertEquals("username",user.getName());
154        assertTrue(user.hasLoggedIn());
155    }
156    
157    @AfterClass
158    public static void destroy() {
159        tc.dispose();
160    }
161}