2 * Copyright 2001-2006 Internet2
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
18 #include <saml/saml2/core/Protocols.h>
19 #include <saml/util/SAMLConstants.h>
21 using namespace opensaml::saml2p;
22 using namespace opensaml::saml2;
24 class LogoutRequest20Test : public CxxTest::TestSuite, public SAMLObjectBaseTestCase {
26 XMLCh* expectedVersion;
27 DateTime* expectedIssueInstant;
28 XMLCh* expectedConsent;
29 XMLCh* expectedDestination;
30 XMLCh* expectedReason;
31 DateTime* expectedNotOnOrAfter;
35 expectedID = XMLString::transcode("abc123");;
36 expectedVersion = XMLString::transcode("2.0");
37 expectedIssueInstant = new DateTime(XMLString::transcode("2006-02-21T16:40:00.000Z"));
38 expectedIssueInstant->parseDateTime();
39 expectedConsent = XMLString::transcode("urn:string:consent");
40 expectedDestination = XMLString::transcode("http://idp.example.org/endpoint");
41 expectedReason = XMLString::transcode("urn:string:reason");
42 expectedNotOnOrAfter = new DateTime(XMLString::transcode("2006-02-21T20:45:00.000Z"));
43 expectedNotOnOrAfter->parseDateTime();
45 singleElementFile = data_path + "saml2/core/impl/LogoutRequest.xml";
46 singleElementOptionalAttributesFile = data_path + "saml2/core/impl/LogoutRequestOptionalAttributes.xml";
47 childElementsFile = data_path + "saml2/core/impl/LogoutRequestChildElements.xml";
48 SAMLObjectBaseTestCase::setUp();
52 XMLString::release(&expectedID);
53 XMLString::release(&expectedVersion);
54 XMLString::release(&expectedConsent);
55 XMLString::release(&expectedDestination);
56 XMLString::release(&expectedReason);
57 delete expectedIssueInstant;
58 delete expectedNotOnOrAfter;
59 SAMLObjectBaseTestCase::tearDown();
62 void testSingleElementUnmarshall() {
63 auto_ptr<XMLObject> xo(unmarshallElement(singleElementFile));
64 LogoutRequest* request = dynamic_cast<LogoutRequest*>(xo.get());
65 TS_ASSERT(request!=NULL);
66 assertEquals("ID attribute", expectedID, request->getID());
67 assertEquals("Version attribute", expectedVersion, request->getVersion());
68 TSM_ASSERT_EQUALS("IssueInstant attribute", expectedIssueInstant->getEpoch(), request->getIssueInstant()->getEpoch());
70 TS_ASSERT(request->getIssuer()==NULL);
71 TS_ASSERT(request->getSignature()==NULL);
72 TS_ASSERT(request->getExtensions()==NULL);
73 TS_ASSERT(request->getBaseID()==NULL);
74 TS_ASSERT(request->getNameID()==NULL);
75 TS_ASSERT(request->getEncryptedID()==NULL);
76 TSM_ASSERT_EQUALS("# of SessionIndex child elements", 0, request->getSessionIndexs().size());
79 void testSingleElementOptionalAttributesUnmarshall() {
80 auto_ptr<XMLObject> xo(unmarshallElement(singleElementOptionalAttributesFile));
81 LogoutRequest* request = dynamic_cast<LogoutRequest*>(xo.get());
82 TS_ASSERT(request!=NULL);
84 assertEquals("Consent attribute", expectedConsent, request->getConsent());
85 assertEquals("Destination attribute", expectedDestination, request->getDestination());
86 assertEquals("Reason attribute", expectedReason, request->getReason());
87 TSM_ASSERT_EQUALS("NotOnOrAfter attribute", expectedNotOnOrAfter->getEpoch(), request->getNotOnOrAfter()->getEpoch());
89 TS_ASSERT(request->getIssuer()==NULL);
90 TS_ASSERT(request->getSignature()==NULL);
91 TS_ASSERT(request->getExtensions()==NULL);
92 TS_ASSERT(request->getBaseID()==NULL);
93 TS_ASSERT(request->getNameID()==NULL);
94 TS_ASSERT(request->getEncryptedID()==NULL);
95 TSM_ASSERT_EQUALS("# of SessionIndex child elements", 0, request->getSessionIndexs().size());
98 void testChildElementsUnmarshall() {
99 auto_ptr<XMLObject> xo(unmarshallElement(childElementsFile));
100 LogoutRequest* request= dynamic_cast<LogoutRequest*>(xo.get());
101 TS_ASSERT(request!=NULL);
102 TS_ASSERT(request->getIssuer()!=NULL);
103 TS_ASSERT(request->getSignature()==NULL);
104 TS_ASSERT(request->getExtensions()==NULL);
105 TS_ASSERT(request->getBaseID()==NULL);
106 TS_ASSERT(request->getNameID()!=NULL);
107 TS_ASSERT(request->getEncryptedID()==NULL);
108 TSM_ASSERT_EQUALS("# of SessionIndex child elements", 2, request->getSessionIndexs().size());
111 void testSingleElementMarshall() {
112 LogoutRequest* request=LogoutRequestBuilder::buildLogoutRequest();
113 request->setID(expectedID);
114 request->setIssueInstant(expectedIssueInstant);
115 //request->setVersion(expectedVersion);
116 assertEquals(expectedDOM, request);
119 void testSingleElementOptionalAttributesMarshall() {
120 LogoutRequest* request=LogoutRequestBuilder::buildLogoutRequest();
121 request->setID(expectedID);
122 request->setIssueInstant(expectedIssueInstant);
123 //request->setVersion(expectedVersion);
124 request->setConsent(expectedConsent);
125 request->setDestination(expectedDestination);
126 request->setReason(expectedReason);
127 request->setNotOnOrAfter(expectedNotOnOrAfter);
128 assertEquals(expectedOptionalAttributesDOM, request);
131 void testChildElementsMarshall() {
132 LogoutRequest* request=LogoutRequestBuilder::buildLogoutRequest();
133 request->setID(expectedID);
134 request->setIssueInstant(expectedIssueInstant);
135 // Do this just so don't have to redeclare the saml namespace prefix on every child element in the control XML file
136 Namespace* ns = new Namespace(opensaml::SAMLConstants::SAML20_NS, opensaml::SAMLConstants::SAML20_PREFIX);
137 request->addNamespace(*ns);
138 request->setIssuer(IssuerBuilder::buildIssuer());
139 request->setNameID(NameIDBuilder::buildNameID());
140 request->getSessionIndexs().push_back(SessionIndexBuilder::buildSessionIndex());
141 request->getSessionIndexs().push_back(SessionIndexBuilder::buildSessionIndex());
142 assertEquals(expectedChildElementsDOM, request);