Multi-line svn commit, see body.
[shibboleth/cpp-opensaml.git] / samltest / saml2 / core / impl / Response20Test.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 \r
25 class Response20Test : public CxxTest::TestSuite, public SAMLObjectBaseTestCase {\r
26     XMLCh* expectedID; \r
27     XMLCh* expectedInResponseTo; \r
28     XMLCh* expectedVersion; \r
29     XMLCh* expectedConsent; \r
30     XMLCh* expectedDestination; \r
31     DateTime* expectedIssueInstant; \r
32 \r
33     // Assertion marshaller autogenerates ID, Version and IssueInstant if they are NULL,\r
34     // so have to agree on something to put in the control XML\r
35     XMLCh* assertionID1, * assertionID2, * assertionID3;\r
36 \r
37 public:\r
38     void setUp() {\r
39         expectedID = XMLString::transcode("def456"); \r
40         expectedInResponseTo = XMLString::transcode("abc123"); \r
41         expectedVersion = XMLString::transcode("2.0"); \r
42         expectedConsent = XMLString::transcode("urn:string:consent"); \r
43         expectedDestination = XMLString::transcode("http://sp.example.org/endpoint"); \r
44         expectedIssueInstant = new DateTime(XMLString::transcode("2006-02-21T16:40:00.000Z"));\r
45 \r
46         assertionID1 = XMLString::transcode("test1"); \r
47         assertionID2= XMLString::transcode("test2"); \r
48         assertionID3 = XMLString::transcode("test3"); \r
49 \r
50         singleElementFile = data_path + "saml2/core/impl/Response.xml";\r
51         singleElementOptionalAttributesFile = data_path + "saml2/core/impl/ResponseOptionalAttributes.xml";\r
52         childElementsFile  = data_path + "saml2/core/impl/ResponseChildElements.xml";    \r
53         SAMLObjectBaseTestCase::setUp();\r
54     }\r
55     \r
56     void tearDown() {\r
57         XMLString::release(&expectedID);\r
58         XMLString::release(&expectedInResponseTo);\r
59         XMLString::release(&expectedVersion);\r
60         XMLString::release(&expectedConsent);\r
61         XMLString::release(&expectedDestination);\r
62         XMLString::release(&assertionID1);\r
63         XMLString::release(&assertionID2);\r
64         XMLString::release(&assertionID3);\r
65         delete expectedIssueInstant;\r
66         SAMLObjectBaseTestCase::tearDown();\r
67     }\r
68 \r
69     void testSingleElementUnmarshall() {\r
70         auto_ptr<XMLObject> xo(unmarshallElement(singleElementFile));\r
71         Response* response = dynamic_cast<Response*>(xo.get());\r
72         TS_ASSERT(response!=NULL);\r
73 \r
74         assertEquals("ID attribute", expectedID, response->getID());\r
75         assertEquals("Version attribute", expectedVersion, response->getVersion());\r
76         assertEquals("IssueInstant attribute", expectedIssueInstant->getFormattedString(), response->getIssueInstant()->getFormattedString());\r
77 \r
78         TS_ASSERT(response->getIssuer()==NULL);\r
79         TS_ASSERT(response->getSignature()==NULL);\r
80         TS_ASSERT(response->getExtensions()==NULL);\r
81         TS_ASSERT(response->getStatus()==NULL);\r
82         TSM_ASSERT_EQUALS("# of Assertion child elements", 0, response->getAssertions().size());\r
83         TSM_ASSERT_EQUALS("# of EncryptedAssertion child elements", 0, response->getEncryptedAssertions().size());\r
84     }\r
85 \r
86     void testSingleElementOptionalAttributesUnmarshall() {\r
87         auto_ptr<XMLObject> xo(unmarshallElement(singleElementOptionalAttributesFile));\r
88         Response* response = dynamic_cast<Response*>(xo.get());\r
89         TS_ASSERT(response!=NULL);\r
90 \r
91         assertEquals("Consent attribute", expectedConsent, response->getConsent());\r
92         assertEquals("Destination attribute", expectedDestination, response->getDestination());\r
93         assertEquals("InResponseTo attribute", expectedInResponseTo, response->getInResponseTo());\r
94 \r
95         TS_ASSERT(response->getIssuer()==NULL);\r
96         TS_ASSERT(response->getSignature()==NULL);\r
97         TS_ASSERT(response->getExtensions()==NULL);\r
98         TS_ASSERT(response->getStatus()==NULL);\r
99         TSM_ASSERT_EQUALS("# of Assertion child elements", 0, response->getAssertions().size());\r
100         TSM_ASSERT_EQUALS("# of EncryptedAssertion child elements", 0, response->getEncryptedAssertions().size());\r
101     }\r
102 \r
103     void testChildElementsUnmarshall() {\r
104         auto_ptr<XMLObject> xo(unmarshallElement(childElementsFile));\r
105         Response* response= dynamic_cast<Response*>(xo.get());\r
106         TS_ASSERT(response!=NULL);\r
107 \r
108         TS_ASSERT(response->getIssuer()!=NULL);\r
109         TS_ASSERT(response->getSignature()!=NULL);\r
110         TS_ASSERT(response->getExtensions()!=NULL);\r
111         TS_ASSERT(response->getStatus()!=NULL);\r
112         TSM_ASSERT_EQUALS("# of Assertion child elements", 3, response->getAssertions().size());\r
113         TSM_ASSERT_EQUALS("# of EncryptedAssertion child elements", 1, response->getEncryptedAssertions().size());\r
114     }\r
115 \r
116     void testSingleElementMarshall() {\r
117         Response* response = ResponseBuilder::buildResponse();\r
118         TS_ASSERT(response!=NULL);\r
119 \r
120         response->setID(expectedID);\r
121         response->setIssueInstant(expectedIssueInstant);\r
122         //response->setVersion(expectedVersion);\r
123         assertEquals(expectedDOM, response);\r
124     }\r
125 \r
126     void testSingleElementOptionalAttributesMarshall() {\r
127         Response* response = ResponseBuilder::buildResponse();\r
128         TS_ASSERT(response!=NULL);\r
129 \r
130         response->setID(expectedID);\r
131         response->setInResponseTo(expectedInResponseTo);\r
132         response->setIssueInstant(expectedIssueInstant);\r
133         //response->setVersion(expectedVersion);\r
134         response->setConsent(expectedConsent);\r
135         response->setDestination(expectedDestination);\r
136         response->setInResponseTo(expectedInResponseTo);\r
137         assertEquals(expectedOptionalAttributesDOM, response);\r
138     }\r
139 \r
140     void testChildElementsMarshall() {\r
141         Response* response = ResponseBuilder::buildResponse();\r
142         TS_ASSERT(response!=NULL);\r
143 \r
144         response->setID(expectedID);\r
145         response->setIssueInstant(expectedIssueInstant);\r
146         // Do this just so don't have to redeclare the saml namespace prefix on every child element in the control XML file\r
147         Namespace* ns = new Namespace(opensaml::SAMLConstants::SAML20_NS, opensaml::SAMLConstants::SAML20_PREFIX);\r
148         response->addNamespace(*ns);\r
149         response->setIssuer(IssuerBuilder::buildIssuer());\r
150         // If the form of the default, basic, empty signature that is emittted changes wrt whitespace, etc,\r
151         // this will probably break the test.  In that case need to fix the control XML.\r
152         response->setSignature(xmlsignature::SignatureBuilder::buildSignature());\r
153         response->setExtensions(ExtensionsBuilder::buildExtensions());\r
154         response->setStatus(StatusBuilder::buildStatus());\r
155 \r
156         Assertion* assertion=NULL;\r
157 \r
158         assertion = AssertionBuilder::buildAssertion();\r
159         assertion->setIssueInstant(expectedIssueInstant);\r
160         assertion->setID(assertionID1);\r
161         response->getAssertions().push_back(assertion);\r
162 \r
163         assertion = AssertionBuilder::buildAssertion();\r
164         assertion->setIssueInstant(expectedIssueInstant);\r
165         assertion->setID(assertionID2);\r
166         response->getAssertions().push_back(assertion);\r
167 \r
168         response->getEncryptedAssertions().push_back((EncryptedAssertionBuilder::buildEncryptedAssertion()));\r
169 \r
170         assertion = AssertionBuilder::buildAssertion();\r
171         assertion->setIssueInstant(expectedIssueInstant);\r
172         assertion->setID(assertionID3);\r
173         response->getAssertions().push_back(assertion);\r
174 \r
175 \r
176         assertEquals(expectedChildElementsDOM, response);\r
177         delete ns;\r
178     }\r
179 \r
180 };\r