view ext/UnitTest++/src/TimeConstraint.cpp @ 165:fbc55c6f57cf

(Convenient) Timers.
author phoku@33b003aa-7bff-0310-803a-e67f0ece8222
date Wed, 15 Oct 2008 18:04:52 +0000
parents 0d325e9d5953
children
line wrap: on
line source

#include "TimeConstraint.h"
#include "TestResults.h"
#include "MemoryOutStream.h"

namespace UnitTest {


TimeConstraint::TimeConstraint(int ms, TestResults& result, TestDetails const& details)
    : m_result(result)
	, m_details(details)
    , m_maxMs(ms)
{
    m_timer.Start();
}

TimeConstraint::~TimeConstraint()
{
    int const totalTimeInMs = m_timer.GetTimeInMs();
    if (totalTimeInMs > m_maxMs)
    {
        MemoryOutStream stream;
        stream << "Time constraint failed. Expected to run test under " << m_maxMs <<
                  "ms but took " << totalTimeInMs << "ms.";
        m_result.OnTestFailure(m_details, stream.GetText());
    }
}

}