summaryrefslogtreecommitdiff
path: root/ACE/tests/Bug_2368_Regression_Test.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'ACE/tests/Bug_2368_Regression_Test.cpp')
-rw-r--r--ACE/tests/Bug_2368_Regression_Test.cpp125
1 files changed, 125 insertions, 0 deletions
diff --git a/ACE/tests/Bug_2368_Regression_Test.cpp b/ACE/tests/Bug_2368_Regression_Test.cpp
new file mode 100644
index 00000000000..94e11107e7d
--- /dev/null
+++ b/ACE/tests/Bug_2368_Regression_Test.cpp
@@ -0,0 +1,125 @@
+/**
+ * @file Bug_2368_Regression_Test.cpp
+ *
+ * $Id$
+ *
+ * Reproduces the problems reported in bug 2368:
+ * http://deuce.doc.wustl.edu/bugzilla/show_bug.cgi?id=2368
+ *
+ * @author Johnny Willemsen <jwillemsen@remedy.nl>
+ */
+
+#include "test_config.h"
+#include "ace/Service_Config.h"
+#include "ace/Reactor.h"
+#include "ace/Log_Msg.h"
+#include "ace/Signal.h"
+
+ACE_RCSID (tests,
+ Bug_2368_Regression_Test,
+ "$Id$")
+
+static bool handleA_close_called = false;
+static bool handleB_close_called = false;
+
+class My_HandlerA : public ACE_Event_Handler
+{
+public:
+ virtual int handle_close (ACE_HANDLE,
+ ACE_Reactor_Mask)
+ {
+ ACE_DEBUG ((LM_DEBUG,
+ "Handle close called\n"));
+ handleA_close_called = true;
+
+ return 0;
+ }
+
+ virtual int handle_signal (int,
+ siginfo_t *,
+ ucontext_t *)
+ {
+ ACE_DEBUG ((LM_DEBUG,
+ "Handle signal called\n"));
+
+ return 0;
+ }
+};
+
+class My_HandlerB : public ACE_Event_Handler
+{
+public:
+ virtual int handle_close (ACE_HANDLE,
+ ACE_Reactor_Mask)
+ {
+ ACE_DEBUG ((LM_DEBUG,
+ "Handle close called\n"));
+ handleB_close_called = true;
+
+ return 0;
+ }
+
+ virtual int handle_signal (int,
+ siginfo_t *,
+ ucontext_t *)
+ {
+ ACE_DEBUG ((LM_DEBUG,
+ "Handle signal called\n"));
+
+ return 0;
+ }
+};
+
+int
+run_main (int, ACE_TCHAR *[])
+{
+ ACE_START_TEST (ACE_TEXT ("Bug_2368_Regression_Test"));
+
+ My_HandlerA my_handlerA;
+ My_HandlerB my_handlerB;
+
+ // Set up an ACE signal handler.
+ if (ACE_Reactor::instance ()->register_handler
+ (SIGINT,
+ &my_handlerA) == -1)
+ ACE_ERROR_RETURN ((LM_DEBUG,
+ "%p\n",
+ "register_handlerA"),
+ -1);
+
+ if (ACE_Reactor::instance ()->register_handler
+ (SIGINT,
+ &my_handlerB) == -1)
+ ACE_ERROR_RETURN ((LM_DEBUG,
+ "%p\n",
+ "register_handlerB"),
+ -1);
+
+ ACE_Sig_Action *new_disp = 0;
+ if (ACE_Reactor::instance ()->remove_handler
+ (SIGINT,
+ new_disp) == -1)
+ ACE_ERROR_RETURN ((LM_DEBUG,
+ "%p\n",
+ "remove_handlerB"),
+ -1);
+
+ if (ACE_Reactor::instance ()->close () == -1)
+ ACE_ERROR ((LM_ERROR,
+ "%p\n",
+ "close"));
+
+ if (!handleA_close_called)
+ ACE_ERROR ((LM_ERROR,
+ "Handle close hasn't been called for A. "
+ "This test failure caused by the unresolved bug is EXPECTED!\n"));
+
+ if (!handleB_close_called)
+ ACE_ERROR ((LM_ERROR,
+ "Handle close hasn't been called for B. "
+ "This test failure caused by the unresolved bug is EXPECTED!\n"));
+
+ ACE_END_TEST;
+
+ return 0;
+}