-/* $Id: test_thread_pool_observer.cpp,v 1.11 2006-06-10 14:29:13 adam Exp $
- Copyright (c) 2005-2006, Index Data.
+/* This file is part of Metaproxy.
+ Copyright (C) Index Data
- See the LICENSE file for details
- */
+Metaproxy is free software; you can redistribute it and/or modify it under
+the terms of the GNU General Public License as published by the Free
+Software Foundation; either version 2, or (at your option) any later
+version.
+
+Metaproxy is distributed in the hope that it will be useful, but WITHOUT ANY
+WARRANTY; without even the implied warranty of MERCHANTABILITY or
+FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
+for more details.
+
+You should have received a copy of the GNU General Public License
+along with this program; if not, write to the Free Software
+Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
+*/
#include "config.hpp"
#include <stdlib.h>
#include "thread_pool_observer.hpp"
#define BOOST_AUTO_TEST_MAIN
+#define BOOST_TEST_DYN_LINK
#include <boost/test/auto_unit_test.hpp>
using namespace boost::unit_test;
class My_Msg : public mp::IThreadPoolMsg {
public:
mp::IThreadPoolMsg *handle();
- void result();
+ void result(const char *t_info);
+ bool cleanup(void *info);
int m_val;
My_Timer_Thread *m_timer;
};
mp::IThreadPoolMsg *My_Msg::handle()
{
- My_Msg *res = new My_Msg;
-
if (m_val == 7)
sleep(1);
+ return this;
+}
- res->m_val = m_val;
- res->m_timer = m_timer;
- return res;
+bool My_Msg::cleanup(void *info)
+{
+ return false;
}
-void My_Msg::result()
+void My_Msg::result(const char *t_info)
{
m_timer->m_sum += m_val;
m_timer->m_responses++;
+ delete this;
}
My_Timer_Thread::My_Timer_Thread(ISocketObservable *obs,
- mp::ThreadPoolSocketObserver *t) :
- m_obs(obs), m_pipe(9123)
+ mp::ThreadPoolSocketObserver *t) :
+ m_obs(obs), m_pipe(9123)
{
m_t = t;
m_sum = 0;
void My_Timer_Thread::socketNotify(int event)
{
- My_Msg *m = new My_Msg;
- m->m_val = m_requests++;
- m->m_timer = this;
- m_t->put(m);
+ if (m_requests == 30)
+ m_obs->deleteObserver(this);
+ else
+ {
+ My_Msg *m = new My_Msg;
+ m->m_val = m_requests++;
+ m->m_timer = this;
+ m_t->put(m);
+ }
}
-BOOST_AUTO_UNIT_TEST( thread_pool_observer1 )
+BOOST_AUTO_TEST_CASE( thread_pool_observer1 )
{
SocketManager mySocketManager;
- mp::ThreadPoolSocketObserver m(&mySocketManager, 3);
- My_Timer_Thread t(&mySocketManager, &m) ;
+ mp::ThreadPoolSocketObserver m(&mySocketManager, 3, 3, 16*1024);
+ My_Timer_Thread t(&mySocketManager, &m);
+
while (t.m_responses < 30 && mySocketManager.processEvent() > 0)
;
BOOST_CHECK_EQUAL(t.m_responses, 30);
- BOOST_CHECK(t.m_sum >= 435);
+ BOOST_CHECK(t.m_sum >= 435); // = 29*30/2
}
/*
* Local variables:
* c-basic-offset: 4
+ * c-file-style: "Stroustrup"
* indent-tabs-mode: nil
- * c-file-style: "stroustrup"
* End:
* vim: shiftwidth=4 tabstop=8 expandtab
*/