/* * JBoss, Home of Professional Open Source. * Copyright 2008, Red Hat Middleware LLC, 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.picketlink.test.identity.federation.core.parser.saml; import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertNotNull; import static org.junit.Assert.assertTrue; import java.io.ByteArrayOutputStream; import java.io.InputStream; import java.util.List; import org.junit.Test; import org.picketlink.identity.federation.core.parsers.saml.SAMLParser; import org.picketlink.identity.federation.core.saml.v1.SAML11Constants; import org.picketlink.identity.federation.core.saml.v1.writers.SAML11RequestWriter; import org.picketlink.identity.federation.core.saml.v2.util.XMLTimeUtil; import org.picketlink.identity.federation.core.util.StaxUtil; import org.picketlink.identity.federation.saml.v1.assertion.SAML11ActionType; import org.picketlink.identity.federation.saml.v1.assertion.SAML11SubjectType; import org.picketlink.identity.federation.saml.v1.protocol.SAML11AttributeQueryType; import org.picketlink.identity.federation.saml.v1.protocol.SAML11AuthenticationQueryType; import org.picketlink.identity.federation.saml.v1.protocol.SAML11AuthorizationDecisionQueryType; import org.picketlink.identity.federation.saml.v1.protocol.SAML11QueryAbstractType; import org.picketlink.identity.federation.saml.v1.protocol.SAML11RequestType; /** * Unit Test SAML 1.1 Request Parsing * * @author Anil.Saldhana@redhat.com * @since Jun 24, 2011 */ public class SAML11RequestParserTestCase extends AbstractParserTest { @Test public void testSAML11RequestWithAuthQuery() throws Exception { ClassLoader tcl = Thread.currentThread().getContextClassLoader(); InputStream configStream = tcl.getResourceAsStream("parser/saml1/saml1-request-authquery.xml"); SAMLParser parser = new SAMLParser(); SAML11RequestType request = (SAML11RequestType) parser.parse(configStream); assertNotNull(request); assertEquals(1, request.getMajorVersion()); assertEquals(1, request.getMinorVersion()); assertEquals("aaf23196-1773-2113-474a-fe114412ab72", request.getID()); assertEquals(XMLTimeUtil.parse("2006-07-17T22:26:40Z"), request.getIssueInstant()); SAML11QueryAbstractType query = request.getQuery(); assertTrue(query instanceof SAML11AuthenticationQueryType); SAML11AuthenticationQueryType attQuery = (SAML11AuthenticationQueryType) query; SAML11SubjectType subject = attQuery.getSubject(); SAML11SubjectType.SAML11SubjectTypeChoice choice = subject.getChoice(); assertEquals("myusername", choice.getNameID().getValue()); ByteArrayOutputStream baos = new ByteArrayOutputStream(); // Lets do the writing SAML11RequestWriter writer = new SAML11RequestWriter(StaxUtil.getXMLStreamWriter(baos)); writer.write(request); String writtenString = new String(baos.toByteArray()); System.out.println(writtenString); validateSchema(writtenString); } @Test public void testSAML11RequestWithAttributeQuery() throws Exception { ClassLoader tcl = Thread.currentThread().getContextClassLoader(); InputStream configStream = tcl.getResourceAsStream("parser/saml1/saml1-request-attributequery.xml"); SAMLParser parser = new SAMLParser(); SAML11RequestType request = (SAML11RequestType) parser.parse(configStream); assertNotNull(request); assertEquals(1, request.getMajorVersion()); assertEquals(1, request.getMinorVersion()); assertEquals("aaf23196-1773-2113-474a-fe114412ab72", request.getID()); assertEquals(XMLTimeUtil.parse("2006-07-17T22:26:40Z"), request.getIssueInstant()); SAML11QueryAbstractType query = request.getQuery(); assertTrue(query instanceof SAML11AttributeQueryType); SAML11AttributeQueryType attQuery = (SAML11AttributeQueryType) query; SAML11SubjectType subject = attQuery.getSubject(); SAML11SubjectType.SAML11SubjectTypeChoice choice = subject.getChoice(); assertEquals("testID", choice.getNameID().getValue()); ByteArrayOutputStream baos = new ByteArrayOutputStream(); // Lets do the writing SAML11RequestWriter writer = new SAML11RequestWriter(StaxUtil.getXMLStreamWriter(baos)); writer.write(request); String writtenString = new String(baos.toByteArray()); System.out.println(writtenString); validateSchema(writtenString); } @Test public void testSAML11RequestWithAuthorizationQuery() throws Exception { ClassLoader tcl = Thread.currentThread().getContextClassLoader(); InputStream configStream = tcl.getResourceAsStream("parser/saml1/saml1-request-authzquery.xml"); SAMLParser parser = new SAMLParser(); SAML11RequestType request = (SAML11RequestType) parser.parse(configStream); assertNotNull(request); assertEquals(1, request.getMajorVersion()); assertEquals(1, request.getMinorVersion()); assertEquals("R1234", request.getID()); assertEquals(XMLTimeUtil.parse("2002-08-05T10:04:15"), request.getIssueInstant()); SAML11QueryAbstractType query = request.getQuery(); assertTrue(query instanceof SAML11AuthorizationDecisionQueryType); SAML11AuthorizationDecisionQueryType attQuery = (SAML11AuthorizationDecisionQueryType) query; SAML11SubjectType subject = attQuery.getSubject(); SAML11SubjectType.SAML11SubjectTypeChoice choice = subject.getChoice(); assertEquals("anil@anil.org", choice.getNameID().getValue()); assertEquals(SAML11Constants.FORMAT_EMAIL_ADDRESS, choice.getNameID().getFormat().toString()); assertEquals("http://jboss.org", choice.getNameID().getNameQualifier()); assertEquals("urn:jboss.resource", attQuery.getResource().toString()); List<SAML11ActionType> actions = attQuery.get(); assertEquals(1, actions.size()); SAML11ActionType action = actions.get(0); assertEquals("create", action.getValue()); assertEquals("http://www.jboss.org", action.getNamespace()); ByteArrayOutputStream baos = new ByteArrayOutputStream(); // Lets do the writing SAML11RequestWriter writer = new SAML11RequestWriter(StaxUtil.getXMLStreamWriter(baos)); writer.write(request); String writtenString = new String(baos.toByteArray()); System.out.println(writtenString); validateSchema(writtenString); } @Test public void testSAML11RequestWithAssertionArtifact() throws Exception { ClassLoader tcl = Thread.currentThread().getContextClassLoader(); InputStream configStream = tcl.getResourceAsStream("parser/saml1/saml1-request-assertionartifact.xml"); SAMLParser parser = new SAMLParser(); SAML11RequestType request = (SAML11RequestType) parser.parse(configStream); assertNotNull(request); assertEquals(1, request.getMajorVersion()); assertEquals(1, request.getMinorVersion()); assertEquals("rid", request.getID()); assertEquals(XMLTimeUtil.parse("2002-06-19T17:03:44.022Z"), request.getIssueInstant()); assertEquals("abcd", request.getAssertionArtifact().get(0)); ByteArrayOutputStream baos = new ByteArrayOutputStream(); // Lets do the writing SAML11RequestWriter writer = new SAML11RequestWriter(StaxUtil.getXMLStreamWriter(baos)); writer.write(request); String writtenString = new String(baos.toByteArray()); System.out.println(writtenString); validateSchema(writtenString); } @Test public void testSAML11RequestWithAssertionIDReference() throws Exception { ClassLoader tcl = Thread.currentThread().getContextClassLoader(); InputStream configStream = tcl.getResourceAsStream("parser/saml1/saml1-request-assertionIDref.xml"); SAMLParser parser = new SAMLParser(); SAML11RequestType request = (SAML11RequestType) parser.parse(configStream); assertNotNull(request); assertEquals(1, request.getMajorVersion()); assertEquals(1, request.getMinorVersion()); assertEquals("rid", request.getID()); assertEquals(XMLTimeUtil.parse("2002-06-19T17:03:44.022Z"), request.getIssueInstant()); assertEquals("abcd", request.getAssertionIDRef().get(0)); ByteArrayOutputStream baos = new ByteArrayOutputStream(); // Lets do the writing SAML11RequestWriter writer = new SAML11RequestWriter(StaxUtil.getXMLStreamWriter(baos)); writer.write(request); String writtenString = new String(baos.toByteArray()); System.out.println(writtenString); validateSchema(writtenString); } }