-/* $Id: test_thread_pool_observer.cpp,v 1.2 2005-10-08 23:29:32 adam Exp $
+/* $Id: test_thread_pool_observer.cpp,v 1.8 2005-12-02 12:21:07 adam Exp $
+ Copyright (c) 2005, Index Data.
+
+%LICENSE%
+ */
+/* $Id: test_thread_pool_observer.cpp,v 1.8 2005-12-02 12:21:07 adam Exp $
Copyright (c) 1998-2005, Index Data.
This file is part of the yaz-proxy.
#include <yaz++/pdu-assoc.h>
#include <yaz++/socket-manager.h>
#include <yaz/log.h>
-#include "thread_pool_observer.h"
+#include "pipe.hpp"
+#include "thread_pool_observer.hpp"
+
+#define BOOST_AUTO_TEST_MAIN
+#include <boost/test/auto_unit_test.hpp>
+using namespace boost::unit_test;
using namespace yazpp_1;
-class My_Msg : public IThreadPoolMsg {
+class My_Timer_Thread;
+
+class My_Msg : public yp2::IThreadPoolMsg {
public:
- IThreadPoolMsg *handle();
+ yp2::IThreadPoolMsg *handle();
void result();
int m_val;
+ My_Timer_Thread *m_timer;
+};
+
+class My_Timer_Thread : public ISocketObserver {
+private:
+ ISocketObservable *m_obs;
+ yp2::Pipe m_pipe;
+ yp2::ThreadPoolSocketObserver *m_t;
+public:
+ int m_sum;
+ int m_requests;
+ int m_responses;
+ My_Timer_Thread(ISocketObservable *obs, yp2::ThreadPoolSocketObserver *t);
+ void socketNotify(int event);
};
-IThreadPoolMsg *My_Msg::handle()
+
+yp2::IThreadPoolMsg *My_Msg::handle()
{
My_Msg *res = new My_Msg;
- int sl = rand() % 5;
+
+ if (m_val == 7)
+ sleep(1);
res->m_val = m_val;
- printf("My_Msg::handle val=%d sleep=%d\n", m_val, sl);
- sleep(sl);
+ res->m_timer = m_timer;
return res;
}
void My_Msg::result()
{
- printf("My_Msg::result val=%d\n", m_val);
+ m_timer->m_sum += m_val;
+ m_timer->m_responses++;
}
-class My_Timer_Thread : public ISocketObserver {
-private:
- ISocketObservable *m_obs;
- int m_fd[2];
- ThreadPoolSocketObserver *m_t;
-public:
- My_Timer_Thread(ISocketObservable *obs, ThreadPoolSocketObserver *t);
- void socketNotify(int event);
-};
-
My_Timer_Thread::My_Timer_Thread(ISocketObservable *obs,
- ThreadPoolSocketObserver *t) : m_obs(obs)
+ yp2::ThreadPoolSocketObserver *t) :
+ m_obs(obs), m_pipe(9123)
{
- pipe(m_fd);
m_t = t;
- obs->addObserver(m_fd[0], this);
+ m_sum = 0;
+ m_requests = 0;
+ m_responses = 0;
+ obs->addObserver(m_pipe.read_fd(), this);
obs->maskObserver(this, SOCKET_OBSERVE_READ);
- obs->timeoutObserver(this, 1);
+ obs->timeoutObserver(this, 0);
}
void My_Timer_Thread::socketNotify(int event)
{
- static int seq = 1;
- printf("Add %d\n", seq);
My_Msg *m = new My_Msg;
- m->m_val = seq++;
+ m->m_val = m_requests++;
+ m->m_timer = this;
m_t->put(m);
}
-int main(int argc, char **argv)
+BOOST_AUTO_UNIT_TEST( thread_pool_observer1 )
{
SocketManager mySocketManager;
- ThreadPoolSocketObserver m(&mySocketManager, 3);
+ yp2::ThreadPoolSocketObserver m(&mySocketManager, 3);
My_Timer_Thread t(&mySocketManager, &m) ;
- int i = 0;
- while (++i < 5 && mySocketManager.processEvent() > 0)
+ while (t.m_responses < 30 && mySocketManager.processEvent() > 0)
;
- return 0;
+ BOOST_CHECK_EQUAL(t.m_responses, 30);
+ BOOST_CHECK(t.m_sum >= 435);
}
+
/*
* Local variables:
* c-basic-offset: 4
* indent-tabs-mode: nil
+ * c-file-style: "stroustrup"
* End:
* vim: shiftwidth=4 tabstop=8 expandtab
*/