-/*\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 AuthnQuery20Test : public CxxTest::TestSuite, public SAMLObjectBaseTestCase {\r
- XMLCh* expectedID; \r
- XMLCh* expectedVersion; \r
- XMLCh* expectedConsent; \r
- XMLCh* expectedDestination; \r
- DateTime* expectedIssueInstant; \r
- XMLCh* expectedSessionIndex; \r
-\r
-public:\r
- void setUp() {\r
- expectedID = XMLString::transcode("abc123");; \r
- expectedVersion = XMLString::transcode("2.0"); \r
- expectedConsent = XMLString::transcode("urn:string:consent"); \r
- expectedDestination = XMLString::transcode("http://idp.example.org/endpoint"); \r
- expectedIssueInstant = new DateTime(XMLString::transcode("2006-02-21T16:40:00.000Z"));\r
- expectedIssueInstant->parseDateTime();\r
- expectedSessionIndex = XMLString::transcode("session12345"); \r
-\r
- singleElementFile = data_path + "saml2/core/impl/AuthnQuery.xml";\r
- singleElementOptionalAttributesFile = data_path + "saml2/core/impl/AuthnQueryOptionalAttributes.xml";\r
- childElementsFile = data_path + "saml2/core/impl/AuthnQueryChildElements.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
- XMLString::release(&expectedSessionIndex);\r
- delete expectedIssueInstant;\r
- SAMLObjectBaseTestCase::tearDown();\r
- }\r
-\r
- void testSingleElementUnmarshall() {\r
- auto_ptr<XMLObject> xo(unmarshallElement(singleElementFile));\r
- AuthnQuery* query = dynamic_cast<AuthnQuery*>(xo.get());\r
- TS_ASSERT(query!=NULL);\r
- assertEquals("ID attribute", expectedID, query->getID());\r
- assertEquals("Version attribute", expectedVersion, query->getVersion());\r
- TSM_ASSERT_EQUALS("IssueInstant attribute", expectedIssueInstant->getEpoch(), query->getIssueInstant()->getEpoch());\r
-\r
- TS_ASSERT(query->getIssuer()==NULL);\r
- TS_ASSERT(query->getSignature()==NULL);\r
- TS_ASSERT(query->getExtensions()==NULL);\r
- TS_ASSERT(query->getSubject()==NULL);\r
- TS_ASSERT(query->getRequestedAuthnContext()==NULL);\r
- }\r
-\r
- void testSingleElementOptionalAttributesUnmarshall() {\r
- auto_ptr<XMLObject> xo(unmarshallElement(singleElementOptionalAttributesFile));\r
- AuthnQuery* query = dynamic_cast<AuthnQuery*>(xo.get());\r
- TS_ASSERT(query!=NULL);\r
- assertEquals("Consent attribute", expectedConsent, query->getConsent());\r
- assertEquals("Destination attribute", expectedDestination, query->getDestination());\r
- assertEquals("SessionIndex attribute", expectedSessionIndex, query->getSessionIndex());\r
-\r
- TS_ASSERT(query->getIssuer()==NULL);\r
- TS_ASSERT(query->getSignature()==NULL);\r
- TS_ASSERT(query->getExtensions()==NULL);\r
- TS_ASSERT(query->getSubject()==NULL);\r
- TS_ASSERT(query->getRequestedAuthnContext()==NULL);\r
- }\r
-\r
- void testChildElementsUnmarshall() {\r
- auto_ptr<XMLObject> xo(unmarshallElement(childElementsFile));\r
- AuthnQuery* query= dynamic_cast<AuthnQuery*>(xo.get());\r
- TS_ASSERT(query!=NULL);\r
- TS_ASSERT(query->getIssuer()!=NULL);\r
- TS_ASSERT(query->getSignature()==NULL);\r
- TS_ASSERT(query->getExtensions()==NULL);\r
- TS_ASSERT(query->getSubject()!=NULL);\r
- TS_ASSERT(query->getRequestedAuthnContext()!=NULL);\r
- }\r
-\r
- void testSingleElementMarshall() {\r
- AuthnQuery* query=AuthnQueryBuilder::buildAuthnQuery();\r
- query->setID(expectedID);\r
- query->setIssueInstant(expectedIssueInstant);\r
- //query->setVersion(expectedVersion);\r
- assertEquals(expectedDOM, query);\r
- }\r
-\r
- void testSingleElementOptionalAttributesMarshall() {\r
- AuthnQuery* query=AuthnQueryBuilder::buildAuthnQuery();\r
- query->setID(expectedID);\r
- query->setIssueInstant(expectedIssueInstant);\r
- //query->setVersion(expectedVersion);\r
- query->setConsent(expectedConsent);\r
- query->setDestination(expectedDestination);\r
- query->setSessionIndex(expectedSessionIndex);\r
- assertEquals(expectedOptionalAttributesDOM, query);\r
- }\r
-\r
- void testChildElementsMarshall() {\r
- AuthnQuery* query=AuthnQueryBuilder::buildAuthnQuery();\r
- query->setID(expectedID);\r
- query->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
- query->addNamespace(*ns);\r
- query->setIssuer(IssuerBuilder::buildIssuer());\r
- query->setSubject(SubjectBuilder::buildSubject());\r
- query->setRequestedAuthnContext(RequestedAuthnContextBuilder::buildRequestedAuthnContext());\r
- assertEquals(expectedChildElementsDOM, query);\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>
+
+using namespace opensaml::saml2p;
+using namespace opensaml::saml2;
+
+class AuthnQuery20Test : public CxxTest::TestSuite, public SAMLObjectBaseTestCase {
+ XMLCh* expectedID;
+ XMLCh* expectedVersion;
+ XMLCh* expectedConsent;
+ XMLCh* expectedDestination;
+ DateTime* expectedIssueInstant;
+ XMLCh* expectedSessionIndex;
+
+public:
+ void setUp() {
+ expectedID = XMLString::transcode("abc123");;
+ expectedVersion = XMLString::transcode("2.0");
+ expectedConsent = XMLString::transcode("urn:string:consent");
+ expectedDestination = XMLString::transcode("http://idp.example.org/endpoint");
+ expectedIssueInstant = new DateTime(XMLString::transcode("2006-02-21T16:40:00.000Z"));
+ expectedIssueInstant->parseDateTime();
+ expectedSessionIndex = XMLString::transcode("session12345");
+
+ singleElementFile = data_path + "saml2/core/impl/AuthnQuery.xml";
+ singleElementOptionalAttributesFile = data_path + "saml2/core/impl/AuthnQueryOptionalAttributes.xml";
+ childElementsFile = data_path + "saml2/core/impl/AuthnQueryChildElements.xml";
+ SAMLObjectBaseTestCase::setUp();
+ }
+
+ void tearDown() {
+ XMLString::release(&expectedID);
+ XMLString::release(&expectedVersion);
+ XMLString::release(&expectedConsent);
+ XMLString::release(&expectedDestination);
+ XMLString::release(&expectedSessionIndex);
+ delete expectedIssueInstant;
+ SAMLObjectBaseTestCase::tearDown();
+ }
+
+ void testSingleElementUnmarshall() {
+ auto_ptr<XMLObject> xo(unmarshallElement(singleElementFile));
+ AuthnQuery* query = dynamic_cast<AuthnQuery*>(xo.get());
+ TS_ASSERT(query!=nullptr);
+ assertEquals("ID attribute", expectedID, query->getID());
+ assertEquals("Version attribute", expectedVersion, query->getVersion());
+ TSM_ASSERT_EQUALS("IssueInstant attribute", expectedIssueInstant->getEpoch(), query->getIssueInstant()->getEpoch());
+
+ TS_ASSERT(query->getIssuer()==nullptr);
+ TS_ASSERT(query->getSignature()==nullptr);
+ TS_ASSERT(query->getExtensions()==nullptr);
+ TS_ASSERT(query->getSubject()==nullptr);
+ TS_ASSERT(query->getRequestedAuthnContext()==nullptr);
+ }
+
+ void testSingleElementOptionalAttributesUnmarshall() {
+ auto_ptr<XMLObject> xo(unmarshallElement(singleElementOptionalAttributesFile));
+ AuthnQuery* query = dynamic_cast<AuthnQuery*>(xo.get());
+ TS_ASSERT(query!=nullptr);
+ assertEquals("Consent attribute", expectedConsent, query->getConsent());
+ assertEquals("Destination attribute", expectedDestination, query->getDestination());
+ assertEquals("SessionIndex attribute", expectedSessionIndex, query->getSessionIndex());
+
+ TS_ASSERT(query->getIssuer()==nullptr);
+ TS_ASSERT(query->getSignature()==nullptr);
+ TS_ASSERT(query->getExtensions()==nullptr);
+ TS_ASSERT(query->getSubject()==nullptr);
+ TS_ASSERT(query->getRequestedAuthnContext()==nullptr);
+ }
+
+ void testChildElementsUnmarshall() {
+ auto_ptr<XMLObject> xo(unmarshallElement(childElementsFile));
+ AuthnQuery* query= dynamic_cast<AuthnQuery*>(xo.get());
+ TS_ASSERT(query!=nullptr);
+ TS_ASSERT(query->getIssuer()!=nullptr);
+ TS_ASSERT(query->getSignature()==nullptr);
+ TS_ASSERT(query->getExtensions()==nullptr);
+ TS_ASSERT(query->getSubject()!=nullptr);
+ TS_ASSERT(query->getRequestedAuthnContext()!=nullptr);
+ }
+
+ void testSingleElementMarshall() {
+ AuthnQuery* query=AuthnQueryBuilder::buildAuthnQuery();
+ query->setID(expectedID);
+ query->setIssueInstant(expectedIssueInstant);
+ //query->setVersion(expectedVersion);
+ assertEquals(expectedDOM, query);
+ }
+
+ void testSingleElementOptionalAttributesMarshall() {
+ AuthnQuery* query=AuthnQueryBuilder::buildAuthnQuery();
+ query->setID(expectedID);
+ query->setIssueInstant(expectedIssueInstant);
+ //query->setVersion(expectedVersion);
+ query->setConsent(expectedConsent);
+ query->setDestination(expectedDestination);
+ query->setSessionIndex(expectedSessionIndex);
+ assertEquals(expectedOptionalAttributesDOM, query);
+ }
+
+ void testChildElementsMarshall() {
+ AuthnQuery* query=AuthnQueryBuilder::buildAuthnQuery();
+ query->setID(expectedID);
+ query->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);
+ query->addNamespace(*ns);
+ query->setIssuer(IssuerBuilder::buildIssuer());
+ query->setSubject(SubjectBuilder::buildSubject());
+ query->setRequestedAuthnContext(RequestedAuthnContextBuilder::buildRequestedAuthnContext());
+ assertEquals(expectedChildElementsDOM, query);
+ delete ns;
+ }
+
+};