[jboss-cvs] JBossAS SVN: r62277 - trunk/testsuite/src/main/org/jboss/test/security/test/mapping.
jboss-cvs-commits at lists.jboss.org
jboss-cvs-commits at lists.jboss.org
Wed Apr 11 12:53:00 EDT 2007
Author: anil.saldhana at jboss.com
Date: 2007-04-11 12:53:00 -0400 (Wed, 11 Apr 2007)
New Revision: 62277
Added:
trunk/testsuite/src/main/org/jboss/test/security/test/mapping/DeploymentRoleMappingTestCase.java
Log:
deployment level role mapping test case
Added: trunk/testsuite/src/main/org/jboss/test/security/test/mapping/DeploymentRoleMappingTestCase.java
===================================================================
--- trunk/testsuite/src/main/org/jboss/test/security/test/mapping/DeploymentRoleMappingTestCase.java (rev 0)
+++ trunk/testsuite/src/main/org/jboss/test/security/test/mapping/DeploymentRoleMappingTestCase.java 2007-04-11 16:53:00 UTC (rev 62277)
@@ -0,0 +1,166 @@
+/*
+ * JBoss, Home of Professional Open Source
+ * Copyright 2005, JBoss Inc., and individual contributors as indicated
+ * by the @authors tag. See the copyright.txt in the distribution for a
+ * full listing of individual contributors.
+ *
+ * This is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU Lesser General Public License as
+ * published by the Free Software Foundation; either version 2.1 of
+ * the License, or (at your option) any later version.
+ *
+ * This software is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this software; if not, write to the Free
+ * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+ * 02110-1301 USA, or see the FSF site: http://www.fsf.org.
+ */
+package org.jboss.test.security.test.mapping;
+
+import java.net.HttpURLConnection;
+import java.net.URL;
+import java.rmi.RemoteException;
+
+import javax.rmi.PortableRemoteObject;
+import javax.security.auth.login.Configuration;
+import javax.security.auth.login.LoginContext;
+
+import junit.extensions.TestSetup;
+import junit.framework.Test;
+import junit.framework.TestSuite;
+
+import org.jboss.security.auth.login.XMLLoginConfigImpl;
+import org.jboss.test.JBossTestCase;
+import org.jboss.test.JBossTestSetup;
+import org.jboss.test.security.interfaces.StatelessSession;
+import org.jboss.test.security.interfaces.StatelessSessionHome;
+import org.jboss.test.util.AppCallbackHandler;
+import org.jboss.test.util.web.HttpUtils;
+
+/**
+ * Tests deployment level role mapping
+ * Define security roles in jboss-app.xml that get merged with
+ * roles for the web/ejb layers
+ * @author <a href="mailto:Anil.Saldhana at jboss.org">Anil Saldhana</a>
+ * @since Nov 14, 2006
+ * @version $Revision$
+ */
+public class DeploymentRoleMappingTestCase extends JBossTestCase
+{
+ static String username = "jduke";
+ static char[] password = "theduke".toCharArray();
+
+ LoginContext lc;
+ boolean loggedIn;
+
+ public DeploymentRoleMappingTestCase(String name)
+ {
+ super(name);
+ }
+
+ public void testEJBApplication() throws Exception
+ {
+ Object obj = getInitialContext().lookup("DeploymentLevelRoleMappingBean");
+ obj = PortableRemoteObject.narrow(obj, StatelessSessionHome.class);
+ StatelessSessionHome home = (StatelessSessionHome) obj;
+ log.debug("Found Unsecure StatelessSessionHome");
+ StatelessSession bean = null;
+ try
+ {
+ bean = home.create();
+ log.debug("Created spec.UnsecureStatelessSession2");
+ bean.echo("Hello from nobody?");
+ fail("Should not be allowed");
+ }
+ catch(RemoteException re)
+ {
+ }
+ finally
+ {
+ if(bean != null)
+ bean.remove();
+ }
+
+ login();
+ obj = getInitialContext().lookup("DeploymentLevelRoleMappingBean");
+ obj = PortableRemoteObject.narrow(obj, StatelessSessionHome.class);
+ home = (StatelessSessionHome) obj;
+ log.debug("Found spec.StatelessSession2");
+ bean = home.create();
+ log.debug("Created spec.StatelessSession2");
+ // Test that the Entity bean sees username as its principal
+ String echo = bean.echo("jduke");
+ log.debug("bean.echo(username) = "+echo);
+ assertTrue("username == echo", echo.equals("jduke"));
+ bean.remove();
+ logout();
+ }
+
+ public void testWebApplication() throws Exception
+ {
+ String baseURL = HttpUtils.getBaseURL("jduke", "theduke");
+ URL url = new URL(baseURL + "deployment-rolemapping/RequestInfoServlet");
+ HttpUtils.accessURL(url, "JBoss Realm", HttpURLConnection.HTTP_OK);
+ }
+
+ private void login() throws Exception
+ {
+ login("jduke", "theduke".toCharArray());
+ }
+ private void login(String username, char[] password) throws Exception
+ {
+ if( loggedIn )
+ return;
+
+ lc = null;
+ String confName = System.getProperty("conf.name", "other");
+ AppCallbackHandler handler = new AppCallbackHandler(username, password);
+ log.debug("Creating LoginContext("+confName+")");
+ lc = new LoginContext(confName, handler);
+ lc.login();
+ log.debug("Created LoginContext, subject="+lc.getSubject());
+ loggedIn = true;
+ }
+ private void logout() throws Exception
+ {
+ if( loggedIn )
+ {
+ loggedIn = false;
+ lc.logout();
+ }
+ }
+
+ /**
+ * Setup the test suite.
+ */
+ public static Test suite() throws Exception
+ {
+ TestSuite suite = new TestSuite();
+ suite.addTest(new TestSuite(DeploymentRoleMappingTestCase.class));
+
+ // Create an initializer for the test suite
+ TestSetup wrapper = new JBossTestSetup(suite)
+ {
+ protected void setUp() throws Exception
+ {
+ super.setUp();
+ Configuration.setConfiguration(new XMLLoginConfigImpl());
+ deploy(getResourceURL("security-spi/deploymentlevel/deploymentlevel-test-service.xml"));
+ redeploy("deployment-rolemapping.ear");
+ flushAuthCache();
+ }
+ protected void tearDown() throws Exception
+ {
+ undeploy(getResourceURL("security-spi/deploymentlevel/deploymentlevel-test-service.xml"));
+ undeploy("deployment-rolemapping.ear");
+ super.tearDown();
+
+ }
+ };
+ return wrapper;
+ }
+}
More information about the jboss-cvs-commits
mailing list