blob: 4095535a2b880df61e38d4216e7883ea743c0e4c [file] [log] [blame]
// Copyright 2013 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 "chrome/browser/diagnostics/diagnostics_controller.h"
#include <string>
#include "base/command_line.h"
#include "base/logging.h"
#include "base/memory/scoped_ptr.h"
#include "base/metrics/histogram.h"
#include "base/time/time.h"
#include "chrome/browser/diagnostics/diagnostics_model.h"
#include "chrome/browser/diagnostics/diagnostics_test.h"
#include "chrome/browser/diagnostics/diagnostics_writer.h"
#include "chrome/common/chrome_switches.h"
#if defined(OS_CHROMEOS)
#include "chromeos/chromeos_switches.h"
#endif
namespace diagnostics {
DiagnosticsController* DiagnosticsController::GetInstance() {
return Singleton<DiagnosticsController>::get();
}
DiagnosticsController::DiagnosticsController() : writer_(NULL) {}
DiagnosticsController::~DiagnosticsController() {}
const DiagnosticsModel& DiagnosticsController::GetResults() const {
return *model_;
}
bool DiagnosticsController::HasResults() {
return (model_.get() && model_->GetTestRunCount() > 0);
}
void DiagnosticsController::ClearResults() { model_.reset(); }
void DiagnosticsController::RecordRegularStartup() {
#if defined(OS_CHROMEOS) // Only collecting UMA stats on ChromeOS
// Count the number of normal starts, so we can compare that with the number
// of recovery runs to get a percentage.
UMA_HISTOGRAM_ENUMERATION(
"Diagnostics.RecoveryRun", RECOVERY_NOT_RUN, RECOVERY_RUN_METRICS_COUNT);
// For each of the test types, record a normal start (no diagnostics run), so
// we have a common denominator.
for (int i = 0; i < DIAGNOSTICS_TEST_ID_COUNT; ++i) {
RecordUMARecoveryResult(static_cast<DiagnosticsTestId>(i), RESULT_NOT_RUN);
RecordUMATestResult(static_cast<DiagnosticsTestId>(i), RESULT_NOT_RUN);
}
#endif
}
// This entry point is called from early in startup when very few things have
// been initialized, so be careful what you use.
int DiagnosticsController::Run(const CommandLine& command_line,
DiagnosticsWriter* writer) {
writer_ = writer;
model_.reset(MakeDiagnosticsModel(command_line));
model_->RunAll(writer_);
return 0;
}
// This entry point is called from early in startup when very few things have
// been initialized, so be careful what you use.
int DiagnosticsController::RunRecovery(const CommandLine& command_line,
DiagnosticsWriter* writer) {
// Separate out recoveries that we execute automatically as a result of a
// crash from user-run recoveries.
#if defined(OS_CHROMEOS) // Only collecting UMA stats on ChromeOS
if (command_line.HasSwitch(chromeos::switches::kLoginUser)) {
UMA_HISTOGRAM_ENUMERATION("Diagnostics.RecoveryRun",
diagnostics::RECOVERY_CRASH_RUN,
diagnostics::RECOVERY_RUN_METRICS_COUNT);
} else {
UMA_HISTOGRAM_ENUMERATION("Diagnostics.RecoveryRun",
diagnostics::RECOVERY_USER_RUN,
diagnostics::RECOVERY_RUN_METRICS_COUNT);
}
#endif
if (!HasResults()) {
if (writer) {
writer->WriteInfoLine("No diagnostics have been run.");
writer->OnAllRecoveryDone(model_.get());
}
return -1;
}
writer_ = writer;
model_->RecoverAll(writer_);
return 0;
}
} // namespace diagnostics