1*6777b538SAndroid Build Coastguard Worker // Copyright 2013 The Chromium Authors
2*6777b538SAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be
3*6777b538SAndroid Build Coastguard Worker // found in the LICENSE file.
4*6777b538SAndroid Build Coastguard Worker
5*6777b538SAndroid Build Coastguard Worker #include "base/test/perf_log.h"
6*6777b538SAndroid Build Coastguard Worker
7*6777b538SAndroid Build Coastguard Worker #include "base/files/file_util.h"
8*6777b538SAndroid Build Coastguard Worker #include "base/notreached.h"
9*6777b538SAndroid Build Coastguard Worker
10*6777b538SAndroid Build Coastguard Worker namespace base {
11*6777b538SAndroid Build Coastguard Worker
12*6777b538SAndroid Build Coastguard Worker static FILE* perf_log_file = nullptr;
13*6777b538SAndroid Build Coastguard Worker
InitPerfLog(const FilePath & log_file)14*6777b538SAndroid Build Coastguard Worker bool InitPerfLog(const FilePath& log_file) {
15*6777b538SAndroid Build Coastguard Worker if (perf_log_file) {
16*6777b538SAndroid Build Coastguard Worker // trying to initialize twice
17*6777b538SAndroid Build Coastguard Worker NOTREACHED();
18*6777b538SAndroid Build Coastguard Worker return false;
19*6777b538SAndroid Build Coastguard Worker }
20*6777b538SAndroid Build Coastguard Worker
21*6777b538SAndroid Build Coastguard Worker perf_log_file = OpenFile(log_file, "w");
22*6777b538SAndroid Build Coastguard Worker return perf_log_file != nullptr;
23*6777b538SAndroid Build Coastguard Worker }
24*6777b538SAndroid Build Coastguard Worker
FinalizePerfLog()25*6777b538SAndroid Build Coastguard Worker void FinalizePerfLog() {
26*6777b538SAndroid Build Coastguard Worker if (!perf_log_file) {
27*6777b538SAndroid Build Coastguard Worker // trying to cleanup without initializing
28*6777b538SAndroid Build Coastguard Worker NOTREACHED();
29*6777b538SAndroid Build Coastguard Worker return;
30*6777b538SAndroid Build Coastguard Worker }
31*6777b538SAndroid Build Coastguard Worker base::CloseFile(perf_log_file);
32*6777b538SAndroid Build Coastguard Worker }
33*6777b538SAndroid Build Coastguard Worker
LogPerfResult(const char * test_name,double value,const char * units)34*6777b538SAndroid Build Coastguard Worker void LogPerfResult(const char* test_name, double value, const char* units) {
35*6777b538SAndroid Build Coastguard Worker if (!perf_log_file) {
36*6777b538SAndroid Build Coastguard Worker NOTREACHED();
37*6777b538SAndroid Build Coastguard Worker return;
38*6777b538SAndroid Build Coastguard Worker }
39*6777b538SAndroid Build Coastguard Worker
40*6777b538SAndroid Build Coastguard Worker fprintf(perf_log_file, "%s\t%g\t%s\n", test_name, value, units);
41*6777b538SAndroid Build Coastguard Worker printf("%s\t%g\t%s\n", test_name, value, units);
42*6777b538SAndroid Build Coastguard Worker fflush(stdout);
43*6777b538SAndroid Build Coastguard Worker }
44*6777b538SAndroid Build Coastguard Worker
45*6777b538SAndroid Build Coastguard Worker } // namespace base
46