Index: components/ntp_tiles/field_trial.cc |
diff --git a/components/ntp_tiles/field_trial.cc b/components/ntp_tiles/field_trial.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..779b5b85953135f38dcbd633fe17a5e56fb5ccef |
--- /dev/null |
+++ b/components/ntp_tiles/field_trial.cc |
@@ -0,0 +1,82 @@ |
+// 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. |
+ |
+#include "base/metrics/field_trial.h" |
+ |
+#if defined(OS_ANDROID) |
+#include <jni.h> |
+#endif |
+ |
+#include "base/command_line.h" |
+#include "base/metrics/field_trial.h" |
+#include "base/strings/string_util.h" |
+#include "components/ntp_tiles/constants.h" |
+#include "components/ntp_tiles/field_trial.h" |
+#include "components/ntp_tiles/switches.h" |
+ |
+#if defined(OS_ANDROID) |
+#include "base/android/jni_android.h" |
+#include "jni/MostVisitedSites_jni.h" |
+#endif |
+ |
+const char kPopularSiteDefaultGroup[] = "Default"; |
+const char kPopularSiteControlGroup[] = "Control"; |
+const char kPopularSiteEnabledGroup[] = "Enabled"; |
+const char kPopularSiteEnabledCommandLineSwitchGroup[] = |
+ "EnabledWithCommandLineSwitch"; |
+const char kPopularSiteDisabledCommandLineSwitchGroup[] = |
+ "DisabledWithCommandLineSwitch"; |
+ |
+void ntp_tiles::SetUpFirstLaunchFieldTrial(bool is_stable_channel) { |
rkaplow
2016/11/10 22:56:46
can you comment this is done as a workaround since
noyau (Ping after 24h)
2016/11/14 17:08:08
Done.
|
+ // Stable channels will run with 10% probability. |
rkaplow
2016/11/10 22:56:46
this is higher a % that we usually experiment on s
noyau (Ping after 24h)
2016/11/14 17:08:08
Not on iOS, were volume are low compared to deskto
rkaplow
2016/11/14 23:42:51
Ok.. in either case this will need to get approval
noyau (Ping after 24h)
2016/11/15 09:05:50
The highlight is already there: The first sentence
|
+ // Non-stable channels will run with 50% probability. |
+ const base::FieldTrial::Probability kTotalProbability = 100; |
+ const base::FieldTrial::Probability kEnabledAndControlProbability = |
+ is_stable_channel ? 10 : 50; |
+ |
+ // Experiment enabled until March 15, 2017. By default, disabled. |
noyau (Ping after 24h)
2016/11/09 10:56:39
Before creating the new experiment should I check
rkaplow
2016/11/10 22:56:46
I think it would make sense to check in case here
noyau (Ping after 24h)
2016/11/14 17:08:08
Is Find the correct way to test for this without t
rkaplow
2016/11/14 23:42:51
I think TrialExists should work since we don't nee
noyau (Ping after 24h)
2016/11/15 09:05:50
Done.
|
+ scoped_refptr<base::FieldTrial> trial( |
+ base::FieldTrialList::FactoryGetFieldTrial( |
+ kPopularSitesFieldTrialName, kTotalProbability, |
+ kPopularSiteDefaultGroup, 2017, 3, 15, // Mar 15, 2017 |
+ base::FieldTrial::ONE_TIME_RANDOMIZED, NULL)); |
+ |
+ base::CommandLine* command_line = base::CommandLine::ForCurrentProcess(); |
+ if (command_line->HasSwitch(ntp_tiles::switches::kEnableNTPPopularSites)) { |
+ trial->AppendGroup(kPopularSiteEnabledCommandLineSwitchGroup, |
+ kTotalProbability); |
+ } else if (command_line->HasSwitch( |
+ ntp_tiles::switches::kDisableNTPPopularSites)) { |
+ trial->AppendGroup(kPopularSiteDisabledCommandLineSwitchGroup, |
+ kTotalProbability); |
+ } else { |
+ trial->AppendGroup(kPopularSiteControlGroup, kEnabledAndControlProbability); |
+ trial->AppendGroup(kPopularSiteEnabledGroup, kEnabledAndControlProbability); |
+ } |
+ trial->group(); |
+} |
+ |
+bool ntp_tiles::ShouldShowPopularSites() { |
+ // Note: It's important to query the field trial state first, to ensure that |
+ // UMA reports the correct group. |
+ const std::string group_name = |
+ base::FieldTrialList::FindFullName(kPopularSitesFieldTrialName); |
+ |
+ base::CommandLine* cmd_line = base::CommandLine::ForCurrentProcess(); |
+ if (cmd_line->HasSwitch(switches::kDisableNTPPopularSites)) |
+ return false; |
+ |
+ if (cmd_line->HasSwitch(switches::kEnableNTPPopularSites)) |
+ return true; |
+ |
+#if defined(OS_ANDROID) |
+ if (Java_MostVisitedSites_isPopularSitesForceEnabled( |
+ base::android::AttachCurrentThread())) { |
+ return true; |
+ } |
+#endif |
+ |
+ return base::StartsWith(group_name, "Enabled", |
+ base::CompareCase::INSENSITIVE_ASCII); |
+} |