Index: components/ntp_snippets/features.cc |
diff --git a/components/ntp_snippets/features.cc b/components/ntp_snippets/features.cc |
index 0b90a4271f144b03a196249075c01dcd95045b5c..5429babee68cf247c87d043f5cbddbdae513338e 100644 |
--- a/components/ntp_snippets/features.cc |
+++ b/components/ntp_snippets/features.cc |
@@ -9,7 +9,6 @@ |
#include "base/time/clock.h" |
#include "components/ntp_snippets/category_rankers/click_based_category_ranker.h" |
#include "components/ntp_snippets/category_rankers/constant_category_ranker.h" |
-#include "components/variations/variations_associated_data.h" |
namespace ntp_snippets { |
@@ -41,35 +40,21 @@ const base::Feature kPublisherFaviconsFromNewServerFeature{ |
"ContentSuggestionsFaviconsFromNewServer", |
base::FEATURE_DISABLED_BY_DEFAULT}; |
-const char kCategoryRankerParameter[] = "category_ranker"; |
const char kCategoryRankerConstantRanker[] = "constant"; |
const char kCategoryRankerClickBasedRanker[] = "click_based"; |
-CategoryRankerChoice GetSelectedCategoryRanker() { |
- std::string category_ranker_value = |
- variations::GetVariationParamValueByFeature(kCategoryRanker, |
- kCategoryRankerParameter); |
- |
- if (category_ranker_value.empty()) { |
- // Default, Enabled or Disabled. |
- return CategoryRankerChoice::CONSTANT; |
- } |
- if (category_ranker_value == kCategoryRankerConstantRanker) { |
- return CategoryRankerChoice::CONSTANT; |
- } |
- if (category_ranker_value == kCategoryRankerClickBasedRanker) { |
- return CategoryRankerChoice::CLICK_BASED; |
- } |
- |
- LOG(DFATAL) << "The " << kCategoryRankerParameter << " parameter value is '" |
- << category_ranker_value << "'"; |
- return CategoryRankerChoice::CONSTANT; |
-} |
+constexpr base::FeatureParam<CategoryRankerChoice>::Option |
+ kCategoryRankerParameterOptions[] = { |
+ {CategoryRankerChoice::CONSTANT, kCategoryRankerConstantRanker}, |
+ {CategoryRankerChoice::CLICK_BASED, kCategoryRankerClickBasedRanker}}; |
+const base::FeatureParam<CategoryRankerChoice> kCategoryRankerParameter{ |
+ &kCategoryRanker, "category_ranker", CategoryRankerChoice::CONSTANT, |
+ &kCategoryRankerParameterOptions}; |
std::unique_ptr<CategoryRanker> BuildSelectedCategoryRanker( |
PrefService* pref_service, |
std::unique_ptr<base::Clock> clock) { |
- CategoryRankerChoice choice = ntp_snippets::GetSelectedCategoryRanker(); |
+ CategoryRankerChoice choice = kCategoryRankerParameter.Get(); |
switch (choice) { |
case CategoryRankerChoice::CONSTANT: |
return base::MakeUnique<ConstantCategoryRanker>(); |
@@ -83,34 +68,21 @@ std::unique_ptr<CategoryRanker> BuildSelectedCategoryRanker( |
const base::Feature kCategoryOrder{"ContentSuggestionsCategoryOrder", |
base::FEATURE_DISABLED_BY_DEFAULT}; |
-const char kCategoryOrderParameter[] = "category_order"; |
+constexpr base::FeatureParam<CategoryOrderChoice>::Option |
+ kCategoryOrderParameterOptions[] = { |
+ {CategoryOrderChoice::GENERAL, kCategoryOrderGeneral}, |
+ {CategoryOrderChoice::EMERGING_MARKETS_ORIENTED, |
+ kCategoryOrderEmergingMarketsOriented}}; |
+const base::FeatureParam<CategoryOrderChoice> kCategoryOrderParameter{ |
+ &kCategoryOrder, "category_order", CategoryOrderChoice::GENERAL, |
+ &kCategoryOrderParameterOptions}; |
+ |
const char kCategoryOrderGeneral[] = "general"; |
const char kCategoryOrderEmergingMarketsOriented[] = |
"emerging_markets_oriented"; |
CategoryOrderChoice GetSelectedCategoryOrder() { |
- if (!base::FeatureList::IsEnabled(kCategoryOrder)) { |
- return CategoryOrderChoice::GENERAL; |
- } |
- |
- std::string category_order_value = |
- variations::GetVariationParamValueByFeature(kCategoryOrder, |
- kCategoryOrderParameter); |
- |
- if (category_order_value.empty()) { |
- // Enabled with no parameters. |
- return CategoryOrderChoice::GENERAL; |
- } |
- if (category_order_value == kCategoryOrderGeneral) { |
- return CategoryOrderChoice::GENERAL; |
- } |
- if (category_order_value == kCategoryOrderEmergingMarketsOriented) { |
- return CategoryOrderChoice::EMERGING_MARKETS_ORIENTED; |
- } |
- |
- LOG(DFATAL) << "The " << kCategoryOrderParameter << " parameter value is '" |
- << category_order_value << "'"; |
- return CategoryOrderChoice::GENERAL; |
+ return kCategoryOrderParameter.Get(); |
} |
} // namespace ntp_snippets |