/**
* Copyright 2011 meltmedia
*
* 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.xchain.framework.security;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertTrue;
import static org.junit.Assert.assertNotNull;
import java.security.Principal;
import javax.xml.namespace.QName;
import org.apache.commons.jxpath.JXPathContext;
import org.junit.After;
import org.junit.AfterClass;
import org.junit.Before;
import org.junit.BeforeClass;
import org.junit.Test;
import org.xchain.Catalog;
import org.xchain.Command;
import org.xchain.framework.factory.CatalogFactory;
import org.xchain.framework.lifecycle.Lifecycle;
import org.xchain.framework.lifecycle.ThreadContext;
import org.xchain.framework.lifecycle.ThreadLifecycle;
import org.xchain.framework.security.Identity;
/**
* @author Christian Trimble
*/
public class TestIdentityFunctions
{
public static final String CATALOG_URI = "resource://context-class-loader/org/xchain/framework/security/security-functions.xchain";
public static final String NAMESPACE_URI = "http://www.xchain.org/security/1.0";
public static final QName IDENTITY_FUNCTION = new QName(NAMESPACE_URI, "identity-function");
public static final QName PRINCIPAL_FUNCTION = new QName(NAMESPACE_URI, "principal-function");
public static final QName PRINCIPAL_NAME_FUNCTION = new QName(NAMESPACE_URI, "principal-name-function");
public static final String RESULT = "result";
protected ThreadContext threadContext = null;
protected JXPathContext context = null;
protected Catalog catalog = null;
protected Command command = null;
@BeforeClass public static void setUpLifecycle()
throws Exception
{
Lifecycle.startLifecycle();
}
@AfterClass public static void tearDownLifecycle()
throws Exception
{
Lifecycle.stopLifecycle();
}
@Before public void setUp()
throws Exception
{
threadContext = new ThreadContext();
ThreadLifecycle.getInstance().startThread(threadContext);
context = JXPathContext.newContext(new Object());
catalog = CatalogFactory.getInstance().getCatalog(CATALOG_URI);
}
@After public void tearDown()
throws Exception
{
ThreadLifecycle.getInstance().stopThread(threadContext);
threadContext = null;
context = null;
}
@Test public void testIdentityFunction()
throws Exception
{
// Get the command.
Command command = catalog.getCommand(IDENTITY_FUNCTION);
// execute the command.
command.execute(context);
// Get the result.
Identity identity = (Identity)context.getValue("$" + RESULT, Identity.class);
assertNotNull("security:identity() did not return the current identity.", identity);
}
@Test public void testPrincipalFunction()
throws Exception
{
// Get the command.
Command command = catalog.getCommand(PRINCIPAL_FUNCTION);
// execute the command.
command.execute(context);
// Get the result.
Principal principal = (Principal)context.getValue("$" + RESULT, Principal.class);
assertNotNull("security:pricipal() did not return the current principal.", principal);
}
@Test public void testPrincipalNameFunction()
throws Exception
{
// Get the command.
Command command = catalog.getCommand(PRINCIPAL_NAME_FUNCTION);
// execute the command.
command.execute(context);
// Get the result.
String principalName = (String)context.getValue("$" + RESULT, String.class);
assertNotNull("security:principal-name() did not return the current principal name.", principalName);
}
}