2008-10-27 18:04:42 -04:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: tests/events/timertest.cpp
|
|
|
|
// Purpose: Test wxTimer events
|
|
|
|
// Author: Vadim Zeitlin
|
|
|
|
// Created: 2008-10-22
|
|
|
|
// RCS-ID: $Id$
|
|
|
|
// Copyright: (c) 2008 Vadim Zeitlin <vadim@wxwidgets.org>
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// headers
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
#include "testprec.h"
|
|
|
|
|
|
|
|
#ifdef __BORLANDC__
|
|
|
|
#pragma hdrstop
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef WX_PRECOMP
|
|
|
|
#endif // WX_PRECOMP
|
|
|
|
|
|
|
|
#include <time.h>
|
|
|
|
|
|
|
|
#include "wx/evtloop.h"
|
|
|
|
#include "wx/timer.h"
|
|
|
|
|
2010-05-16 11:44:17 -04:00
|
|
|
// --------------------------------------------------------------------------
|
2008-10-27 18:04:42 -04:00
|
|
|
// helper class counting the number of timer events
|
2010-05-16 11:44:17 -04:00
|
|
|
// --------------------------------------------------------------------------
|
|
|
|
|
2008-10-27 18:04:42 -04:00
|
|
|
class TimerCounterHandler : public wxEvtHandler
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
TimerCounterHandler()
|
|
|
|
{
|
|
|
|
m_events = 0;
|
|
|
|
|
|
|
|
Connect(wxEVT_TIMER, wxTimerEventHandler(TimerCounterHandler::OnTimer));
|
|
|
|
}
|
|
|
|
|
|
|
|
int GetNumEvents() const { return m_events; }
|
|
|
|
|
|
|
|
private:
|
|
|
|
void OnTimer(wxTimerEvent& WXUNUSED(event))
|
|
|
|
{
|
|
|
|
m_events++;
|
|
|
|
|
|
|
|
Tick();
|
|
|
|
}
|
|
|
|
|
|
|
|
virtual void Tick() { /* nothing to do in the base class */ }
|
|
|
|
|
|
|
|
int m_events;
|
|
|
|
|
|
|
|
DECLARE_NO_COPY_CLASS(TimerCounterHandler)
|
|
|
|
};
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------
|
|
|
|
// test class
|
|
|
|
// --------------------------------------------------------------------------
|
|
|
|
|
|
|
|
class TimerEventTestCase : public CppUnit::TestCase
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
TimerEventTestCase() {}
|
|
|
|
|
|
|
|
private:
|
|
|
|
CPPUNIT_TEST_SUITE( TimerEventTestCase );
|
|
|
|
CPPUNIT_TEST( OneShot );
|
|
|
|
CPPUNIT_TEST( Multiple );
|
|
|
|
CPPUNIT_TEST_SUITE_END();
|
|
|
|
|
|
|
|
void OneShot();
|
|
|
|
void Multiple();
|
|
|
|
|
|
|
|
DECLARE_NO_COPY_CLASS(TimerEventTestCase)
|
|
|
|
};
|
|
|
|
|
|
|
|
// register in the unnamed registry so that these tests are run by default
|
|
|
|
CPPUNIT_TEST_SUITE_REGISTRATION( TimerEventTestCase );
|
|
|
|
|
|
|
|
// also include in it's own registry so that these tests can be run alone
|
|
|
|
CPPUNIT_TEST_SUITE_NAMED_REGISTRATION( TimerEventTestCase, "TimerEventTestCase" );
|
|
|
|
|
|
|
|
void TimerEventTestCase::OneShot()
|
|
|
|
{
|
|
|
|
class ExitOnTimerHandler : public TimerCounterHandler
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
ExitOnTimerHandler(wxEventLoopBase& loop)
|
|
|
|
: TimerCounterHandler(),
|
|
|
|
m_loop(loop)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
virtual void Tick() { m_loop.Exit(); }
|
|
|
|
|
|
|
|
wxEventLoopBase& m_loop;
|
|
|
|
|
|
|
|
// don't use DECLARE_NO_COPY_CLASS() to avoid upsetting MSVC
|
|
|
|
};
|
|
|
|
|
|
|
|
wxEventLoop loop;
|
|
|
|
|
|
|
|
ExitOnTimerHandler handler(loop);
|
|
|
|
wxTimer timer(&handler);
|
|
|
|
timer.Start(200, true);
|
|
|
|
|
|
|
|
loop.Run();
|
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL( 1, handler.GetNumEvents() );
|
|
|
|
}
|
|
|
|
|
|
|
|
void TimerEventTestCase::Multiple()
|
|
|
|
{
|
2010-10-05 09:37:44 -04:00
|
|
|
// FIXME: This test crashes on wxGTK ANSI build slave for unknown reason,
|
|
|
|
// disable it here to let the rest of the test suite run until this
|
|
|
|
// can be fixed.
|
|
|
|
#if !defined(__WXGTK__) || wxUSE_UNICODE
|
2008-10-27 18:04:42 -04:00
|
|
|
wxEventLoop loop;
|
|
|
|
|
|
|
|
TimerCounterHandler handler;
|
|
|
|
wxTimer timer(&handler);
|
|
|
|
timer.Start(100);
|
|
|
|
|
|
|
|
// run the loop for 2 seconds
|
|
|
|
time_t t;
|
|
|
|
time(&t);
|
|
|
|
const time_t tEnd = t + 2;
|
|
|
|
while ( time(&t) < tEnd )
|
|
|
|
{
|
|
|
|
loop.Dispatch();
|
|
|
|
}
|
|
|
|
|
|
|
|
// we can't count on getting exactly 20 ticks but we shouldn't get more
|
|
|
|
// than this
|
|
|
|
const int numTicks = handler.GetNumEvents();
|
|
|
|
CPPUNIT_ASSERT( numTicks <= 20 );
|
|
|
|
|
2009-03-26 10:58:22 -04:00
|
|
|
// and we should get a decent number of them but if the system is very
|
|
|
|
// loaded (as happens with build bot slaves running a couple of builds in
|
|
|
|
// parallel actually) it may be much less than 20 so just check that we get
|
|
|
|
// more than one
|
|
|
|
CPPUNIT_ASSERT( numTicks > 1 );
|
2010-10-05 09:37:44 -04:00
|
|
|
#endif // !(wxGTK Unicode)
|
2008-10-27 18:04:42 -04:00
|
|
|
}
|