[email protected] | d778d6e | 2011-08-12 09:47:05 | [diff] [blame] | 1 | // Copyright (c) 2011 The Chromium Authors. All rights reserved. |
[email protected] | e4be2dd | 2010-12-14 00:44:39 | [diff] [blame] | 2 | // Use of this source code is governed by a BSD-style license that can be |
| 3 | // found in the LICENSE file. |
| 4 | |
| 5 | #include "chrome/browser/diagnostics/diagnostics_test.h" |
| 6 | |
[email protected] | 5799981 | 2013-02-24 05:40:52 | [diff] [blame] | 7 | #include "base/files/file_path.h" |
[email protected] | 0c38b26 | 2013-08-23 23:34:24 | [diff] [blame] | 8 | #include "base/logging.h" |
asvitkine | aa06031 | 2016-09-01 22:44:13 | [diff] [blame^] | 9 | #include "base/metrics/histogram_macros.h" |
[email protected] | e4be2dd | 2010-12-14 00:44:39 | [diff] [blame] | 10 | #include "base/path_service.h" |
avi | e4d7b6f | 2015-12-26 00:59:18 | [diff] [blame] | 11 | #include "build/build_config.h" |
[email protected] | e4be2dd | 2010-12-14 00:44:39 | [diff] [blame] | 12 | #include "chrome/common/chrome_constants.h" |
| 13 | #include "chrome/common/chrome_paths.h" |
| 14 | |
[email protected] | f22fae4 | 2013-07-09 21:11:11 | [diff] [blame] | 15 | namespace diagnostics { |
[email protected] | e4be2dd | 2010-12-14 00:44:39 | [diff] [blame] | 16 | |
[email protected] | 0c38b26 | 2013-08-23 23:34:24 | [diff] [blame] | 17 | DiagnosticsTest::DiagnosticsTest(DiagnosticsTestId id) |
| 18 | : id_(id), outcome_code_(-1), result_(DiagnosticsModel::TEST_NOT_RUN) {} |
[email protected] | e4be2dd | 2010-12-14 00:44:39 | [diff] [blame] | 19 | |
[email protected] | f22fae4 | 2013-07-09 21:11:11 | [diff] [blame] | 20 | DiagnosticsTest::~DiagnosticsTest() {} |
| 21 | |
| 22 | bool DiagnosticsTest::Execute(DiagnosticsModel::Observer* observer, |
| 23 | DiagnosticsModel* model, |
| 24 | size_t index) { |
| 25 | start_time_ = base::Time::Now(); |
[email protected] | e4be2dd | 2010-12-14 00:44:39 | [diff] [blame] | 26 | result_ = DiagnosticsModel::TEST_RUNNING; |
[email protected] | e4be2dd | 2010-12-14 00:44:39 | [diff] [blame] | 27 | bool keep_going = ExecuteImpl(observer); |
[email protected] | f22fae4 | 2013-07-09 21:11:11 | [diff] [blame] | 28 | if (observer) |
[email protected] | 60756be | 2013-08-07 05:20:26 | [diff] [blame] | 29 | observer->OnTestFinished(index, model); |
| 30 | return keep_going; |
| 31 | } |
| 32 | |
| 33 | bool DiagnosticsTest::Recover(DiagnosticsModel::Observer* observer, |
| 34 | DiagnosticsModel* model, |
| 35 | size_t index) { |
| 36 | result_ = DiagnosticsModel::RECOVERY_RUNNING; |
| 37 | bool keep_going = RecoveryImpl(observer); |
| 38 | result_ = keep_going ? DiagnosticsModel::RECOVERY_OK |
| 39 | : DiagnosticsModel::RECOVERY_FAIL_STOP; |
[email protected] | 0c38b26 | 2013-08-23 23:34:24 | [diff] [blame] | 40 | #if defined(OS_CHROMEOS) // Only collecting UMA stats on ChromeOS |
| 41 | if (result_ == DiagnosticsModel::RECOVERY_OK) { |
| 42 | RecordUMARecoveryResult(static_cast<DiagnosticsTestId>(GetId()), |
| 43 | RESULT_SUCCESS); |
| 44 | } else { |
| 45 | RecordUMARecoveryResult(static_cast<DiagnosticsTestId>(GetId()), |
| 46 | RESULT_FAILURE); |
| 47 | } |
| 48 | #endif |
[email protected] | 60756be | 2013-08-07 05:20:26 | [diff] [blame] | 49 | if (observer) |
| 50 | observer->OnRecoveryFinished(index, model); |
[email protected] | e4be2dd | 2010-12-14 00:44:39 | [diff] [blame] | 51 | return keep_going; |
| 52 | } |
| 53 | |
[email protected] | f22fae4 | 2013-07-09 21:11:11 | [diff] [blame] | 54 | void DiagnosticsTest::RecordOutcome(int outcome_code, |
| 55 | const std::string& additional_info, |
| 56 | DiagnosticsModel::TestResult result) { |
| 57 | end_time_ = base::Time::Now(); |
| 58 | outcome_code_ = outcome_code; |
[email protected] | e4be2dd | 2010-12-14 00:44:39 | [diff] [blame] | 59 | additional_info_ = additional_info; |
| 60 | result_ = result; |
[email protected] | 0c38b26 | 2013-08-23 23:34:24 | [diff] [blame] | 61 | #if defined(OS_CHROMEOS) // Only collecting UMA stats on ChromeOS |
| 62 | if (result_ == DiagnosticsModel::TEST_OK) { |
| 63 | // Record individual test success. |
| 64 | RecordUMATestResult(static_cast<DiagnosticsTestId>(GetId()), |
| 65 | RESULT_SUCCESS); |
| 66 | } else if (result_ == DiagnosticsModel::TEST_FAIL_CONTINUE || |
| 67 | result_ == DiagnosticsModel::TEST_FAIL_STOP) { |
| 68 | // Record test failure in summary histogram. |
| 69 | UMA_HISTOGRAM_ENUMERATION( |
| 70 | "Diagnostics.TestFailures", GetId(), DIAGNOSTICS_TEST_ID_COUNT); |
| 71 | // Record individual test failure. |
| 72 | RecordUMATestResult(static_cast<DiagnosticsTestId>(GetId()), |
| 73 | RESULT_FAILURE); |
| 74 | } |
| 75 | #endif |
[email protected] | e4be2dd | 2010-12-14 00:44:39 | [diff] [blame] | 76 | } |
| 77 | |
| 78 | // static |
[email protected] | f22fae4 | 2013-07-09 21:11:11 | [diff] [blame] | 79 | base::FilePath DiagnosticsTest::GetUserDefaultProfileDir() { |
[email protected] | 650b2d5 | 2013-02-10 03:41:45 | [diff] [blame] | 80 | base::FilePath path; |
[email protected] | e4be2dd | 2010-12-14 00:44:39 | [diff] [blame] | 81 | if (!PathService::Get(chrome::DIR_USER_DATA, &path)) |
[email protected] | 650b2d5 | 2013-02-10 03:41:45 | [diff] [blame] | 82 | return base::FilePath(); |
[email protected] | d778d6e | 2011-08-12 09:47:05 | [diff] [blame] | 83 | return path.AppendASCII(chrome::kInitialProfile); |
[email protected] | e4be2dd | 2010-12-14 00:44:39 | [diff] [blame] | 84 | } |
[email protected] | f22fae4 | 2013-07-09 21:11:11 | [diff] [blame] | 85 | |
[email protected] | 0c38b26 | 2013-08-23 23:34:24 | [diff] [blame] | 86 | int DiagnosticsTest::GetId() const { return id_; } |
[email protected] | f22fae4 | 2013-07-09 21:11:11 | [diff] [blame] | 87 | |
[email protected] | 0c38b26 | 2013-08-23 23:34:24 | [diff] [blame] | 88 | std::string DiagnosticsTest::GetName() const { return GetTestName(id_); } |
| 89 | |
| 90 | std::string DiagnosticsTest::GetTitle() const { |
| 91 | return GetTestDescription(id_); |
| 92 | } |
[email protected] | f22fae4 | 2013-07-09 21:11:11 | [diff] [blame] | 93 | |
| 94 | DiagnosticsModel::TestResult DiagnosticsTest::GetResult() const { |
| 95 | return result_; |
| 96 | } |
| 97 | |
| 98 | int DiagnosticsTest::GetOutcomeCode() const { return outcome_code_; } |
| 99 | |
| 100 | std::string DiagnosticsTest::GetAdditionalInfo() const { |
| 101 | return additional_info_; |
| 102 | } |
| 103 | |
| 104 | base::Time DiagnosticsTest::GetStartTime() const { return start_time_; } |
| 105 | |
| 106 | base::Time DiagnosticsTest::GetEndTime() const { return end_time_; } |
| 107 | |
[email protected] | 60756be | 2013-08-07 05:20:26 | [diff] [blame] | 108 | bool DiagnosticsTest::RecoveryImpl(DiagnosticsModel::Observer* observer) { |
| 109 | return true; |
[email protected] | 0c38b26 | 2013-08-23 23:34:24 | [diff] [blame] | 110 | } |
[email protected] | 60756be | 2013-08-07 05:20:26 | [diff] [blame] | 111 | |
[email protected] | f22fae4 | 2013-07-09 21:11:11 | [diff] [blame] | 112 | } // namespace diagnostics |