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