summaryrefslogtreecommitdiffstats
path: root/cppuhelper/qa/misc/test_misc.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'cppuhelper/qa/misc/test_misc.cxx')
-rw-r--r--cppuhelper/qa/misc/test_misc.cxx32
1 files changed, 32 insertions, 0 deletions
diff --git a/cppuhelper/qa/misc/test_misc.cxx b/cppuhelper/qa/misc/test_misc.cxx
index 151eb15ea1f6..0e4fdf9efb42 100644
--- a/cppuhelper/qa/misc/test_misc.cxx
+++ b/cppuhelper/qa/misc/test_misc.cxx
@@ -19,9 +19,11 @@ class Test : public ::CppUnit::TestFixture
{
public:
void testCatchThrow();
+ void testgetCaughtException();
CPPUNIT_TEST_SUITE(Test);
CPPUNIT_TEST(testCatchThrow);
+ CPPUNIT_TEST(testgetCaughtException);
CPPUNIT_TEST_SUITE_END();
};
@@ -51,6 +53,36 @@ void Test::testCatchThrow()
}
}
+void Test::testgetCaughtException()
+{
+ css::uno::Any aSavedExceptionAny;
+ std::exception_ptr
+ aSavedException; /// exception caught during unzipping is saved to be thrown during reading
+ try
+ {
+ throw css::uno::RuntimeException("RuntimeException");
+ }
+ catch (...)
+ {
+ aSavedException = std::current_exception();
+ }
+ CPPUNIT_ASSERT(bool(aSavedException));
+ try
+ {
+ std::rethrow_exception(aSavedException);
+ }
+ catch (const css::uno::RuntimeException&)
+ {
+ // the expected case
+ aSavedExceptionAny = cppu::getCaughtException();
+ }
+ catch (...)
+ {
+ CPPUNIT_ASSERT(false);
+ }
+ CPPUNIT_ASSERT(aSavedExceptionAny.hasValue());
+}
+
CPPUNIT_TEST_SUITE_REGISTRATION(Test);
}