-/*\r
- * Copyright 2001-2006 Internet2\r
- * \r
- * Licensed under the Apache License, Version 2.0 (the "License");\r
- * you may not use this file except in compliance with the License.\r
- * You may obtain a copy of the License at\r
- *\r
- * http://www.apache.org/licenses/LICENSE-2.0\r
- *\r
- * Unless required by applicable law or agreed to in writing, software\r
- * distributed under the License is distributed on an "AS IS" BASIS,\r
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r
- * See the License for the specific language governing permissions and\r
- * limitations under the License.\r
- */\r
-\r
-#include "internal.h"\r
-#include <saml/saml2/core/Protocols.h>\r
-#include <saml/util/SAMLConstants.h>\r
-\r
-using namespace opensaml::saml2p;\r
-using namespace opensaml::saml2;\r
-\r
-\r
-class Response20Test : public CxxTest::TestSuite, public SAMLObjectBaseTestCase {\r
- XMLCh* expectedID; \r
- XMLCh* expectedInResponseTo; \r
- XMLCh* expectedVersion; \r
- XMLCh* expectedConsent; \r
- XMLCh* expectedDestination; \r
- DateTime* expectedIssueInstant; \r
-\r
- // Assertion marshaller autogenerates ID, Version and IssueInstant if they are NULL,\r
- // so have to agree on something to put in the control XML\r
- XMLCh* assertionID1, * assertionID2, * assertionID3;\r
-\r
-public:\r
- void setUp() {\r
- expectedID = XMLString::transcode("def456"); \r
- expectedInResponseTo = XMLString::transcode("abc123"); \r
- expectedVersion = XMLString::transcode("2.0"); \r
- expectedConsent = XMLString::transcode("urn:string:consent"); \r
- expectedDestination = XMLString::transcode("http://sp.example.org/endpoint"); \r
- expectedIssueInstant = new DateTime(XMLString::transcode("2006-02-21T16:40:00.000Z"));\r
-\r
- assertionID1 = XMLString::transcode("test1"); \r
- assertionID2= XMLString::transcode("test2"); \r
- assertionID3 = XMLString::transcode("test3"); \r
-\r
- singleElementFile = data_path + "saml2/core/impl/Response.xml";\r
- singleElementOptionalAttributesFile = data_path + "saml2/core/impl/ResponseOptionalAttributes.xml";\r
- childElementsFile = data_path + "saml2/core/impl/ResponseChildElements.xml"; \r
- SAMLObjectBaseTestCase::setUp();\r
- }\r
- \r
- void tearDown() {\r
- XMLString::release(&expectedID);\r
- XMLString::release(&expectedInResponseTo);\r
- XMLString::release(&expectedVersion);\r
- XMLString::release(&expectedConsent);\r
- XMLString::release(&expectedDestination);\r
- XMLString::release(&assertionID1);\r
- XMLString::release(&assertionID2);\r
- XMLString::release(&assertionID3);\r
- delete expectedIssueInstant;\r
- SAMLObjectBaseTestCase::tearDown();\r
- }\r
-\r
- void testSingleElementUnmarshall() {\r
- auto_ptr<XMLObject> xo(unmarshallElement(singleElementFile));\r
- Response* response = dynamic_cast<Response*>(xo.get());\r
- TS_ASSERT(response!=NULL);\r
-\r
- assertEquals("ID attribute", expectedID, response->getID());\r
- assertEquals("Version attribute", expectedVersion, response->getVersion());\r
- assertEquals("IssueInstant attribute", expectedIssueInstant->getFormattedString(), response->getIssueInstant()->getFormattedString());\r
-\r
- TS_ASSERT(response->getIssuer()==NULL);\r
- TS_ASSERT(response->getSignature()==NULL);\r
- TS_ASSERT(response->getExtensions()==NULL);\r
- TS_ASSERT(response->getStatus()==NULL);\r
- TSM_ASSERT_EQUALS("# of Assertion child elements", 0, response->getAssertions().size());\r
- TSM_ASSERT_EQUALS("# of EncryptedAssertion child elements", 0, response->getEncryptedAssertions().size());\r
- }\r
-\r
- void testSingleElementOptionalAttributesUnmarshall() {\r
- auto_ptr<XMLObject> xo(unmarshallElement(singleElementOptionalAttributesFile));\r
- Response* response = dynamic_cast<Response*>(xo.get());\r
- TS_ASSERT(response!=NULL);\r
-\r
- assertEquals("Consent attribute", expectedConsent, response->getConsent());\r
- assertEquals("Destination attribute", expectedDestination, response->getDestination());\r
- assertEquals("InResponseTo attribute", expectedInResponseTo, response->getInResponseTo());\r
-\r
- TS_ASSERT(response->getIssuer()==NULL);\r
- TS_ASSERT(response->getSignature()==NULL);\r
- TS_ASSERT(response->getExtensions()==NULL);\r
- TS_ASSERT(response->getStatus()==NULL);\r
- TSM_ASSERT_EQUALS("# of Assertion child elements", 0, response->getAssertions().size());\r
- TSM_ASSERT_EQUALS("# of EncryptedAssertion child elements", 0, response->getEncryptedAssertions().size());\r
- }\r
-\r
- void testChildElementsUnmarshall() {\r
- auto_ptr<XMLObject> xo(unmarshallElement(childElementsFile));\r
- Response* response= dynamic_cast<Response*>(xo.get());\r
- TS_ASSERT(response!=NULL);\r
-\r
- TS_ASSERT(response->getIssuer()!=NULL);\r
- TS_ASSERT(response->getSignature()!=NULL);\r
- TS_ASSERT(response->getExtensions()!=NULL);\r
- TS_ASSERT(response->getStatus()!=NULL);\r
- TSM_ASSERT_EQUALS("# of Assertion child elements", 3, response->getAssertions().size());\r
- TSM_ASSERT_EQUALS("# of EncryptedAssertion child elements", 1, response->getEncryptedAssertions().size());\r
- }\r
-\r
- void testSingleElementMarshall() {\r
- Response* response = ResponseBuilder::buildResponse();\r
- TS_ASSERT(response!=NULL);\r
-\r
- response->setID(expectedID);\r
- response->setIssueInstant(expectedIssueInstant);\r
- //response->setVersion(expectedVersion);\r
- assertEquals(expectedDOM, response);\r
- }\r
-\r
- void testSingleElementOptionalAttributesMarshall() {\r
- Response* response = ResponseBuilder::buildResponse();\r
- TS_ASSERT(response!=NULL);\r
-\r
- response->setID(expectedID);\r
- response->setInResponseTo(expectedInResponseTo);\r
- response->setIssueInstant(expectedIssueInstant);\r
- //response->setVersion(expectedVersion);\r
- response->setConsent(expectedConsent);\r
- response->setDestination(expectedDestination);\r
- response->setInResponseTo(expectedInResponseTo);\r
- assertEquals(expectedOptionalAttributesDOM, response);\r
- }\r
-\r
- void testChildElementsMarshall() {\r
- Response* response = ResponseBuilder::buildResponse();\r
- TS_ASSERT(response!=NULL);\r
-\r
- response->setID(expectedID);\r
- response->setIssueInstant(expectedIssueInstant);\r
- // Do this just so don't have to redeclare the saml namespace prefix on every child element in the control XML file\r
- Namespace* ns = new Namespace(opensaml::SAMLConstants::SAML20_NS, opensaml::SAMLConstants::SAML20_PREFIX);\r
- response->addNamespace(*ns);\r
- response->setIssuer(IssuerBuilder::buildIssuer());\r
- // If the form of the default, basic, empty signature that is emittted changes wrt whitespace, etc,\r
- // this will probably break the test. In that case need to fix the control XML.\r
- response->setSignature(xmlsignature::SignatureBuilder::buildSignature());\r
- response->setExtensions(ExtensionsBuilder::buildExtensions());\r
- response->setStatus(StatusBuilder::buildStatus());\r
-\r
- Assertion* assertion=NULL;\r
-\r
- assertion = AssertionBuilder::buildAssertion();\r
- assertion->setIssueInstant(expectedIssueInstant);\r
- assertion->setID(assertionID1);\r
- response->getAssertions().push_back(assertion);\r
-\r
- assertion = AssertionBuilder::buildAssertion();\r
- assertion->setIssueInstant(expectedIssueInstant);\r
- assertion->setID(assertionID2);\r
- response->getAssertions().push_back(assertion);\r
-\r
- response->getEncryptedAssertions().push_back((EncryptedAssertionBuilder::buildEncryptedAssertion()));\r
-\r
- assertion = AssertionBuilder::buildAssertion();\r
- assertion->setIssueInstant(expectedIssueInstant);\r
- assertion->setID(assertionID3);\r
- response->getAssertions().push_back(assertion);\r
-\r
-\r
- assertEquals(expectedChildElementsDOM, response);\r
- delete ns;\r
- }\r
-\r
-};\r
+/*
+ * Copyright 2001-2010 Internet2
+ *
+ * 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.
+ */
+
+#include "internal.h"
+#include <saml/saml2/core/Protocols.h>
+#include <saml/util/SAMLConstants.h>
+#include <xmltooling/signature/Signature.h>
+
+using namespace opensaml::saml2p;
+using namespace opensaml::saml2;
+
+
+class Response20Test : public CxxTest::TestSuite, public SAMLObjectBaseTestCase {
+ XMLCh* expectedID;
+ XMLCh* expectedInResponseTo;
+ XMLCh* expectedVersion;
+ XMLCh* expectedConsent;
+ XMLCh* expectedDestination;
+ DateTime* expectedIssueInstant;
+
+ // Assertion marshaller autogenerates ID, Version and IssueInstant if they are nullptr,
+ // so have to agree on something to put in the control XML
+ XMLCh* assertionID1, * assertionID2, * assertionID3;
+
+public:
+ void setUp() {
+ expectedID = XMLString::transcode("def456");
+ expectedInResponseTo = XMLString::transcode("abc123");
+ expectedVersion = XMLString::transcode("2.0");
+ expectedConsent = XMLString::transcode("urn:string:consent");
+ expectedDestination = XMLString::transcode("http://sp.example.org/endpoint");
+ expectedIssueInstant = new DateTime(XMLString::transcode("2006-02-21T16:40:00.000Z"));
+ expectedIssueInstant->parseDateTime();
+
+ assertionID1 = XMLString::transcode("test1");
+ assertionID2= XMLString::transcode("test2");
+ assertionID3 = XMLString::transcode("test3");
+
+ singleElementFile = data_path + "saml2/core/impl/Response.xml";
+ singleElementOptionalAttributesFile = data_path + "saml2/core/impl/ResponseOptionalAttributes.xml";
+ childElementsFile = data_path + "saml2/core/impl/ResponseChildElements.xml";
+ SAMLObjectBaseTestCase::setUp();
+ }
+
+ void tearDown() {
+ XMLString::release(&expectedID);
+ XMLString::release(&expectedInResponseTo);
+ XMLString::release(&expectedVersion);
+ XMLString::release(&expectedConsent);
+ XMLString::release(&expectedDestination);
+ XMLString::release(&assertionID1);
+ XMLString::release(&assertionID2);
+ XMLString::release(&assertionID3);
+ delete expectedIssueInstant;
+ SAMLObjectBaseTestCase::tearDown();
+ }
+
+ void testSingleElementUnmarshall() {
+ auto_ptr<XMLObject> xo(unmarshallElement(singleElementFile));
+ Response* response = dynamic_cast<Response*>(xo.get());
+ TS_ASSERT(response!=nullptr);
+
+ assertEquals("ID attribute", expectedID, response->getID());
+ assertEquals("Version attribute", expectedVersion, response->getVersion());
+ TSM_ASSERT_EQUALS("IssueInstant attribute", expectedIssueInstant->getEpoch(), response->getIssueInstant()->getEpoch());
+
+ TS_ASSERT(response->getIssuer()==nullptr);
+ TS_ASSERT(response->getSignature()==nullptr);
+ TS_ASSERT(response->getExtensions()==nullptr);
+ TS_ASSERT(response->getStatus()==nullptr);
+ TSM_ASSERT_EQUALS("# of Assertion child elements", 0, response->getAssertions().size());
+ TSM_ASSERT_EQUALS("# of EncryptedAssertion child elements", 0, response->getEncryptedAssertions().size());
+ }
+
+ void testSingleElementOptionalAttributesUnmarshall() {
+ auto_ptr<XMLObject> xo(unmarshallElement(singleElementOptionalAttributesFile));
+ Response* response = dynamic_cast<Response*>(xo.get());
+ TS_ASSERT(response!=nullptr);
+
+ assertEquals("Consent attribute", expectedConsent, response->getConsent());
+ assertEquals("Destination attribute", expectedDestination, response->getDestination());
+ assertEquals("InResponseTo attribute", expectedInResponseTo, response->getInResponseTo());
+
+ TS_ASSERT(response->getIssuer()==nullptr);
+ TS_ASSERT(response->getSignature()==nullptr);
+ TS_ASSERT(response->getExtensions()==nullptr);
+ TS_ASSERT(response->getStatus()==nullptr);
+ TSM_ASSERT_EQUALS("# of Assertion child elements", 0, response->getAssertions().size());
+ TSM_ASSERT_EQUALS("# of EncryptedAssertion child elements", 0, response->getEncryptedAssertions().size());
+ }
+
+ void testChildElementsUnmarshall() {
+ auto_ptr<XMLObject> xo(unmarshallElement(childElementsFile));
+ Response* response= dynamic_cast<Response*>(xo.get());
+ TS_ASSERT(response!=nullptr);
+
+ TS_ASSERT(response->getIssuer()!=nullptr);
+ TS_ASSERT(response->getSignature()!=nullptr);
+ TS_ASSERT(response->getExtensions()!=nullptr);
+ TS_ASSERT(response->getStatus()!=nullptr);
+ TSM_ASSERT_EQUALS("# of Assertion child elements", 3, response->getAssertions().size());
+ TSM_ASSERT_EQUALS("# of EncryptedAssertion child elements", 1, response->getEncryptedAssertions().size());
+ }
+
+ void testSingleElementMarshall() {
+ Response* response = ResponseBuilder::buildResponse();
+ TS_ASSERT(response!=nullptr);
+
+ response->setID(expectedID);
+ response->setIssueInstant(expectedIssueInstant);
+ //response->setVersion(expectedVersion);
+ assertEquals(expectedDOM, response);
+ }
+
+ void testSingleElementOptionalAttributesMarshall() {
+ Response* response = ResponseBuilder::buildResponse();
+ TS_ASSERT(response!=nullptr);
+
+ response->setID(expectedID);
+ response->setInResponseTo(expectedInResponseTo);
+ response->setIssueInstant(expectedIssueInstant);
+ //response->setVersion(expectedVersion);
+ response->setConsent(expectedConsent);
+ response->setDestination(expectedDestination);
+ response->setInResponseTo(expectedInResponseTo);
+ assertEquals(expectedOptionalAttributesDOM, response);
+ }
+
+ void testChildElementsMarshall() {
+ Response* response = ResponseBuilder::buildResponse();
+ TS_ASSERT(response!=nullptr);
+
+ response->setID(expectedID);
+ response->setIssueInstant(expectedIssueInstant);
+ // Do this just so don't have to redeclare the saml namespace prefix on every child element in the control XML file
+ Namespace* ns = new Namespace(samlconstants::SAML20_NS, samlconstants::SAML20_PREFIX);
+ response->addNamespace(*ns);
+ response->setIssuer(IssuerBuilder::buildIssuer());
+ // If the form of the default, basic, empty signature that is emittted changes wrt whitespace, etc,
+ // this will probably break the test. In that case need to fix the control XML.
+ response->setSignature(xmlsignature::SignatureBuilder::buildSignature());
+ response->setExtensions(ExtensionsBuilder::buildExtensions());
+ response->setStatus(StatusBuilder::buildStatus());
+
+ Assertion* assertion=nullptr;
+
+ assertion = AssertionBuilder::buildAssertion();
+ assertion->setIssueInstant(expectedIssueInstant);
+ assertion->setID(assertionID1);
+ response->getAssertions().push_back(assertion);
+
+ assertion = AssertionBuilder::buildAssertion();
+ assertion->setIssueInstant(expectedIssueInstant);
+ assertion->setID(assertionID2);
+ response->getAssertions().push_back(assertion);
+
+ response->getEncryptedAssertions().push_back((EncryptedAssertionBuilder::buildEncryptedAssertion()));
+
+ assertion = AssertionBuilder::buildAssertion();
+ assertion->setIssueInstant(expectedIssueInstant);
+ assertion->setID(assertionID3);
+ response->getAssertions().push_back(assertion);
+
+
+ assertEquals(expectedChildElementsDOM, response);
+ delete ns;
+ }
+
+};