Change license header, remove stale pkg files.
[shibboleth/cpp-opensaml.git] / samltest / saml1 / core / impl / AttributeDesignatorTest.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/saml1/core/Assertions.h>
23
24 using namespace opensaml::saml1;
25
26 class AttributeDesignatorTest : public CxxTest::TestSuite, public SAMLObjectBaseTestCase {
27     XMLCh* expectedAttributeName;
28     XMLCh* expectedAttributeNamespace;
29
30 public:
31     void setUp() {
32         expectedAttributeName=XMLString::transcode("AttributeName");
33         expectedAttributeNamespace=XMLString::transcode("namespace");
34         singleElementFile = data_path + "saml1/core/impl/singleAttributeDesignator.xml";
35         singleElementOptionalAttributesFile = data_path + "saml1/core/impl/singleAttributeDesignatorAttributes.xml";
36         SAMLObjectBaseTestCase::setUp();
37     }
38     
39     void tearDown() {
40         XMLString::release(&expectedAttributeName);
41         XMLString::release(&expectedAttributeNamespace);
42         SAMLObjectBaseTestCase::tearDown();
43     }
44
45     void testSingleElementUnmarshall() {
46         auto_ptr<XMLObject> xo(unmarshallElement(singleElementFile));
47         AttributeDesignator& ad = dynamic_cast<AttributeDesignator&>(*xo.get());
48         TSM_ASSERT("AttributeName", ad.getAttributeName()==nullptr);
49         TSM_ASSERT("AttributeNamespace", ad.getAttributeNamespace()==nullptr);
50     }
51
52     void testSingleElementOptionalAttributesUnmarshall() {
53         auto_ptr<XMLObject> xo(unmarshallElement(singleElementOptionalAttributesFile));
54         AttributeDesignator& ad = dynamic_cast<AttributeDesignator&>(*xo.get());
55         assertEquals("AttributeName", expectedAttributeName, ad.getAttributeName());
56         assertEquals("AttributeNamespace", expectedAttributeNamespace, ad.getAttributeNamespace());
57     }
58
59     void testSingleElementMarshall() {
60         assertEquals(expectedDOM, AttributeDesignatorBuilder::buildAttributeDesignator());
61     }
62
63     void testSingleElementOptionalAttributesMarshall() {
64         AttributeDesignator* ad=AttributeDesignatorBuilder::buildAttributeDesignator();
65         ad->setAttributeName(expectedAttributeName);
66         ad->setAttributeNamespace(expectedAttributeNamespace);
67         assertEquals(expectedOptionalAttributesDOM, ad);
68     }
69
70 };