[Android] Out with the Android GR, in with the new unified C++ GR
[chromium-blink-merge.git] / base / test / perf_time_logger.h
blob403b2723acf4f43f7db3c9154de2912f8a9e7d6d
1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef BASE_TEST_PERF_TIME_LOGGER_H_
6 #define BASE_TEST_PERF_TIME_LOGGER_H_
8 #include <string>
10 #include "base/basictypes.h"
11 #include "base/timer/elapsed_timer.h"
13 namespace base {
15 // Automates calling LogPerfResult for the common case where you want
16 // to measure the time that something took. Call Done() when the test
17 // is complete if you do extra work after the test or there are stack
18 // objects with potentially expensive constructors. Otherwise, this
19 // class with automatically log on destruction.
20 class PerfTimeLogger {
21 public:
22 explicit PerfTimeLogger(const char* test_name);
23 ~PerfTimeLogger();
25 void Done();
27 private:
28 bool logged_;
29 std::string test_name_;
30 ElapsedTimer timer_;
32 DISALLOW_COPY_AND_ASSIGN(PerfTimeLogger);
35 } // namespace base
37 #endif // BASE_TEST_PERF_TIME_LOGGER_H_