/*
* JBoss, Home of Professional Open Source.
* Copyright 2013, Red Hat, Inc., and individual contributors
* as indicated by the @author tags. See the copyright.txt file 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.as.controller.remote;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertTrue;
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.DataInputStream;
import java.io.DataOutputStream;
import java.io.IOException;
import java.net.InetAddress;
import java.security.Principal;
import java.util.Collection;
import java.util.HashSet;
import javax.security.auth.Subject;
import org.jboss.as.controller.security.InetAddressPrincipal;
import org.jboss.as.core.security.RealmGroup;
import org.jboss.as.core.security.RealmRole;
import org.jboss.as.core.security.RealmUser;
import org.jboss.as.core.security.SimplePrincipal;
import org.junit.Test;
/**
* Test case for the utility to write and read subjects.
*
* @author <a href="mailto:darran.lofthouse@jboss.com">Darran Lofthouse</a>
*/
public class SubjectProtocolUtilTestCase {
@Test
public void testSupportedTypes() throws Exception {
Collection<Principal> toSend = new HashSet<Principal>();
Collection<Principal> toreceive = new HashSet<Principal>();
add(new RealmUser("NamedOnlyUser"), toSend, toreceive);
add(new RealmUser("TestRealm", "TestUser"), toSend, toreceive);
add(new RealmGroup("NamedOnlyGroup"), toSend, toreceive);
add(new RealmGroup("TestRealm", "TestGroup"), toSend, toreceive);
add(new RealmRole("RealmRole"), toSend, toreceive);
InetAddress testAddress = InetAddress.getByAddress("localhost", new byte[] { 0x7F, 0x00, 0x00, 0x01 });
add(new InetAddressPrincipal(testAddress), toSend, toreceive);
assertEquals("To send count", 6, toSend.size());
assertEquals("To receive count", 6, toreceive.size());
performTest(toSend, toreceive);
}
@Test
public void testUnSupportedTypes() throws Exception {
Collection<Principal> toSend = new HashSet<Principal>();
Collection<Principal> toreceive = new HashSet<Principal>();
add(new RealmUser("NamedOnlyUser"), toSend, toreceive);
add(new RealmUser("TestRealm", "TestUser"), toSend, toreceive);
add(new RealmGroup("NamedOnlyGroup"), toSend, toreceive);
add(new SimplePrincipal("SimplePrincipal"), toSend);
add(new RealmGroup("TestRealm", "TestGroup"), toSend, toreceive);
add(new RealmRole("RealmRole"), toSend, toreceive);
InetAddress testAddress = InetAddress.getByAddress("localhost", new byte[] { 0x7F, 0x00, 0x00, 0x01 });
add(new InetAddressPrincipal(testAddress), toSend, toreceive);
assertEquals("To send count", 7, toSend.size());
assertEquals("To receive count", 6, toreceive.size());
performTest(toSend, toreceive);
}
private void add(Principal principal, Collection<Principal>... collections) {
for (Collection<Principal> current : collections) {
assertTrue("Principal added", current.add(principal));
}
}
private void performTest(Collection<Principal> original, Collection<Principal> expected) throws IOException {
Subject toSend = new Subject();
toSend.getPrincipals().addAll(original);
ByteArrayOutputStream baos = new ByteArrayOutputStream();
DataOutputStream dos = new DataOutputStream(baos);
SubjectProtocolUtil.write(dos, toSend);
dos.close();
baos.close();
byte[] sent = baos.toByteArray();
ByteArrayInputStream bais = new ByteArrayInputStream(sent);
DataInputStream dis = new DataInputStream(bais);
Subject received = SubjectProtocolUtil.read(dis);
for (Principal current : received.getPrincipals()) {
assertTrue("Principal received was in expected list.", expected.remove(current));
}
assertTrue("All expected principals received", expected.isEmpty());
}
}