summaryrefslogtreecommitdiff
path: root/cpp/test/Ice/library/AllTests.cpp
diff options
context:
space:
mode:
authorBernard Normier <bernard@zeroc.com>2016-08-25 12:15:27 -0400
committerBernard Normier <bernard@zeroc.com>2016-08-25 12:15:27 -0400
commitb0bc915ba0df62edb6d63eb40b41d4dba2968b3a (patch)
tree90b344339957a7dddecf9548ed80d8d930530936 /cpp/test/Ice/library/AllTests.cpp
parentFix ICE-7298 - Visual Studio 2013 build error (diff)
downloadice-b0bc915ba0df62edb6d63eb40b41d4dba2968b3a.tar.bz2
ice-b0bc915ba0df62edb6d63eb40b41d4dba2968b3a.tar.xz
ice-b0bc915ba0df62edb6d63eb40b41d4dba2968b3a.zip
New test for dynamic_cast across shared libraries
Diffstat (limited to 'cpp/test/Ice/library/AllTests.cpp')
-rw-r--r--cpp/test/Ice/library/AllTests.cpp45
1 files changed, 45 insertions, 0 deletions
diff --git a/cpp/test/Ice/library/AllTests.cpp b/cpp/test/Ice/library/AllTests.cpp
new file mode 100644
index 00000000000..30abe4969f2
--- /dev/null
+++ b/cpp/test/Ice/library/AllTests.cpp
@@ -0,0 +1,45 @@
+// **********************************************************************
+//
+// Copyright (c) 2003-2016 ZeroC, Inc. All rights reserved.
+//
+// This copy of Ice is licensed to you under the terms described in the
+// ICE_LICENSE file included in this distribution.
+//
+// **********************************************************************
+
+#include <Ice/Ice.h>
+#include <Test.h>
+
+ICE_DECLSPEC_IMPORT void
+consume(const Ice::ObjectPtr&, const Ice::ObjectPrxPtr&);
+
+#if defined(_MSC_VER)
+# pragma comment(lib, ICE_LIBNAME("consumer"))
+# pragma comment(lib, ICE_LIBNAME("gencode"))
+#endif
+
+class TestI : public Test::MyInterface
+{
+public:
+
+ void op(bool, const Ice::Current& = Ice::noExplicitCurrent);
+
+};
+
+void
+TestI::op(bool throwIt, const Ice::Current&)
+{
+ if(throwIt)
+ {
+ throw Test::UserError("error message");
+ }
+}
+
+ICE_DECLSPEC_EXPORT
+void allTests(const Ice::ObjectAdapterPtr& oa)
+{
+ Test::MyInterfacePtr servant = ICE_MAKE_SHARED(TestI);
+ Test::MyInterfacePrxPtr proxy = ICE_UNCHECKED_CAST(Test::MyInterfacePrx, oa->addWithUUID(servant));
+ consume(servant, proxy);
+}
+