--- /dev/null
+/*\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
+class NameIDMappingRequest20Test : public CxxTest::TestSuite, public SAMLObjectBaseTestCase {\r
+ XMLCh* expectedID; \r
+ XMLCh* expectedVersion; \r
+ DateTime* expectedIssueInstant; \r
+ XMLCh* expectedConsent; \r
+ XMLCh* expectedDestination; \r
+\r
+public:\r
+ void setUp() {\r
+ expectedID = XMLString::transcode("abc123");; \r
+ expectedVersion = XMLString::transcode("2.0"); \r
+ expectedIssueInstant = new DateTime(XMLString::transcode("2006-02-21T16:40:00.000Z"));\r
+ expectedConsent = XMLString::transcode("urn:string:consent"); \r
+ expectedDestination = XMLString::transcode("http://idp.example.org/endpoint"); \r
+\r
+ singleElementFile = data_path + "saml2/core/impl/NameIDMappingRequest.xml";\r
+ singleElementOptionalAttributesFile = data_path + "saml2/core/impl/NameIDMappingRequestOptionalAttributes.xml";\r
+ childElementsFile = data_path + "saml2/core/impl/NameIDMappingRequestChildElements.xml"; \r
+ SAMLObjectBaseTestCase::setUp();\r
+ }\r
+ \r
+ void tearDown() {\r
+ XMLString::release(&expectedID);\r
+ XMLString::release(&expectedVersion);\r
+ XMLString::release(&expectedConsent);\r
+ XMLString::release(&expectedDestination);\r
+ delete expectedIssueInstant;\r
+ SAMLObjectBaseTestCase::tearDown();\r
+ }\r
+\r
+ void testSingleElementUnmarshall() {\r
+ auto_ptr<XMLObject> xo(unmarshallElement(singleElementFile));\r
+ NameIDMappingRequest* request = dynamic_cast<NameIDMappingRequest*>(xo.get());\r
+ TS_ASSERT(request!=NULL);\r
+ assertEquals("ID attribute", expectedID, request->getID());\r
+ assertEquals("Version attribute", expectedVersion, request->getVersion());\r
+ assertEquals("IssueInstant attribute", expectedIssueInstant->getFormattedString(), request->getIssueInstant()->getFormattedString());\r
+\r
+ TS_ASSERT(request->getIssuer()==NULL);\r
+ TS_ASSERT(request->getSignature()==NULL);\r
+ TS_ASSERT(request->getExtensions()==NULL);\r
+ TS_ASSERT(request->getBaseID()==NULL);\r
+ TS_ASSERT(request->getNameID()==NULL);\r
+ TS_ASSERT(request->getEncryptedID()==NULL);\r
+ TS_ASSERT(request->getNameIDPolicy()==NULL);\r
+ }\r
+\r
+ void testSingleElementOptionalAttributesUnmarshall() {\r
+ auto_ptr<XMLObject> xo(unmarshallElement(singleElementOptionalAttributesFile));\r
+ NameIDMappingRequest* request = dynamic_cast<NameIDMappingRequest*>(xo.get());\r
+ TS_ASSERT(request!=NULL);\r
+\r
+ assertEquals("Consent attribute", expectedConsent, request->getConsent());\r
+ assertEquals("Destination attribute", expectedDestination, request->getDestination());\r
+\r
+ TS_ASSERT(request->getIssuer()==NULL);\r
+ TS_ASSERT(request->getSignature()==NULL);\r
+ TS_ASSERT(request->getExtensions()==NULL);\r
+ TS_ASSERT(request->getBaseID()==NULL);\r
+ TS_ASSERT(request->getNameID()==NULL);\r
+ TS_ASSERT(request->getEncryptedID()==NULL);\r
+ TS_ASSERT(request->getNameIDPolicy()==NULL);\r
+ }\r
+\r
+ void testChildElementsUnmarshall() {\r
+ auto_ptr<XMLObject> xo(unmarshallElement(childElementsFile));\r
+ NameIDMappingRequest* request= dynamic_cast<NameIDMappingRequest*>(xo.get());\r
+ TS_ASSERT(request!=NULL);\r
+ TS_ASSERT(request->getIssuer()!=NULL);\r
+ TS_ASSERT(request->getSignature()==NULL);\r
+ TS_ASSERT(request->getExtensions()==NULL);\r
+ TS_ASSERT(request->getBaseID()==NULL);\r
+ TS_ASSERT(request->getNameID()!=NULL);\r
+ TS_ASSERT(request->getEncryptedID()==NULL);\r
+ TS_ASSERT(request->getNameIDPolicy()!=NULL);\r
+ }\r
+\r
+ void testSingleElementMarshall() {\r
+ NameIDMappingRequest* request=NameIDMappingRequestBuilder::buildNameIDMappingRequest();\r
+ request->setID(expectedID);\r
+ request->setIssueInstant(expectedIssueInstant);\r
+ //request->setVersion(expectedVersion);\r
+ assertEquals(expectedDOM, request);\r
+ }\r
+\r
+ void testSingleElementOptionalAttributesMarshall() {\r
+ NameIDMappingRequest* request=NameIDMappingRequestBuilder::buildNameIDMappingRequest();\r
+ request->setID(expectedID);\r
+ request->setIssueInstant(expectedIssueInstant);\r
+ //request->setVersion(expectedVersion);\r
+ request->setConsent(expectedConsent);\r
+ request->setDestination(expectedDestination);\r
+ assertEquals(expectedOptionalAttributesDOM, request);\r
+ }\r
+\r
+ void testChildElementsMarshall() {\r
+ NameIDMappingRequest* request=NameIDMappingRequestBuilder::buildNameIDMappingRequest();\r
+ request->setID(expectedID);\r
+ request->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
+ request->addNamespace(*ns);\r
+ request->setIssuer(IssuerBuilder::buildIssuer());\r
+ request->setNameID(NameIDBuilder::buildNameID());\r
+ request->setNameIDPolicy(NameIDPolicyBuilder::buildNameIDPolicy());\r
+ assertEquals(expectedChildElementsDOM, request);\r
+ delete ns;\r
+ }\r
+\r
+};\r