INTEGRATION: CWS sb22 (1.1.2); FILE ADDED

2004/08/20 14:37:58 sb 1.1.2.1: #109743# Test that the API exports the necessary symbols.
This commit is contained in:
Pascal Junck 2004-11-03 08:09:18 +00:00
parent 3c436e2652
commit c62a55b37f

284
salhelper/qa/test_api.cxx Normal file
View file

@ -0,0 +1,284 @@
/*************************************************************************
*
* $RCSfile: test_api.cxx,v $
*
* $Revision: 1.2 $
*
* last change: $Author: pjunck $ $Date: 2004-11-03 09:09:18 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
*
* - GNU Lesser General Public License Version 2.1
* - Sun Industry Standards Source License Version 1.1
*
* Sun Microsystems Inc., October, 2000
*
* GNU Lesser General Public License Version 2.1
* =============================================
* Copyright 2000 by Sun Microsystems, Inc.
* 901 San Antonio Road, Palo Alto, CA 94303, USA
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License version 2.1, as published by the Free Software Foundation.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA
*
*
* Sun Industry Standards Source License Version 1.1
* =================================================
* The contents of this file are subject to the Sun Industry Standards
* Source License Version 1.1 (the "License"); You may not use this file
* except in compliance with the License. You may obtain a copy of the
* License at http://www.openoffice.org/license.html.
*
* Software provided under this License is provided on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
* WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
* MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
* See the License for the specific provisions governing your rights and
* obligations concerning the Software.
*
* The Initial Developer of the Original Code is: Sun Microsystems, Inc.
*
* Copyright: 2000 by Sun Microsystems, Inc.
*
* All Rights Reserved.
*
* Contributor(s): _______________________________________
*
*
************************************************************************/
#include "sal/config.h"
#include <typeinfo>
namespace salhelper {
class Condition;
class ConditionModifier;
class ConditionWaiter;
class ORealDynamicLoader;
class SimpleReferenceObject;
}
namespace {
std::type_info const & getConditionTypeInfo()
{ return typeid (salhelper::Condition *); }
std::type_info const & getConditionModifierTypeInfo()
{ return typeid (salhelper::ConditionModifier *); }
std::type_info const & getConditionWaiterTypeInfo()
{ return typeid (salhelper::ConditionWaiter *); }
std::type_info const & getORealDynamicLoaderTypeInfo()
{ return typeid (salhelper::ORealDynamicLoader *); }
std::type_info const & getSimpleReferenceObjectTypeInfo()
{ return typeid (salhelper::SimpleReferenceObject *); }
}
#include "cppunit/simpleheader.hxx"
#include "osl/mutex.hxx"
#include "salhelper/condition.hxx"
#include "salhelper/dynload.hxx"
#include "salhelper/simplereferenceobject.hxx"
#include <memory>
namespace {
class DerivedCondition: public salhelper::Condition {
public:
explicit DerivedCondition(osl::Mutex & mutex): Condition(mutex) {}
protected:
virtual bool applies() const { return false; }
};
class DerivedConditionWaiterTimedout:
public salhelper::ConditionWaiter::timedout
{};
class DerivedSimpleReferenceObject: public salhelper::SimpleReferenceObject {};
class Test: public CppUnit::TestFixture {
public:
void testCondition();
void testConditionModifier();
void testConditionWaiter();
void testConditionWaiterTimedout();
void testORealDynamicLoader();
void testSimpleReferenceObject();
void testDerivedCondition();
void testDerivedConditionWaiterTimedout();
void testDerivedSimpleReferenceObject();
CPPUNIT_TEST_SUITE(Test);
CPPUNIT_TEST(testCondition);
CPPUNIT_TEST(testConditionModifier);
CPPUNIT_TEST(testConditionWaiter);
CPPUNIT_TEST(testConditionWaiterTimedout);
CPPUNIT_TEST(testORealDynamicLoader);
CPPUNIT_TEST(testSimpleReferenceObject);
CPPUNIT_TEST(testDerivedCondition);
CPPUNIT_TEST(testDerivedConditionWaiterTimedout);
CPPUNIT_TEST(testDerivedSimpleReferenceObject);
CPPUNIT_TEST_SUITE_END();
};
void Test::testCondition() {
osl::Mutex mutex;
std::auto_ptr< salhelper::Condition > p(new DerivedCondition(mutex));
CPPUNIT_ASSERT(typeid (*p.get()) != typeid (salhelper::Condition));
CPPUNIT_ASSERT(typeid (p.get()) == typeid (salhelper::Condition *));
CPPUNIT_ASSERT(
typeid (const_cast< salhelper::Condition const * >(p.get()))
== typeid (salhelper::Condition const *));
CPPUNIT_ASSERT(
typeid (const_cast< salhelper::Condition volatile * >(p.get()))
== typeid (salhelper::Condition volatile *));
CPPUNIT_ASSERT(typeid (salhelper::Condition *) == getConditionTypeInfo());
}
void Test::testConditionModifier() {
salhelper::ConditionModifier * p = 0;
CPPUNIT_ASSERT(typeid (*p) == typeid (salhelper::ConditionModifier));
CPPUNIT_ASSERT(typeid (p) == typeid (salhelper::ConditionModifier *));
CPPUNIT_ASSERT(
typeid (const_cast< salhelper::ConditionModifier const * >(p))
== typeid (salhelper::ConditionModifier const *));
CPPUNIT_ASSERT(
typeid (const_cast< salhelper::ConditionModifier volatile * >(p))
== typeid (salhelper::ConditionModifier volatile *));
CPPUNIT_ASSERT(
typeid (salhelper::ConditionModifier *)
== getConditionModifierTypeInfo());
}
void Test::testConditionWaiter() {
salhelper::ConditionWaiter * p = 0;
CPPUNIT_ASSERT(typeid (*p) == typeid (salhelper::ConditionWaiter));
CPPUNIT_ASSERT(typeid (p) == typeid (salhelper::ConditionWaiter *));
CPPUNIT_ASSERT(
typeid (const_cast< salhelper::ConditionWaiter const * >(p))
== typeid (salhelper::ConditionWaiter const *));
CPPUNIT_ASSERT(
typeid (const_cast< salhelper::ConditionWaiter volatile * >(p))
== typeid (salhelper::ConditionWaiter volatile *));
CPPUNIT_ASSERT(
typeid (salhelper::ConditionWaiter *) == getConditionWaiterTypeInfo());
}
void Test::testConditionWaiterTimedout() {
salhelper::ConditionWaiter::timedout x;
CPPUNIT_ASSERT(typeid (x) == typeid (salhelper::ConditionWaiter::timedout));
CPPUNIT_ASSERT(
typeid (&x) == typeid (salhelper::ConditionWaiter::timedout *));
CPPUNIT_ASSERT(
typeid (const_cast< salhelper::ConditionWaiter::timedout const * >(&x))
== typeid (salhelper::ConditionWaiter::timedout const *));
CPPUNIT_ASSERT(
(typeid
(const_cast< salhelper::ConditionWaiter::timedout volatile * >(&x)))
== typeid (salhelper::ConditionWaiter::timedout volatile *));
try {
throw salhelper::ConditionWaiter::timedout();
} catch (salhelper::ConditionWaiter::timedout &) {
} catch (...) {
CPPUNIT_FAIL("not caught");
}
}
void Test::testORealDynamicLoader() {
salhelper::ORealDynamicLoader * p = 0;
CPPUNIT_ASSERT(typeid (p) != typeid (salhelper::ORealDynamicLoader));
CPPUNIT_ASSERT(typeid (p) == typeid (salhelper::ORealDynamicLoader *));
CPPUNIT_ASSERT(
typeid (const_cast< salhelper::ORealDynamicLoader const * >(p))
== typeid (salhelper::ORealDynamicLoader const *));
CPPUNIT_ASSERT(
typeid (const_cast< salhelper::ORealDynamicLoader volatile * >(p))
== typeid (salhelper::ORealDynamicLoader volatile *));
CPPUNIT_ASSERT(
typeid (salhelper::ORealDynamicLoader *)
== getORealDynamicLoaderTypeInfo());
}
void Test::testSimpleReferenceObject() {
salhelper::SimpleReferenceObject * p = new DerivedSimpleReferenceObject;
try {
CPPUNIT_ASSERT(
typeid (*p) != typeid (salhelper::SimpleReferenceObject));
CPPUNIT_ASSERT(
typeid (p) == typeid (salhelper::SimpleReferenceObject *));
CPPUNIT_ASSERT(
typeid (const_cast< salhelper::SimpleReferenceObject const * >(p))
== typeid (salhelper::SimpleReferenceObject const *));
CPPUNIT_ASSERT(
(typeid
(const_cast< salhelper::SimpleReferenceObject volatile * >(p)))
== typeid (salhelper::SimpleReferenceObject volatile *));
CPPUNIT_ASSERT(
typeid (salhelper::SimpleReferenceObject *)
== getSimpleReferenceObjectTypeInfo());
} catch (...) {
delete static_cast< DerivedSimpleReferenceObject * >(p);
throw;
}
}
void Test::testDerivedCondition() {
osl::Mutex mutex;
std::auto_ptr< salhelper::Condition > p(new DerivedCondition(mutex));
CPPUNIT_ASSERT(dynamic_cast< DerivedCondition * >(p.get()) != 0);
}
void Test::testDerivedConditionWaiterTimedout() {
std::auto_ptr< salhelper::ConditionWaiter::timedout > p(
new DerivedConditionWaiterTimedout);
CPPUNIT_ASSERT(
dynamic_cast< DerivedConditionWaiterTimedout * >(p.get()) != 0);
try {
throw DerivedConditionWaiterTimedout();
} catch (salhelper::ConditionWaiter::timedout &) {
} catch (...) {
CPPUNIT_FAIL("not caught");
}
}
void Test::testDerivedSimpleReferenceObject() {
salhelper::SimpleReferenceObject * p = new DerivedSimpleReferenceObject;
try {
CPPUNIT_ASSERT(dynamic_cast< DerivedSimpleReferenceObject * >(p) != 0);
} catch (...) {
delete static_cast< DerivedSimpleReferenceObject * >(p);
throw;
}
}
CPPUNIT_TEST_SUITE_NAMED_REGISTRATION(Test, "alltests");
}
NOADDITIONAL;