blob: b202cbcbbf09cb40b22fe30ad12283749e9c0ea1 [file] [log] [blame]
// Copyright (c) 2011 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.
#ifndef CHROME_BROWSER_DIAGNOSTICS_DIAGNOSTICS_MODEL_H_
#define CHROME_BROWSER_DIAGNOSTICS_DIAGNOSTICS_MODEL_H_
#include <stddef.h>
#include <string>
#include "base/time/time.h"
namespace base {
class CommandLine;
}
namespace diagnostics {
// The chrome diagnostics system is a model-view-controller system. The Model
// responsible for holding and running the individual tests and providing a
// uniform interface for querying the outcome.
class DiagnosticsModel {
public:
// A particular test can be in one of the following states.
enum TestResult {
TEST_NOT_RUN,
TEST_RUNNING,
TEST_OK,
TEST_FAIL_CONTINUE,
TEST_FAIL_STOP,
RECOVERY_RUNNING,
RECOVERY_OK,
RECOVERY_FAIL_STOP,
};
// Number of diagnostic tests available on the current platform. To be used
// only by tests to verify that the right number of tests were run.
static const int kDiagnosticsTestCount;
// Observer derived form this class which provides a way to be notified of
// changes to the model as the tests are run. For all the callbacks |id|
// is the index of the test in question and information can be obtained by
// calling model->GetTest(id).
class Observer {
public:
virtual ~Observer() {}
// Called when a test has finished, regardless of outcome.
virtual void OnTestFinished(int index, DiagnosticsModel* model) = 0;
// Called once all the test are run.
virtual void OnAllTestsDone(DiagnosticsModel* model) = 0;
// Called when a recovery has finished regardless of outcome.
virtual void OnRecoveryFinished(int index, DiagnosticsModel* model) = 0;
// Called once all the recoveries are run.
virtual void OnAllRecoveryDone(DiagnosticsModel* model) = 0;
};
// Encapsulates what you can know about a given test.
class TestInfo {
public:
virtual ~TestInfo() {}
// A numerical id for this test. Must be a unique number among all the
// tests.
virtual int GetId() const = 0;
// A parse-able ASCII string that indicates what is being tested.
virtual std::string GetName() const = 0;
// A human readable string that tells you what is being tested.
// This is not localized: it is only meant for developer consumption.
virtual std::string GetTitle() const = 0;
// The result of running the test. If called before the test is ran the
// answer is TEST_NOT_RUN.
virtual TestResult GetResult() const = 0;
// A human readable string that tells you more about what happened. If
// called before the test is run it returns the empty string.
// This is not localized: it is only meant for developer consumption.
virtual std::string GetAdditionalInfo() const = 0;
// A test-specific code representing what happened. If called before the
// test is run, it should return -1.
virtual int GetOutcomeCode() const = 0;
// Returns the system time when the test was performed.
virtual base::Time GetStartTime() const = 0;
// Returns the system time when the test was finished.
virtual base::Time GetEndTime() const = 0;
};
virtual ~DiagnosticsModel() {}
// Returns how many tests have been run.
virtual int GetTestRunCount() const = 0;
// Returns how many tests are available. This value never changes.
virtual int GetTestAvailableCount() const = 0;
// Runs all the available tests, the |observer| callbacks will be called as
// the diagnostics progress. |observer| maybe NULL if no observation is
// needed.
virtual void RunAll(DiagnosticsModel::Observer* observer) = 0;
// Attempt to recover from any failures discovered by testing.
virtual void RecoverAll(DiagnosticsModel::Observer* observer) = 0;
// Get the information for a particular test. Lifetime of returned object is
// limited to the lifetime of this model.
virtual const TestInfo& GetTest(size_t index) const = 0;
// Get the information for a test with given numerical |id|. Lifetime of
// returned object is limited to the lifetime of this model. Returns false if
// there is no such id. |result| may not be NULL.
virtual bool GetTestInfo(int id, const TestInfo** result) const = 0;
};
// The factory for the model. The main purpose is to hide the creation of
// different models for different platforms.
DiagnosticsModel* MakeDiagnosticsModel(const base::CommandLine& cmdline);
} // namespace diagnostics
#endif // CHROME_BROWSER_DIAGNOSTICS_DIAGNOSTICS_MODEL_H_