Index: components/browser_watcher/postmortem_report_collector.h |
diff --git a/components/browser_watcher/postmortem_report_collector.h b/components/browser_watcher/postmortem_report_collector.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..7546961a26589b8034de378c8022e784076583eb |
--- /dev/null |
+++ b/components/browser_watcher/postmortem_report_collector.h |
@@ -0,0 +1,80 @@ |
+// 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_REPORT_COLLECTOR_H_ |
+#define COMPONENTS_BROWSER_WATCHER_POSTMORTEM_REPORT_COLLECTOR_H_ |
+ |
+#include <stdio.h> |
+ |
+#include <memory> |
+#include <set> |
+#include <vector> |
+ |
+#include "base/files/file.h" |
+#include "base/files/file_path.h" |
+#include "base/gtest_prod_util.h" |
+#include "base/macros.h" |
+#include "components/browser_watcher/stability_report.pb.h" |
+#include "third_party/crashpad/crashpad/client/crash_report_database.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 and some error logging. |
Sigurður Ásgeirsson
2016/08/11 17:44:15
as we discussed earlier today, it'd be better^Weas
manzagop (departed)
2016/08/12 21:23:22
Sgtm. Let's include moving the code and this TODO
|
+class PostmortemReportCollector { |
+ public: |
+ // 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, |
+ std::unique_ptr<crashpad::CrashReportDatabase> report_database); |
+ 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); |
+ |
+ private: |
+ FRIEND_TEST_ALL_PREFIXES(PostmortemReportCollectorTest, |
+ GetDebugStateFilePaths); |
+ FRIEND_TEST_ALL_PREFIXES(PostmortemReportCollectorTest, CollectEmptyFile); |
+ FRIEND_TEST_ALL_PREFIXES(PostmortemReportCollectorTest, CollectRandomFile); |
+ FRIEND_TEST_ALL_PREFIXES(PostmortemReportCollectorCollectionTest, |
+ CollectSuccess); |
+ |
+ PostmortemReportCollector(); |
+ |
+ // Virtual for unittesting. |
Sigurður Ásgeirsson
2016/08/11 17:44:15
I do hope there's a test for this method, as it ge
manzagop (departed)
2016/08/12 21:23:22
Well... there is a test!
The reason: I was thinki
|
+ virtual std::vector<base::FilePath> GetDebugStateFilePaths( |
+ const std::set<base::FilePath>& excluded_debug_files); |
+ |
+ // Virtual for unittesting. |
+ // TODO(manzagop): move this for reuse in live scenario. |
+ virtual std::unique_ptr<StabilityReport> Collect( |
+ const base::FilePath& debug_state_file); |
+ |
+ virtual bool WriteReportToMinidump(const StabilityReport& report, |
+ const crashpad::UUID& client_id, |
+ const crashpad::UUID& report_id, |
+ FILE* minidump_file); |
+ |
+ base::FilePath debug_state_dir_; |
Sigurður Ásgeirsson
2016/08/11 17:44:15
there doesn't seem to be any benefit to the debug_
manzagop (departed)
2016/08/12 21:23:22
Agreed, removed. The class is now an empty husk. I
|
+ base::FilePath::StringType debug_file_pattern_; |
+ std::unique_ptr<crashpad::CrashReportDatabase> report_database_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(PostmortemReportCollector); |
+}; |
+ |
+} // namespace browser_watcher |
+ |
+#endif // COMPONENTS_BROWSER_WATCHER_POSTMORTEM_REPORT_COLLECTOR_H_ |