1e892a82ca81d80c575acbc8573541e0a6f5b168
[shibboleth/cpp-opensaml.git] / samltest / saml2 / core / impl / AuthzDecisionQuery20Test.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 AuthzDecisionQuery20Test : public CxxTest::TestSuite, public SAMLObjectBaseTestCase {\r
25     XMLCh* expectedID; \r
26     XMLCh* expectedVersion; \r
27     XMLCh* expectedConsent; \r
28     XMLCh* expectedDestination; \r
29     DateTime* expectedIssueInstant; \r
30     XMLCh* expectedResource; \r
31 \r
32 public:\r
33     void setUp() {\r
34         expectedID = XMLString::transcode("abc123");; \r
35         expectedVersion = XMLString::transcode("2.0"); \r
36         expectedConsent = XMLString::transcode("urn:string:consent"); \r
37         expectedDestination = XMLString::transcode("http://idp.example.org/endpoint"); \r
38         expectedIssueInstant = new DateTime(XMLString::transcode("2006-02-21T16:40:00.000Z"));\r
39         expectedResource = XMLString::transcode("urn:string:resource");\r
40 \r
41         singleElementFile = data_path + "saml2/core/impl/AuthzDecisionQuery.xml";\r
42         singleElementOptionalAttributesFile = data_path + "saml2/core/impl/AuthzDecisionQueryOptionalAttributes.xml";\r
43         childElementsFile  = data_path + "saml2/core/impl/AuthzDecisionQueryChildElements.xml";    \r
44         SAMLObjectBaseTestCase::setUp();\r
45     }\r
46     \r
47     void tearDown() {\r
48         XMLString::release(&expectedID);\r
49         XMLString::release(&expectedVersion);\r
50         XMLString::release(&expectedConsent);\r
51         XMLString::release(&expectedDestination);\r
52         XMLString::release(&expectedResource);\r
53         delete expectedIssueInstant;\r
54         SAMLObjectBaseTestCase::tearDown();\r
55     }\r
56 \r
57     void testSingleElementUnmarshall() {\r
58         auto_ptr<XMLObject> xo(unmarshallElement(singleElementFile));\r
59         AuthzDecisionQuery* query = dynamic_cast<AuthzDecisionQuery*>(xo.get());\r
60         TS_ASSERT(query!=NULL);\r
61         assertEquals("ID attribute", expectedID, query->getID());\r
62         assertEquals("Version attribute", expectedVersion, query->getVersion());\r
63         assertEquals("IssueInstant attribute", expectedIssueInstant->getFormattedString(), query->getIssueInstant()->getFormattedString());\r
64         assertEquals("Resource attribute", expectedResource, query->getResource());\r
65 \r
66         TS_ASSERT(query->getIssuer()==NULL);\r
67         TS_ASSERT(query->getSignature()==NULL);\r
68         TS_ASSERT(query->getExtensions()==NULL);\r
69         TS_ASSERT(query->getSubject()==NULL);\r
70         TSM_ASSERT_EQUALS("# of Action child elements", 0, query->getActions().size());\r
71         TS_ASSERT(query->getEvidence()==NULL);\r
72     }\r
73 \r
74     void testSingleElementOptionalAttributesUnmarshall() {\r
75         auto_ptr<XMLObject> xo(unmarshallElement(singleElementOptionalAttributesFile));\r
76         AuthzDecisionQuery* query = dynamic_cast<AuthzDecisionQuery*>(xo.get());\r
77         TS_ASSERT(query!=NULL);\r
78         assertEquals("Consent attribute", expectedConsent, query->getConsent());\r
79         assertEquals("Destination attribute", expectedDestination, query->getDestination());\r
80 \r
81         TS_ASSERT(query->getIssuer()==NULL);\r
82         TS_ASSERT(query->getSignature()==NULL);\r
83         TS_ASSERT(query->getExtensions()==NULL);\r
84         TS_ASSERT(query->getSubject()==NULL);\r
85         TSM_ASSERT_EQUALS("# of Action child elements", 0, query->getActions().size());\r
86         TS_ASSERT(query->getEvidence()==NULL);\r
87     }\r
88 \r
89     void testChildElementsUnmarshall() {\r
90         auto_ptr<XMLObject> xo(unmarshallElement(childElementsFile));\r
91         AuthzDecisionQuery* query= dynamic_cast<AuthzDecisionQuery*>(xo.get());\r
92         TS_ASSERT(query!=NULL);\r
93         TS_ASSERT(query->getIssuer()!=NULL);\r
94         TS_ASSERT(query->getSignature()==NULL);\r
95         TS_ASSERT(query->getExtensions()==NULL);\r
96         TS_ASSERT(query->getSubject()!=NULL);\r
97         TSM_ASSERT_EQUALS("# of Action child elements", 2, query->getActions().size());\r
98         TS_ASSERT(query->getEvidence()!=NULL);\r
99     }\r
100 \r
101     void testSingleElementMarshall() {\r
102         AuthzDecisionQuery* query=AuthzDecisionQueryBuilder::buildAuthzDecisionQuery();\r
103         query->setID(expectedID);\r
104         query->setIssueInstant(expectedIssueInstant);\r
105         //query->setVersion(expectedVersion);\r
106         query->setResource(expectedResource);\r
107         assertEquals(expectedDOM, query);\r
108     }\r
109 \r
110     void testSingleElementOptionalAttributesMarshall() {\r
111         AuthzDecisionQuery* query=AuthzDecisionQueryBuilder::buildAuthzDecisionQuery();\r
112         query->setID(expectedID);\r
113         query->setIssueInstant(expectedIssueInstant);\r
114         //query->setVersion(expectedVersion);\r
115         query->setConsent(expectedConsent);\r
116         query->setDestination(expectedDestination);\r
117         query->setResource(expectedResource);\r
118         assertEquals(expectedOptionalAttributesDOM, query);\r
119     }\r
120 \r
121     void testChildElementsMarshall() {\r
122         AuthzDecisionQuery* query=AuthzDecisionQueryBuilder::buildAuthzDecisionQuery();\r
123         query->setID(expectedID);\r
124         query->setIssueInstant(expectedIssueInstant);\r
125         // Do this just so don't have to redeclare the saml namespace prefix on every child element in the control XML file\r
126         Namespace* ns = new Namespace(opensaml::SAMLConstants::SAML20_NS, opensaml::SAMLConstants::SAML20_PREFIX);\r
127         query->addNamespace(*ns);\r
128         query->setIssuer(IssuerBuilder::buildIssuer());\r
129         query->setSubject(SubjectBuilder::buildSubject());\r
130         query->getActions().push_back(ActionBuilder::buildAction());\r
131         query->getActions().push_back(ActionBuilder::buildAction());\r
132         query->setEvidence(EvidenceBuilder::buildEvidence());\r
133         assertEquals(expectedChildElementsDOM, query);\r
134         delete ns;\r
135     }\r
136 \r
137 };\r