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