summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPascal Junck <pjunck@openoffice.org>2004-11-03 08:09:18 +0000
committerPascal Junck <pjunck@openoffice.org>2004-11-03 08:09:18 +0000
commitc62a55b37f5d8918aa25e2f6876a016b0da13ebc (patch)
treede6659f9590e74ef2a1a1d32811a9b480105d34c
parent3c436e26526d1625428086a5eb029488d54ceaa7 (diff)
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.
-rw-r--r--salhelper/qa/test_api.cxx284
1 files changed, 284 insertions, 0 deletions
diff --git a/salhelper/qa/test_api.cxx b/salhelper/qa/test_api.cxx
new file mode 100644
index 000000000000..72186c911145
--- /dev/null
+++ b/salhelper/qa/test_api.cxx
@@ -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;