#include "wx/stopwatch.h"
#include "wx/utils.h"
+namespace
+{
+
+const long tolerance = 50; // in ms
+const int sleepTime = 500;
+
+} // anonymous namespace
+
// --------------------------------------------------------------------------
// test class
// --------------------------------------------------------------------------
CPPUNIT_TEST_SUITE( StopWatchTestCase );
CPPUNIT_TEST( Misc );
CPPUNIT_TEST( BackwardsClockBug );
+ CPPUNIT_TEST( RestartBug );
CPPUNIT_TEST_SUITE_END();
void Misc();
void BackwardsClockBug();
+ void RestartBug();
DECLARE_NO_COPY_CLASS(StopWatchTestCase)
};
// register in the unnamed registry so that these tests are run by default
CPPUNIT_TEST_SUITE_REGISTRATION( StopWatchTestCase );
-// also include in it's own registry so that these tests can be run alone
+// also include in its own registry so that these tests can be run alone
CPPUNIT_TEST_SUITE_NAMED_REGISTRATION( StopWatchTestCase, "StopWatchTestCase" );
void StopWatchTestCase::Misc()
{
wxStopWatch sw;
- long tmp;
+ long t;
+ wxLongLong usec;
sw.Pause(); // pause it immediately
- wxSleep(2);
- tmp = sw.Time();
- CPPUNIT_ASSERT(tmp >= 0 && tmp < 100);
- // should not have counted while paused!
+ // verify that almost no time elapsed
+ usec = sw.TimeInMicro();
+ WX_ASSERT_MESSAGE
+ (
+ ("Elapsed time was %" wxLongLongFmtSpec "dus", usec),
+ usec < tolerance*1000
+ );
+
+ wxSleep(1);
+ t = sw.Time();
+
+ // check that the stop watch doesn't advance while paused
+ WX_ASSERT_MESSAGE
+ (
+ ("Actual time value is %ld", t),
+ t >= 0 && t < tolerance
+ );
sw.Resume();
- wxSleep(3);
- tmp = sw.Time();
- CPPUNIT_ASSERT(tmp >= 3000 && tmp < 4000);
+ wxMilliSleep(sleepTime);
+ t = sw.Time();
+ // check that it did advance now by ~1.5s
+ WX_ASSERT_MESSAGE
+ (
+ ("Actual time value is %ld", t),
+ t > sleepTime - tolerance && t < sleepTime + tolerance
+ );
sw.Pause();
+
+ // check that this sleep won't be taken into account below
+ wxMilliSleep(sleepTime);
sw.Resume();
- wxSleep(2);
- tmp = sw.Time();
- CPPUNIT_ASSERT(tmp >= 5000 && tmp < 6000);
+ wxMilliSleep(sleepTime);
+ t = sw.Time();
+
+ // and it should advance again
+ WX_ASSERT_MESSAGE
+ (
+ ("Actual time value is %ld", t),
+ t > 2*sleepTime - tolerance && t < 2*sleepTime + tolerance
+ );
}
void StopWatchTestCase::BackwardsClockBug()
}
}
}
+
+void StopWatchTestCase::RestartBug()
+{
+ wxStopWatch sw;
+ sw.Pause();
+
+ // Calling Start() should resume the stopwatch if it was paused.
+ static const int offset = 5000;
+ sw.Start(offset);
+ wxMilliSleep(sleepTime);
+
+ long t = sw.Time();
+ WX_ASSERT_MESSAGE
+ (
+ ("Actual time value is %ld", t),
+ t > offset + sleepTime - tolerance &&
+ t < offset + sleepTime + tolerance
+ );
+}