aboutsummaryrefslogtreecommitdiffstats
path: root/tests/UnitTest++/src/TimeConstraint.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'tests/UnitTest++/src/TimeConstraint.cpp')
-rw-r--r--tests/UnitTest++/src/TimeConstraint.cpp29
1 files changed, 29 insertions, 0 deletions
diff --git a/tests/UnitTest++/src/TimeConstraint.cpp b/tests/UnitTest++/src/TimeConstraint.cpp
new file mode 100644
index 0000000..b313be7
--- /dev/null
+++ b/tests/UnitTest++/src/TimeConstraint.cpp
@@ -0,0 +1,29 @@
+#include "TimeConstraint.h"
+#include "TestResults.h"
+#include "MemoryOutStream.h"
+#include "CurrentTest.h"
+
+namespace UnitTest {
+
+
+TimeConstraint::TimeConstraint(int ms, TestDetails const& details)
+ : 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.";
+
+ UnitTest::CurrentTest::Results()->OnTestFailure(m_details, stream.GetText());
+ }
+}
+
+}