Roll gyp r1967:1970.
[chromium-blink-merge.git] / base / test / perf_log.cc
blob22884b8e69b0953ad01de9b16d3c31435116daba
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 #include "base/test/perf_log.h"
7 #include "base/files/file_util.h"
8 #include "base/logging.h"
10 namespace base {
12 static FILE* perf_log_file = NULL;
14 bool InitPerfLog(const FilePath& log_file) {
15 if (perf_log_file) {
16 // trying to initialize twice
17 NOTREACHED();
18 return false;
21 perf_log_file = OpenFile(log_file, "w");
22 return perf_log_file != NULL;
25 void FinalizePerfLog() {
26 if (!perf_log_file) {
27 // trying to cleanup without initializing
28 NOTREACHED();
29 return;
31 base::CloseFile(perf_log_file);
34 void LogPerfResult(const char* test_name, double value, const char* units) {
35 if (!perf_log_file) {
36 NOTREACHED();
37 return;
40 fprintf(perf_log_file, "%s\t%g\t%s\n", test_name, value, units);
41 printf("%s\t%g\t%s\n", test_name, value, units);
42 fflush(stdout);
45 } // namespace base