ultimatepp/bazaar/UnitTestTest/TestTimeConstraint.cpp
mdelfede d2b54f7989 changed svn layout
git-svn-id: svn://ultimatepp.org/upp/trunk@281 f0d560ea-af0d-0410-9eb7-867de7ffcac7
2008-06-07 22:31:27 +00:00

57 lines
1.4 KiB
C++

#include <UnitTest++/UnitTest++.h>
#include <UnitTest++/TestResults.h>
#include <UnitTest++/TimeHelpers.h>
#include "RecordingReporter.h"
using namespace UnitTest;
namespace
{
TEST(TimeConstraintSucceedsWithFastTest)
{
TestResults result;
{
TimeConstraint t(200, result, TestDetails("", "", "", 0));
TimeHelpers::SleepMs(5);
}
CHECK_EQUAL(0, result.GetFailureCount());
}
TEST(TimeConstraintFailsWithSlowTest)
{
TestResults result;
{
TimeConstraint t(10, result, TestDetails("", "", "", 0));
TimeHelpers::SleepMs(20);
}
CHECK_EQUAL(1, result.GetFailureCount());
}
TEST(TimeConstraintFailureIncludesCorrectData)
{
RecordingReporter reporter;
TestResults result(&reporter);
{
TestDetails const details("testname", "suitename", "filename", 10);
TimeConstraint t(10, result, details);
TimeHelpers::SleepMs(20);
}
CHECK(std::strstr(reporter.lastFailedFile, "filename"));
CHECK_EQUAL(10, reporter.lastFailedLine);
CHECK(std::strstr(reporter.lastFailedTest, "testname"));
}
TEST(TimeConstraintFailureIncludesTimeoutInformation)
{
RecordingReporter reporter;
TestResults result(&reporter);
{
TimeConstraint t(10, result, TestDetails("", "", "", 0));
TimeHelpers::SleepMs(20);
}
CHECK(std::strstr(reporter.lastFailedMessage, "ime constraint"));
CHECK(std::strstr(reporter.lastFailedMessage, "under 10ms"));
}
}