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