diff options
author | Vedant Kumar <vsk@apple.com> | 2015-12-22 17:36:17 +0000 |
---|---|---|
committer | Vedant Kumar <vsk@apple.com> | 2015-12-22 17:36:17 +0000 |
commit | d167586a2849c18631c13f37bb2d6ccd14a069cb (patch) | |
tree | 9843884dcb62bf54a07bef4efa44bdc857fb0777 /llvm/unittests/Support | |
parent | e4beddce5543fb41ce328d9368ae502e59de059f (diff) | |
download | bcm5719-llvm-d167586a2849c18631c13f37bb2d6ccd14a069cb.tar.gz bcm5719-llvm-d167586a2849c18631c13f37bb2d6ccd14a069cb.zip |
[Support] Allow multiple paired calls to {start,stop}Timer()
Differential Revision: http://reviews.llvm.org/D15619
Reviewed-by: rafael
llvm-svn: 256258
Diffstat (limited to 'llvm/unittests/Support')
-rw-r--r-- | llvm/unittests/Support/CMakeLists.txt | 1 | ||||
-rw-r--r-- | llvm/unittests/Support/TimerTest.cpp | 49 |
2 files changed, 50 insertions, 0 deletions
diff --git a/llvm/unittests/Support/CMakeLists.txt b/llvm/unittests/Support/CMakeLists.txt index 9bd685759ed..3ab98d58d5f 100644 --- a/llvm/unittests/Support/CMakeLists.txt +++ b/llvm/unittests/Support/CMakeLists.txt @@ -42,6 +42,7 @@ add_llvm_unittest(SupportTests TargetRegistry.cpp ThreadLocalTest.cpp ThreadPool.cpp + TimerTest.cpp TimeValueTest.cpp TrailingObjectsTest.cpp UnicodeTest.cpp diff --git a/llvm/unittests/Support/TimerTest.cpp b/llvm/unittests/Support/TimerTest.cpp new file mode 100644 index 00000000000..ac7c52db6d1 --- /dev/null +++ b/llvm/unittests/Support/TimerTest.cpp @@ -0,0 +1,49 @@ +//===- unittests/TimerTest.cpp - Timer tests ------------------------------===// +// +// The LLVM Compiler Infrastructure +// +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// + +#include "llvm/Support/Timer.h" +#include "gtest/gtest.h" +#include <chrono> +#include <thread> + +using namespace llvm; + +namespace { + +TEST(Timer, Additivity) { + Timer T1("T1"); + + EXPECT_TRUE(T1.isInitialized()); + + T1.startTimer(); + T1.stopTimer(); + auto TR1 = T1.getTotalTime(); + + T1.startTimer(); + std::this_thread::sleep_for(std::chrono::milliseconds(1)); + T1.stopTimer(); + auto TR2 = T1.getTotalTime(); + + EXPECT_TRUE(TR1 < TR2); +} + +TEST(Timer, CheckIfTriggered) { + Timer T1("T1"); + + EXPECT_FALSE(T1.hasTriggered()); + T1.startTimer(); + EXPECT_TRUE(T1.hasTriggered()); + T1.stopTimer(); + EXPECT_TRUE(T1.hasTriggered()); + + T1.clear(); + EXPECT_FALSE(T1.hasTriggered()); +} + +} // end anon namespace |