| // Copyright (c) 2010 The Chromium Authors. All rights reserved. | 
 | // Use of this source code is governed by a BSD-style license that can be | 
 | // found in the LICENSE file. | 
 |  | 
 | #include "base/test/perf_test_suite.h" | 
 |  | 
 | #include "base/command_line.h" | 
 | #include "base/debug/debugger.h" | 
 | #include "base/files/file_path.h" | 
 | #include "base/path_service.h" | 
 | #include "base/process/launch.h" | 
 | #include "base/strings/string_util.h" | 
 | #include "base/test/perf_log.h" | 
 | #include "build/build_config.h" | 
 | #include "testing/gtest/include/gtest/gtest.h" | 
 |  | 
 | namespace base { | 
 |  | 
 | PerfTestSuite::PerfTestSuite(int argc, char** argv) : TestSuite(argc, argv) {} | 
 |  | 
 | void PerfTestSuite::Initialize() { | 
 |   TestSuite::Initialize(); | 
 |  | 
 |   // Initialize the perf timer log | 
 |   FilePath log_path = | 
 |       CommandLine::ForCurrentProcess()->GetSwitchValuePath("log-file"); | 
 |   if (log_path.empty()) { | 
 |     PathService::Get(FILE_EXE, &log_path); | 
 | #if defined(OS_ANDROID) || defined(OS_FUCHSIA) | 
 |     base::FilePath tmp_dir; | 
 |     PathService::Get(base::DIR_CACHE, &tmp_dir); | 
 |     log_path = tmp_dir.Append(log_path.BaseName()); | 
 | #endif | 
 |     log_path = log_path.ReplaceExtension(FILE_PATH_LITERAL("log")); | 
 |     log_path = log_path.InsertBeforeExtension(FILE_PATH_LITERAL("_perf")); | 
 |   } | 
 |   ASSERT_TRUE(InitPerfLog(log_path)); | 
 |  | 
 |   // Raise to high priority to have more precise measurements. Since we don't | 
 |   // aim at 1% precision, it is not necessary to run at realtime level. | 
 |   if (!debug::BeingDebugged()) | 
 |     RaiseProcessToHighPriority(); | 
 | } | 
 |  | 
 | void PerfTestSuite::Shutdown() { | 
 |   TestSuite::Shutdown(); | 
 |   FinalizePerfLog(); | 
 | } | 
 |  | 
 | }  // namespace base |