summaryrefslogtreecommitdiff
path: root/cpp/test/Ice/library/Consumer.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'cpp/test/Ice/library/Consumer.cpp')
-rw-r--r--cpp/test/Ice/library/Consumer.cpp74
1 files changed, 74 insertions, 0 deletions
diff --git a/cpp/test/Ice/library/Consumer.cpp b/cpp/test/Ice/library/Consumer.cpp
new file mode 100644
index 00000000000..0ce1ffe7a19
--- /dev/null
+++ b/cpp/test/Ice/library/Consumer.cpp
@@ -0,0 +1,74 @@
+// **********************************************************************
+//
+// 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 <Test.h>
+#include <TestCommon.h>
+
+#if defined(_MSC_VER)
+# pragma comment(lib, ICE_LIBNAME("gencode"))
+#endif
+
+using namespace std;
+
+ICE_DECLSPEC_EXPORT void
+consume(const Ice::ObjectPtr& o, const Ice::ObjectPrxPtr& p)
+{
+ cout << "testing dynamic cast across libraries... " << flush;
+
+ //
+ // Make sure dynamic cast works as expected
+ // and exception raised by a shared library can be caught by another
+ // shared library
+ //
+
+ Test::MyInterfacePtr servant = ICE_DYNAMIC_CAST(Test::MyInterface, o);
+ test(servant);
+
+#ifdef ICE_CPP11_MAPPING
+ auto proxy = dynamic_pointer_cast<Test::MyInterfacePrx>(p);
+#else
+ Test::MyInterfacePrx proxy = dynamic_cast<IceProxy::Test::MyInterface*>(p.get());
+#endif
+ test(proxy);
+
+ proxy->op(false);
+ servant->op(false, Ice::noExplicitCurrent);
+
+ cout << "ok" << endl;
+
+ cout << "testing exceptions thrown across libraries... " << flush;
+
+ try
+ {
+ proxy->op(true);
+ }
+ catch(const Test::UserError&)
+ {
+ // expected
+ }
+ catch(...)
+ {
+ test(false);
+ }
+
+ try
+ {
+ servant->op(true);
+ }
+ catch(const Test::UserError&)
+ {
+ // expected
+ }
+ catch(...)
+ {
+ test(false);
+ }
+
+ cout << "ok" << endl;
+}