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