Chromium Code Reviews| Index: components/browser_watcher/postmortem.h |
| diff --git a/components/browser_watcher/postmortem.h b/components/browser_watcher/postmortem.h |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..473e777b6c24d2b39c08b1f7399e6a7b8b6b91d9 |
| --- /dev/null |
| +++ b/components/browser_watcher/postmortem.h |
| @@ -0,0 +1,77 @@ |
| +// Copyright 2016 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. |
| +// |
| +// Following an unclean shutdown, a stability report can be collected and |
| +// submitted for upload to a reporter. |
| + |
| +#ifndef COMPONENTS_BROWSER_WATCHER_POSTMORTEM_H_ |
|
scottmg
2016/08/03 22:47:06
postmortem_report_collector.h?
manzagop (departed)
2016/08/10 15:59:51
Done.
Ah sorry! I should have left the renaming
|
| +#define COMPONENTS_BROWSER_WATCHER_POSTMORTEM_H_ |
| + |
| +#include <memory> |
| +#include <set> |
| +#include <vector> |
| + |
| +#include "base/files/file_path.h" |
| +#include "base/macros.h" |
| +#include "components/browser_watcher/stability_report.pb.h" |
| + |
| +namespace browser_watcher { |
| + |
| +// Collects unclean shutdown information, builds reports out of it and submits |
| +// the reports for upload to a delegate. |
| +// TODO(manzagop): throttling, graceful handling of accumulating data. |
| +// TODO(manzagop): UMA metrics. |
| +class PostmortemReportCollector { |
| + public: |
| + // Handles reporting the stability reports, including validating user consent, |
| + // assigning a report id and potential throttling. Takes ownership of the |
| + // report files. |
| + class ReporterDelegate { |
| + public: |
| + virtual ~ReporterDelegate() = default; |
| + // TODO(manzagop): specific crash keys are desirable. Work it out. |
| + virtual void SubmitReportForUpload(const base::FilePath& minidump) = 0; |
|
scottmg
2016/08/03 22:47:06
Because of the crash report database API, you migh
manzagop (departed)
2016/08/10 15:59:51
I changed a few things and I take a dependency on
|
| + }; |
| + |
| + // Creates a postmortem report collector that will look for unclean shutdown |
| + // data in |debug_dir| using |debug_file_pattern|. If data is found, |
| + // |delegate| will be used for reporting. |
| + PostmortemReportCollector( |
| + const base::FilePath& debug_dir, |
| + const base::FilePath::StringType& debug_file_pattern, |
| + ReporterDelegate* delegate); |
| + virtual ~PostmortemReportCollector() = default; |
| + |
| + // Collects reports about unclean shutdowns and submits them for upload. |
| + // |excluded_debug_files| is a set of files to exclude, such as files |
| + // pertaining to a running instance. |
| + void CollectAndSubmitForUpload( |
| + const std::set<base::FilePath>& excluded_debug_files); |
| + |
| + protected: |
| + // For unittesting. |
|
scottmg
2016/08/03 22:47:06
Maybe private and friend the test.
manzagop (departed)
2016/08/10 15:59:51
Done.
|
| + PostmortemReportCollector(); |
| + |
| + // Virtual and protected for unittesting. |
| + virtual std::vector<base::FilePath> GetDebugStateFilePaths( |
| + const std::set<base::FilePath>& excluded_debug_files); |
| + |
| + // TODO(manzagop): move this for reuse in live scenario. |
| + virtual std::unique_ptr<StabilityReport> Collect( |
| + const base::FilePath& debug_state_file); |
| + |
| + virtual bool CreateReport(const StabilityReport& report, |
| + const base::FilePath& minidump_path); |
| + |
| + private: |
| + base::FilePath debug_state_dir_; |
| + base::FilePath::StringType debug_file_pattern_; |
| + ReporterDelegate* delegate_; |
| + |
| + DISALLOW_COPY_AND_ASSIGN(PostmortemReportCollector); |
| +}; |
| + |
| +} // namespace browser_watcher |
| + |
| +#endif // COMPONENTS_BROWSER_WATCHER_POSTMORTEM_H_ |