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