Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(81)

Unified Diff: chrome/app/breakpad_unittest_win.cc

Issue 9432033: Add experiments info to crash dumps. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: Last Few Nits Created 8 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « chrome/app/breakpad_field_trial_win.cc ('k') | chrome/app/breakpad_win.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/app/breakpad_unittest_win.cc
===================================================================
--- chrome/app/breakpad_unittest_win.cc (revision 0)
+++ chrome/app/breakpad_unittest_win.cc (revision 0)
@@ -0,0 +1,77 @@
+// Copyright (c) 2012 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 <vector>
+
+#include "base/stringprintf.h"
+#include "breakpad/src/client/windows/common/ipc_protocol.h"
+#include "chrome/app/breakpad_field_trial_win.h"
+#include "chrome/app/breakpad_win.h"
+#include "chrome/common/child_process_logging.h"
+#include "testing/gtest/include/gtest/gtest.h"
+
+using breakpad_win::g_custom_entries;
+using breakpad_win::g_experiment_chunks_offset;
+using breakpad_win::g_num_of_experiments_offset;
+
+class ChromeAppBreakpadTest : public testing::Test {
+ public:
+ ChromeAppBreakpadTest() {
+ testing::InitCustomInfoEntries();
+ }
+
+ protected:
+ typedef std::vector<string16> Experiments;
+ void ValidateExperimentChunks(const Experiments& experiments) {
+ testing::SetExperimentList(experiments);
+ EXPECT_STREQ(base::StringPrintf(L"%d", experiments.size()).c_str(),
+ (*g_custom_entries)[g_num_of_experiments_offset].value);
+ // We make a copy of the array that we empty as we find the experiments.
+ Experiments experiments_left(experiments);
+ for (int i = 0; i < kMaxReportedExperimentChunks; ++i) {
+ EXPECT_STREQ(base::StringPrintf(L"experiment-chunk-%i", i + 1).c_str(),
+ (*g_custom_entries)[g_experiment_chunks_offset + i].name);
+ if (experiments_left.empty()) {
+ // All other slots should be empty.
+ EXPECT_STREQ(
+ L"", (*g_custom_entries)[g_experiment_chunks_offset + i].value);
+ } else {
+ // We can't guarantee the order, so we must search for them all.
+ Experiments::const_iterator experiment = experiments_left.begin();
+ while (experiment != experiments_left.end()) {
+ if (wcsstr((*g_custom_entries)[g_experiment_chunks_offset + i].value,
+ experiment->c_str())) {
+ experiment = experiments_left.erase(experiment);
+ } else {
+ ++experiment;
+ }
+ }
+ }
+ }
+ EXPECT_TRUE(experiments_left.empty());
+ }
+
+ private:
+ static const wchar_t* kNumExperiments;
+ static const size_t kNumExperimentsSize;
+};
+
+const wchar_t* ChromeAppBreakpadTest::kNumExperiments = L"num-experiments";
+const size_t ChromeAppBreakpadTest::kNumExperimentsSize =
+ wcslen(ChromeAppBreakpadTest::kNumExperiments);
+
+TEST_F(ChromeAppBreakpadTest, ExperimentList) {
+ Experiments experiments;
+ experiments.push_back(L"ABCDE-12345");
+ ValidateExperimentChunks(experiments);
+
+ experiments.push_back(L"There-You Are");
+ ValidateExperimentChunks(experiments);
+
+ experiments.push_back(L"Peter-Sellers");
+ ValidateExperimentChunks(experiments);
+
+ experiments.push_back(L"Eat me-Drink me");
+ ValidateExperimentChunks(experiments);
+}
Property changes on: chrome\app\breakpad_unittest_win.cc
___________________________________________________________________
Added: svn:eol-style
+ LF
« no previous file with comments | « chrome/app/breakpad_field_trial_win.cc ('k') | chrome/app/breakpad_win.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698