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.
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
12 * http://www.apache.org/licenses/LICENSE-2.0
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.
22 #include <saml/saml1/core/Assertions.h>
24 using namespace opensaml::saml1;
26 class AttributeDesignatorTest : public CxxTest::TestSuite, public SAMLObjectBaseTestCase {
27 XMLCh* expectedAttributeName;
28 XMLCh* expectedAttributeNamespace;
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();
40 XMLString::release(&expectedAttributeName);
41 XMLString::release(&expectedAttributeNamespace);
42 SAMLObjectBaseTestCase::tearDown();
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);
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());
59 void testSingleElementMarshall() {
60 assertEquals(expectedDOM, AttributeDesignatorBuilder::buildAttributeDesignator());
63 void testSingleElementOptionalAttributesMarshall() {
64 AttributeDesignator* ad=AttributeDesignatorBuilder::buildAttributeDesignator();
65 ad->setAttributeName(expectedAttributeName);
66 ad->setAttributeNamespace(expectedAttributeNamespace);
67 assertEquals(expectedOptionalAttributesDOM, ad);