Multi-line svn commit, see body.
[shibboleth/cpp-opensaml.git] / samltest / saml2 / core / impl / NameIDMappingRequest20Test.h
diff --git a/samltest/saml2/core/impl/NameIDMappingRequest20Test.h b/samltest/saml2/core/impl/NameIDMappingRequest20Test.h
new file mode 100644 (file)
index 0000000..877a0da
--- /dev/null
@@ -0,0 +1,133 @@
+/*\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