OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/common/variations/variations_util.h" | 5 #include "chrome/common/variations/variations_util.h" |
6 | 6 |
7 #include <stddef.h> | 7 #include <stddef.h> |
8 | 8 |
9 #include <string> | 9 #include <string> |
10 #include <vector> | 10 #include <vector> |
11 | 11 |
12 #include "base/feature_list.h" | 12 #include "base/feature_list.h" |
13 #include "base/metrics/field_trial.h" | 13 #include "base/metrics/field_trial.h" |
14 #include "base/strings/string_split.h" | 14 #include "base/strings/string_split.h" |
15 #include "base/strings/stringprintf.h" | 15 #include "base/strings/stringprintf.h" |
16 #include "chrome/common/variations/fieldtrial_testing_config.h" | 16 #include "chrome/common/variations/fieldtrial_testing_config.h" |
17 #include "components/variations/variations_associated_data.h" | 17 #include "components/variations/variations_associated_data.h" |
18 #include "net/base/escape.h" | 18 #include "net/base/escape.h" |
19 | 19 |
20 namespace chrome_variations { | 20 namespace chrome_variations { |
21 | 21 |
22 namespace { | 22 namespace { |
23 | 23 |
24 std::string EscapeValue(const std::string& value) { | 24 std::string EscapeValue(const std::string& value) { |
25 return net::UnescapeURLComponent( | 25 return net::UnescapeURLComponent( |
26 value, net::UnescapeRule::PATH_SEPARATORS | | 26 value, net::UnescapeRule::PATH_SEPARATORS | |
27 net::UnescapeRule::URL_SPECIAL_CHARS_EXCEPT_PATH_SEPARATORS); | 27 net::UnescapeRule::URL_SPECIAL_CHARS_EXCEPT_PATH_SEPARATORS); |
28 } | 28 } |
29 | 29 |
30 void AssociateParamsFromGroup(const std::string& trial_name, | 30 void AssociateParamsFromExperiment( |
31 const FieldTrialTestingGroup& group, | 31 const std::string& study_name, |
32 base::FeatureList* feature_list) { | 32 const FieldTrialTestingExperiment& experiment, |
33 if (group.params_size != 0) { | 33 base::FeatureList* feature_list) { |
| 34 if (experiment.params_size != 0) { |
34 std::map<std::string, std::string> params; | 35 std::map<std::string, std::string> params; |
35 for (size_t i = 0; i < group.params_size; ++i) { | 36 for (size_t i = 0; i < experiment.params_size; ++i) { |
36 const FieldTrialTestingGroupParams& param = group.params[i]; | 37 const FieldTrialTestingExperimentParams& param = experiment.params[i]; |
37 params[param.key] = param.value; | 38 params[param.key] = param.value; |
38 } | 39 } |
39 variations::AssociateVariationParams(trial_name, group.name, params); | 40 variations::AssociateVariationParams(study_name, experiment.name, params); |
40 } | 41 } |
41 base::FieldTrial* trial = | 42 base::FieldTrial* trial = |
42 base::FieldTrialList::CreateFieldTrial(trial_name, group.name); | 43 base::FieldTrialList::CreateFieldTrial(study_name, experiment.name); |
43 | 44 |
44 if (!trial) { | 45 if (!trial) { |
45 DLOG(WARNING) << "Field trial config trial skipped: " << trial_name | 46 DLOG(WARNING) << "Field trial config study skipped: " << study_name |
46 << "." << group.name | 47 << "." << experiment.name |
47 << " (it is overridden from chrome://flags)"; | 48 << " (it is overridden from chrome://flags)"; |
48 return; | 49 return; |
49 } | 50 } |
50 | 51 |
51 for (size_t i = 0; i < group.enable_features_size; ++i) { | 52 for (size_t i = 0; i < experiment.enable_features_size; ++i) { |
52 feature_list->RegisterFieldTrialOverride( | 53 feature_list->RegisterFieldTrialOverride( |
53 group.enable_features[i], base::FeatureList::OVERRIDE_ENABLE_FEATURE, | 54 experiment.enable_features[i], |
54 trial); | 55 base::FeatureList::OVERRIDE_ENABLE_FEATURE, trial); |
55 } | 56 } |
56 for (size_t i = 0; i < group.disable_features_size; ++i) { | 57 for (size_t i = 0; i < experiment.disable_features_size; ++i) { |
57 feature_list->RegisterFieldTrialOverride( | 58 feature_list->RegisterFieldTrialOverride( |
58 group.disable_features[i], | 59 experiment.disable_features[i], |
59 base::FeatureList::OVERRIDE_DISABLE_FEATURE, trial); | 60 base::FeatureList::OVERRIDE_DISABLE_FEATURE, trial); |
60 } | 61 } |
61 } | 62 } |
62 | 63 |
63 } // namespace | 64 } // namespace |
64 | 65 |
65 bool AssociateParamsFromString(const std::string& varations_string) { | 66 bool AssociateParamsFromString(const std::string& varations_string) { |
66 // Format: Trial1.Group1:k1/v1/k2/v2,Trial2.Group2:k1/v1/k2/v2 | 67 // Format: Trial1.Group1:k1/v1/k2/v2,Trial2.Group2:k1/v1/k2/v2 |
67 std::set<std::pair<std::string, std::string>> trial_groups; | 68 std::set<std::pair<std::string, std::string>> trial_groups; |
68 for (const base::StringPiece& experiment_group : base::SplitStringPiece( | 69 for (const base::StringPiece& experiment_group : base::SplitStringPiece( |
(...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
104 std::string value = EscapeValue(key_values[i + 1]); | 105 std::string value = EscapeValue(key_values[i + 1]); |
105 params[key] = value; | 106 params[key] = value; |
106 } | 107 } |
107 variations::AssociateVariationParams(trial, group, params); | 108 variations::AssociateVariationParams(trial, group, params); |
108 } | 109 } |
109 return true; | 110 return true; |
110 } | 111 } |
111 | 112 |
112 void AssociateParamsFromFieldTrialConfig(const FieldTrialTestingConfig& config, | 113 void AssociateParamsFromFieldTrialConfig(const FieldTrialTestingConfig& config, |
113 base::FeatureList* feature_list) { | 114 base::FeatureList* feature_list) { |
114 for (size_t i = 0; i < config.trials_size; ++i) { | 115 for (size_t i = 0; i < config.studies_size; ++i) { |
115 const FieldTrialTestingTrial& trial = config.trials[i]; | 116 const FieldTrialTestingStudy& study = config.studies[i]; |
116 if (trial.groups_size > 0) { | 117 if (study.experiments_size > 0) { |
117 AssociateParamsFromGroup(trial.name, trial.groups[0], feature_list); | 118 AssociateParamsFromExperiment( |
| 119 study.name, study.experiments[0], feature_list); |
118 } else { | 120 } else { |
119 DLOG(ERROR) << "Unexpected empty trial: " << trial.name; | 121 DLOG(ERROR) << "Unexpected empty study: " << study.name; |
120 } | 122 } |
121 } | 123 } |
122 } | 124 } |
123 | 125 |
124 void AssociateDefaultFieldTrialConfig(base::FeatureList* feature_list) { | 126 void AssociateDefaultFieldTrialConfig(base::FeatureList* feature_list) { |
125 AssociateParamsFromFieldTrialConfig(kFieldTrialConfig, feature_list); | 127 AssociateParamsFromFieldTrialConfig(kFieldTrialConfig, feature_list); |
126 } | 128 } |
127 | 129 |
128 } // namespace chrome_variations | 130 } // namespace chrome_variations |
OLD | NEW |