Changes to attempt to silence bcc64x
[ACE_TAO.git] / ACE / tests / Bug_2610_Regression_Test.cpp
blobc0f46ddcfc4b71925b04fadd7bd4b149296b525f
1 /**
2 * @file Bug_2610_Regression_Test.cpp
4 * Reproduces the problems reported in bug 2610:
5 * http://bugzilla.dre.vanderbilt.edu/show_bug.cgi?id=2610
7 * @author Milan Cvetkovic <milan.cvetkovic@mpathix.com>
8 */
10 #include "test_config.h"
11 #include "ace/INET_Addr.h"
12 #include "ace/SOCK_Stream.h"
13 #include "ace/SOCK_Acceptor.h"
14 #include "ace/SOCK_Connector.h"
15 #include "ace/Svc_Handler.h"
16 #include "ace/Acceptor.h"
17 #include "ace/Connector.h"
18 #include "ace/Trace.h"
19 #include "ace/Thread_Semaphore.h"
21 #if defined (ACE_HAS_THREADS)
23 # define TEST_TRACE(X) ACE_Trace ____ (ACE_TEXT (X), __LINE__, ACE_TEXT (__FILE__))
25 int g_svc_handlers_leaked = 0;
26 // use semaphore for synchronization
28 ACE_Thread_Semaphore g_semaphore (0);
30 class My_Svc_Handler : public ACE_Svc_Handler<ACE_SOCK_STREAM,ACE_NULL_SYNCH>
32 public:
33 using super = ACE_Svc_Handler<ACE_SOCK_Stream, ACE_NULL_SYNCH>;
34 My_Svc_Handler()
36 TEST_TRACE ("My_Svc_Handler:My_Svc_Handler");
37 ++g_svc_handlers_leaked;
38 reference_counting_policy().value(
39 Reference_Counting_Policy::ENABLED);
42 ~My_Svc_Handler() override
44 TEST_TRACE ("My_Svc_Handler::~My_Svc_Handler");
45 --g_svc_handlers_leaked;
48 int handle_close (ACE_HANDLE /*fd*/, ACE_Reactor_Mask /*mask*/) override
50 TEST_TRACE ("handle_close");
51 g_semaphore.release();
52 return 0;
56 bool g_acceptor_accept_fails;
58 class My_Acceptor : public ACE_Acceptor<My_Svc_Handler, ACE_SOCK_ACCEPTOR>
60 public:
61 using super = ACE_Acceptor<My_Svc_Handler, ACE_SOCK_Acceptor>;
62 My_Acceptor () : super (ACE_INET_Addr(9000)) {}
64 protected:
65 int accept_svc_handler (My_Svc_Handler *svc_handler) override
67 TEST_TRACE ("accept_svc_handler");
68 int rv = super::accept_svc_handler(svc_handler);
69 if (g_acceptor_accept_fails)
71 g_semaphore.release();
72 return -1;
74 return rv;
76 int activate_svc_handler (My_Svc_Handler* /*svc_handler*/) override
78 TEST_TRACE ("My_Acceptor::activate_svc_handler");
79 g_semaphore.release();
80 return -1;
84 class My_Connector : public ACE_Connector<My_Svc_Handler, ACE_SOCK_CONNECTOR>
86 public:
87 using super = ACE_Connector<My_Svc_Handler, ACE_SOCK_Connector>;
88 protected:
89 int activate_svc_handler (My_Svc_Handler* /*svc_handler*/) override
91 TEST_TRACE ("My_Connector::activate_svc_handler");
92 g_semaphore.release();
93 return -1;
97 struct My_Task : public ACE_Task_Base
99 int svc() override
101 TEST_TRACE ("My_Task::svc");
102 ACE_Reactor::instance()->owner(ACE_OS::thr_self());
103 int rv = ACE_Reactor::instance()->run_reactor_event_loop();
104 if (rv < 0)
106 ACE_ERROR ((LM_ERROR,
107 ACE_TEXT ("%p\n"),
108 ACE_TEXT ("Cannot run reactor event loop")));
110 return 0;
114 // event handler used to signal when the reactor started
115 struct Timer_Handler : public ACE_Event_Handler
117 int handle_timeout (const ACE_Time_Value&, const void*) override
119 g_semaphore.release(); // signal reactor started
120 return 0;
124 #endif
127 run_main (int, ACE_TCHAR *[])
129 ACE_START_TEST (ACE_TEXT ("Bug_2610_Regression_Test"));
131 #if defined (ACE_HAS_THREADS)
133 My_Acceptor acceptor;
134 Timer_Handler timer_handler;
135 ACE_Reactor::instance()->schedule_timer(
136 &timer_handler, 0, ACE_Time_Value(0));
138 My_Task task;
139 int activated = task.activate();
140 if (activated < 0)
142 ACE_ERROR_RETURN ((LM_ERROR,
143 ACE_TEXT ("%p\n"),
144 ACE_TEXT ("Could not activate task")),
145 -1);
148 // Don't assume addr family of the listener - check and adapt when needed.
149 ACE_INET_Addr listen_addr;
150 acceptor.acceptor ().get_local_addr (listen_addr);
151 #if defined (ACE_HAS_IPV6)
152 const ACE_TCHAR *me =
153 listen_addr.get_type () == PF_INET ? ACE_LOCALHOST : ACE_IPV6_LOCALHOST;
154 #else
155 const ACE_TCHAR *me = ACE_LOCALHOST;
156 #endif /* ACE_HAS_IPV6 */
157 ACE_INET_Addr a1 (listen_addr.get_port_number (),
159 listen_addr.get_type ());
160 ACE_SOCK_Connector c1;
161 g_semaphore.acquire();// wait for reactor to start
164 g_acceptor_accept_fails = true;
165 ACE_SOCK_Stream s1;
166 if (-1 == c1.connect (s1, a1))
168 ACE_ERROR_RETURN ((LM_ERROR,
169 ACE_TEXT ("%p\n"),
170 ACE_TEXT ("Could not connect")),
171 -1);
173 g_semaphore.acquire(); // wait for accept_svc_handler() to start
176 g_acceptor_accept_fails = false;
177 ACE_SOCK_Stream s1;
178 if (-1 == c1.connect (s1, a1))
180 ACE_ERROR_RETURN ((LM_ERROR,
181 ACE_TEXT ("%p\n"),
182 ACE_TEXT ("Could not connect")),
183 -1);
185 g_semaphore.acquire(); // wait for activate_svc_handler to complete
189 My_Svc_Handler* handler=0;
190 My_Connector connector;
191 connector.connect (handler, a1);
192 ACE_Event_Handler_var safe_handler (handler);
193 g_semaphore.acquire(); // wait for connect to complete
195 ACE_Reactor::end_event_loop();
196 task.wait();
198 if (g_svc_handlers_leaked != 0)
200 ACE_ERROR_RETURN ((LM_ERROR,
201 ACE_TEXT ("Svc_Handler leakage detected, ")
202 ACE_TEXT ("%d objects remain\n"),
203 g_svc_handlers_leaked),
206 #else
207 ACE_ERROR ((LM_INFO,
208 ACE_TEXT ("threads not supported on this platform\n")));
209 #endif
211 ACE_END_TEST;
213 return 0;