Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "chrome/browser/omnibox/omnibox_field_trial.h" | 5 #include "chrome/browser/omnibox/omnibox_field_trial.h" |
| 6 | 6 |
| 7 #include "base/basictypes.h" | 7 #include "base/basictypes.h" |
| 8 #include "base/metrics/field_trial.h" | 8 #include "base/metrics/field_trial.h" |
| 9 #include "base/strings/string16.h" | 9 #include "base/strings/string16.h" |
| 10 #include "chrome/common/metrics/entropy_provider.h" | 10 #include "chrome/common/metrics/entropy_provider.h" |
| 11 #include "chrome/common/metrics/variations/variations_util.h" | |
| 11 #include "testing/gtest/include/gtest/gtest.h" | 12 #include "testing/gtest/include/gtest/gtest.h" |
| 12 | 13 |
| 13 class OmniboxFieldTrialTest : public testing::Test { | 14 class OmniboxFieldTrialTest : public testing::Test { |
| 14 public: | 15 public: |
| 15 OmniboxFieldTrialTest() {} | 16 OmniboxFieldTrialTest() {} |
| 16 | 17 |
| 17 static void SetUpTestCase() { | 18 static void SetUpTestCase() { |
| 18 ResetFieldTrialList(); | 19 ResetFieldTrialList(); |
|
Alexei Svitkine (slow)
2013/07/31 20:27:46
Hmm, I think this keeps the field trial list persi
Mark P
2013/07/31 21:59:28
These tests pass as-is. (This isn't the changelis
| |
| 19 } | 20 } |
| 20 | 21 |
| 21 static void TearDownTestCase() { | 22 static void TearDownTestCase() { |
| 22 delete field_trial_list_; | 23 delete field_trial_list_; |
| 23 field_trial_list_ = NULL; | 24 field_trial_list_ = NULL; |
| 24 } | 25 } |
| 25 | 26 |
| 26 static void ResetFieldTrialList() { | 27 static void ResetFieldTrialList() { |
| 27 // It's important to delete the old pointer first which sets | 28 // It's important to delete the old pointer first which sets |
| 28 // FieldTrialList::global_ to NULL. | 29 // FieldTrialList::global_ to NULL. |
| (...skipping 93 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 122 | 123 |
| 123 ResetFieldTrialList(); | 124 ResetFieldTrialList(); |
| 124 CreateTestTrial("AutocompleteDynamicTrial_2", "EnableZeroSuggest_Queries"); | 125 CreateTestTrial("AutocompleteDynamicTrial_2", "EnableZeroSuggest_Queries"); |
| 125 EXPECT_TRUE(OmniboxFieldTrial::InZeroSuggestFieldTrial()); | 126 EXPECT_TRUE(OmniboxFieldTrial::InZeroSuggestFieldTrial()); |
| 126 | 127 |
| 127 ResetFieldTrialList(); | 128 ResetFieldTrialList(); |
| 128 CreateTestTrial("AutocompleteDynamicTrial_3", "EnableZeroSuggest_URLs"); | 129 CreateTestTrial("AutocompleteDynamicTrial_3", "EnableZeroSuggest_URLs"); |
| 129 EXPECT_TRUE(OmniboxFieldTrial::InZeroSuggestFieldTrial()); | 130 EXPECT_TRUE(OmniboxFieldTrial::InZeroSuggestFieldTrial()); |
| 130 } | 131 } |
| 131 } | 132 } |
| 133 | |
| 134 TEST_F(OmniboxFieldTrialTest, | |
| 135 GetConsequencesOfRuleInPageClassificationContext) { | |
| 136 // Must be the same as kBundledExperimentFieldTrialName | |
| 137 // defined in omnibox_field_trial.cc. | |
|
Peter Kasting
2013/07/31 20:14:09
Nit: Should we declare this in a .h somewhere, the
Mark P
2013/07/31 21:59:28
I'd rather not have someone reading the .h have to
Alexei Svitkine (slow)
2013/08/01 15:25:35
Fair enough, SGTM.
| |
| 138 const std::string kTrialName = "OmniboxBundledExperimentV1"; | |
| 139 { | |
| 140 std::map<std::string, std::string> params; | |
| 141 params["1:rule1"] = "1-rule1-value"; | |
| 142 params["3:rule1"] = "3-rule1-value"; | |
| 143 params["*:rule1"] = "*-rule1-value"; | |
| 144 params["*:rule2"] = "*-rule2-value"; | |
| 145 params["4:rule3"] = "4-rule3-value"; | |
| 146 params["unrecognized"] = "unrecognized-value"; | |
| 147 ASSERT_TRUE(chrome_variations::AssociateVariationParams( | |
| 148 kTrialName, "A", params)); | |
| 149 } | |
| 150 | |
| 151 base::FieldTrialList::CreateFieldTrial(kTrialName, "A"); | |
| 152 EXPECT_EQ("1-rule1-value", | |
| 153 OmniboxFieldTrial::GetConsequencesOfRuleInPageClassificationContext( | |
| 154 AutocompleteInput::NEW_TAB_PAGE, "rule1")); // exact match | |
| 155 EXPECT_EQ("*-rule1-value", | |
| 156 OmniboxFieldTrial::GetConsequencesOfRuleInPageClassificationContext( | |
| 157 AutocompleteInput::BLANK, "rule1")); // fallback to global | |
| 158 EXPECT_EQ("3-rule1-value", | |
| 159 OmniboxFieldTrial::GetConsequencesOfRuleInPageClassificationContext( | |
| 160 AutocompleteInput::HOMEPAGE, "rule1")); // exact match | |
| 161 EXPECT_EQ("*-rule1-value", | |
| 162 OmniboxFieldTrial::GetConsequencesOfRuleInPageClassificationContext( | |
| 163 AutocompleteInput::OTHER, "rule1")); // fallback to global | |
| 164 EXPECT_EQ("*-rule2-value", | |
| 165 OmniboxFieldTrial::GetConsequencesOfRuleInPageClassificationContext( | |
| 166 AutocompleteInput::HOMEPAGE, "rule2")); // fallback to global | |
| 167 EXPECT_EQ("*-rule2-value", | |
| 168 OmniboxFieldTrial::GetConsequencesOfRuleInPageClassificationContext( | |
| 169 AutocompleteInput::OTHER, "rule2")); // fallback to global | |
| 170 EXPECT_EQ("", | |
| 171 OmniboxFieldTrial::GetConsequencesOfRuleInPageClassificationContext( | |
| 172 AutocompleteInput::BLANK, "rule3")); // no global | |
| 173 EXPECT_EQ("", | |
| 174 OmniboxFieldTrial::GetConsequencesOfRuleInPageClassificationContext( | |
| 175 AutocompleteInput::HOMEPAGE, "rule3")); // no global | |
| 176 EXPECT_EQ("4-rule3-value", | |
| 177 OmniboxFieldTrial::GetConsequencesOfRuleInPageClassificationContext( | |
| 178 AutocompleteInput::OTHER, "rule3")); // exact match | |
| 179 EXPECT_EQ("", | |
| 180 OmniboxFieldTrial::GetConsequencesOfRuleInPageClassificationContext( | |
| 181 AutocompleteInput::OTHER, "rule4")); // no rule at all | |
| 182 } | |
| OLD | NEW |