| Index: chrome/common/metrics/variations/experiment_labels_win_unittest.cc
|
| diff --git a/chrome/common/metrics/variations/variations_util_unittest.cc b/chrome/common/metrics/variations/experiment_labels_win_unittest.cc
|
| similarity index 67%
|
| copy from chrome/common/metrics/variations/variations_util_unittest.cc
|
| copy to chrome/common/metrics/variations/experiment_labels_win_unittest.cc
|
| index e14d53a3252f6924fea181622a5dbf2c408e4f4a..d6b6d16e998e88ebaf810d1e3110765baee93bfb 100644
|
| --- a/chrome/common/metrics/variations/variations_util_unittest.cc
|
| +++ b/chrome/common/metrics/variations/experiment_labels_win_unittest.cc
|
| @@ -1,274 +1,192 @@
|
| -// 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 "chrome/common/metrics/variations/variations_util.h"
|
| -
|
| -#include <set>
|
| -#include <string>
|
| -
|
| -#include "base/metrics/field_trial.h"
|
| -#include "base/strings/string_split.h"
|
| -#include "base/strings/utf_string_conversions.h"
|
| -#include "base/time/time.h"
|
| -#include "components/variations/metrics_util.h"
|
| -#include "testing/gtest/include/gtest/gtest.h"
|
| -
|
| -namespace chrome_variations {
|
| -
|
| -namespace {
|
| -
|
| -const VariationID TEST_VALUE_A = 3300200;
|
| -const VariationID TEST_VALUE_B = 3300201;
|
| -const VariationID TEST_VALUE_C = 3300202;
|
| -const VariationID TEST_VALUE_D = 3300203;
|
| -
|
| -// Tests whether a field trial is active (i.e. group() has been called on it).
|
| -bool IsFieldTrialActive(const std::string& trial_name) {
|
| - base::FieldTrial::ActiveGroups active_groups;
|
| - base::FieldTrialList::GetActiveFieldTrialGroups(&active_groups);
|
| - for (size_t i = 0; i < active_groups.size(); ++i) {
|
| - if (active_groups[i].trial_name == trial_name)
|
| - return true;
|
| - }
|
| - return false;
|
| -}
|
| -
|
| -// Call FieldTrialList::FactoryGetFieldTrial() with a future expiry date.
|
| -scoped_refptr<base::FieldTrial> CreateFieldTrial(
|
| - const std::string& trial_name,
|
| - int total_probability,
|
| - const std::string& default_group_name,
|
| - int* default_group_number) {
|
| - return base::FieldTrialList::FactoryGetFieldTrial(
|
| - trial_name, total_probability, default_group_name,
|
| - base::FieldTrialList::kNoExpirationYear, 1, 1,
|
| - base::FieldTrial::SESSION_RANDOMIZED, default_group_number);
|
| -}
|
| -
|
| -} // namespace
|
| -
|
| -class VariationsUtilTest : public ::testing::Test {
|
| - public:
|
| - VariationsUtilTest() : field_trial_list_(NULL) {
|
| - }
|
| -
|
| - virtual ~VariationsUtilTest() {
|
| - // Ensure that the maps are cleared between tests, since they are stored as
|
| - // process singletons.
|
| - testing::ClearAllVariationIDs();
|
| - }
|
| -
|
| - private:
|
| - base::FieldTrialList field_trial_list_;
|
| -
|
| - DISALLOW_COPY_AND_ASSIGN(VariationsUtilTest);
|
| -};
|
| -
|
| -TEST_F(VariationsUtilTest, GetFieldTrialActiveGroups) {
|
| - typedef std::set<ActiveGroupId, ActiveGroupIdCompare> ActiveGroupIdSet;
|
| - std::string trial_one("trial one");
|
| - std::string group_one("group one");
|
| - std::string trial_two("trial two");
|
| - std::string group_two("group two");
|
| -
|
| - base::FieldTrial::ActiveGroups active_groups;
|
| - base::FieldTrial::ActiveGroup active_group;
|
| - active_group.trial_name = trial_one;
|
| - active_group.group_name = group_one;
|
| - active_groups.push_back(active_group);
|
| -
|
| - active_group.trial_name = trial_two;
|
| - active_group.group_name = group_two;
|
| - active_groups.push_back(active_group);
|
| -
|
| - // Create our expected groups of IDs.
|
| - ActiveGroupIdSet expected_groups;
|
| - ActiveGroupId name_group_id;
|
| - name_group_id.name = metrics::HashName(trial_one);
|
| - name_group_id.group = metrics::HashName(group_one);
|
| - expected_groups.insert(name_group_id);
|
| - name_group_id.name = metrics::HashName(trial_two);
|
| - name_group_id.group = metrics::HashName(group_two);
|
| - expected_groups.insert(name_group_id);
|
| -
|
| - std::vector<ActiveGroupId> active_group_ids;
|
| - testing::TestGetFieldTrialActiveGroupIds(active_groups, &active_group_ids);
|
| - EXPECT_EQ(2U, active_group_ids.size());
|
| - for (size_t i = 0; i < active_group_ids.size(); ++i) {
|
| - ActiveGroupIdSet::iterator expected_group =
|
| - expected_groups.find(active_group_ids[i]);
|
| - EXPECT_FALSE(expected_group == expected_groups.end());
|
| - expected_groups.erase(expected_group);
|
| - }
|
| - EXPECT_EQ(0U, expected_groups.size());
|
| -}
|
| -
|
| -TEST_F(VariationsUtilTest, BuildGoogleUpdateExperimentLabel) {
|
| - struct {
|
| - const char* active_group_pairs;
|
| - const char* expected_ids;
|
| - } test_cases[] = {
|
| - // Empty group.
|
| - {"", ""},
|
| - // Group of 1.
|
| - {"FieldTrialA#Default", "3300200"},
|
| - // Group of 1, doesn't have an associated ID.
|
| - {"FieldTrialA#DoesNotExist", ""},
|
| - // Group of 3.
|
| - {"FieldTrialA#Default#FieldTrialB#Group1#FieldTrialC#Default",
|
| - "3300200#3300201#3300202"},
|
| - // Group of 3, one doesn't have an associated ID.
|
| - {"FieldTrialA#Default#FieldTrialB#DoesNotExist#FieldTrialC#Default",
|
| - "3300200#3300202"},
|
| - // Group of 3, all three don't have an associated ID.
|
| - {"FieldTrialX#Default#FieldTrialB#DoesNotExist#FieldTrialC#Default",
|
| - "3300202"},
|
| - };
|
| -
|
| - // Register a few VariationIDs.
|
| - AssociateGoogleVariationID(GOOGLE_UPDATE_SERVICE, "FieldTrialA", "Default",
|
| - TEST_VALUE_A);
|
| - AssociateGoogleVariationID(GOOGLE_UPDATE_SERVICE, "FieldTrialB", "Group1",
|
| - TEST_VALUE_B);
|
| - AssociateGoogleVariationID(GOOGLE_UPDATE_SERVICE, "FieldTrialC", "Default",
|
| - TEST_VALUE_C);
|
| - AssociateGoogleVariationID(GOOGLE_UPDATE_SERVICE, "FieldTrialD", "Default",
|
| - TEST_VALUE_D); // Not actually used.
|
| -
|
| - for (size_t i = 0; i < ARRAYSIZE_UNSAFE(test_cases); ++i) {
|
| - // Parse the input groups.
|
| - base::FieldTrial::ActiveGroups groups;
|
| - std::vector<std::string> group_data;
|
| - base::SplitString(test_cases[i].active_group_pairs, '#', &group_data);
|
| - ASSERT_EQ(0U, group_data.size() % 2);
|
| - for (size_t j = 0; j < group_data.size(); j += 2) {
|
| - base::FieldTrial::ActiveGroup group;
|
| - group.trial_name = group_data[j];
|
| - group.group_name = group_data[j + 1];
|
| - groups.push_back(group);
|
| - }
|
| -
|
| - // Parse the expected output.
|
| - std::vector<std::string> expected_ids_list;
|
| - base::SplitString(test_cases[i].expected_ids, '#', &expected_ids_list);
|
| -
|
| - std::string experiment_labels_string = UTF16ToUTF8(
|
| - BuildGoogleUpdateExperimentLabel(groups));
|
| -
|
| - // Split the VariationIDs from the labels for verification below.
|
| - std::vector<std::string> split_labels;
|
| - std::set<std::string> parsed_ids;
|
| - base::SplitString(experiment_labels_string, ';', &split_labels);
|
| - for (std::vector<std::string>::const_iterator it = split_labels.begin();
|
| - it != split_labels.end(); ++it) {
|
| - // The ID is precisely between the '=' and '|' characters in each label.
|
| - size_t index_of_equals = it->find('=');
|
| - size_t index_of_pipe = it->find('|');
|
| - ASSERT_NE(std::string::npos, index_of_equals);
|
| - ASSERT_NE(std::string::npos, index_of_pipe);
|
| - ASSERT_GT(index_of_pipe, index_of_equals);
|
| - parsed_ids.insert(it->substr(index_of_equals + 1,
|
| - index_of_pipe - index_of_equals - 1));
|
| - }
|
| -
|
| - // Verify that the resulting string contains each of the expected labels,
|
| - // and nothing more. Note that the date is stripped out and ignored.
|
| - for (std::vector<std::string>::const_iterator it =
|
| - expected_ids_list.begin(); it != expected_ids_list.end(); ++it) {
|
| - std::set<std::string>::iterator it2 = parsed_ids.find(*it);
|
| - EXPECT_TRUE(parsed_ids.end() != it2);
|
| - parsed_ids.erase(it2);
|
| - }
|
| - EXPECT_TRUE(parsed_ids.empty());
|
| - } // for
|
| -}
|
| -
|
| -TEST_F(VariationsUtilTest, CombineExperimentLabels) {
|
| - struct {
|
| - const char* variations_labels;
|
| - const char* other_labels;
|
| - const char* expected_label;
|
| - } test_cases[] = {
|
| - {"A=B|Tue, 21 Jan 2014 15:30:21 GMT",
|
| - "C=D|Tue, 21 Jan 2014 15:30:21 GMT",
|
| - "C=D|Tue, 21 Jan 2014 15:30:21 GMT;A=B|Tue, 21 Jan 2014 15:30:21 GMT"},
|
| - {"A=B|Tue, 21 Jan 2014 15:30:21 GMT",
|
| - "",
|
| - "A=B|Tue, 21 Jan 2014 15:30:21 GMT"},
|
| - {"",
|
| - "A=B|Tue, 21 Jan 2014 15:30:21 GMT",
|
| - "A=B|Tue, 21 Jan 2014 15:30:21 GMT"},
|
| - {"A=B|Tue, 21 Jan 2014 15:30:21 GMT;C=D|Tue, 21 Jan 2014 15:30:21 GMT",
|
| - "P=Q|Tue, 21 Jan 2014 15:30:21 GMT;X=Y|Tue, 21 Jan 2014 15:30:21 GMT",
|
| - "P=Q|Tue, 21 Jan 2014 15:30:21 GMT;X=Y|Tue, 21 Jan 2014 15:30:21 GMT;"
|
| - "A=B|Tue, 21 Jan 2014 15:30:21 GMT;C=D|Tue, 21 Jan 2014 15:30:21 GMT"},
|
| - {"",
|
| - "",
|
| - ""},
|
| - };
|
| -
|
| - for (size_t i = 0; i < ARRAYSIZE_UNSAFE(test_cases); ++i) {
|
| - std::string result = UTF16ToUTF8(CombineExperimentLabels(
|
| - ASCIIToUTF16(test_cases[i].variations_labels),
|
| - ASCIIToUTF16(test_cases[i].other_labels)));
|
| - EXPECT_EQ(test_cases[i].expected_label, result);
|
| - }
|
| -}
|
| -
|
| -TEST_F(VariationsUtilTest, ExtractNonVariationLabels) {
|
| - struct {
|
| - const char* input_label;
|
| - const char* expected_output;
|
| - } test_cases[] = {
|
| - // Empty
|
| - {"", ""},
|
| - // One
|
| - {"gcapi_brand=123|Tue, 21 Jan 2014 15:30:21 GMT",
|
| - "gcapi_brand=123|Tue, 21 Jan 2014 15:30:21 GMT"},
|
| - // Three
|
| - {"CrVar1=123|Tue, 21 Jan 2014 15:30:21 GMT;"
|
| - "experiment1=456|Tue, 21 Jan 2014 15:30:21 GMT;"
|
| - "experiment2=789|Tue, 21 Jan 2014 15:30:21 GMT;"
|
| - "CrVar1=123|Tue, 21 Jan 2014 15:30:21 GMT",
|
| - "experiment1=456|Tue, 21 Jan 2014 15:30:21 GMT;"
|
| - "experiment2=789|Tue, 21 Jan 2014 15:30:21 GMT"},
|
| - // One and one Variation
|
| - {"gcapi_brand=123|Tue, 21 Jan 2014 15:30:21 GMT;"
|
| - "CrVar1=3310002|Tue, 21 Jan 2014 15:30:21 GMT",
|
| - "gcapi_brand=123|Tue, 21 Jan 2014 15:30:21 GMT"},
|
| - // One and one Variation, flipped
|
| - {"CrVar1=3310002|Tue, 21 Jan 2014 15:30:21 GMT;"
|
| - "gcapi_brand=123|Tue, 21 Jan 2014 15:30:21 GMT",
|
| - "gcapi_brand=123|Tue, 21 Jan 2014 15:30:21 GMT"},
|
| - // Sandwiched
|
| - {"CrVar1=3310002|Tue, 21 Jan 2014 15:30:21 GMT;"
|
| - "gcapi_brand=123|Tue, 21 Jan 2014 15:30:21 GMT;"
|
| - "CrVar2=3310003|Tue, 21 Jan 2014 15:30:21 GMT;"
|
| - "CrVar3=3310004|Tue, 21 Jan 2014 15:30:21 GMT",
|
| - "gcapi_brand=123|Tue, 21 Jan 2014 15:30:21 GMT"},
|
| - // Only Variations
|
| - {"CrVar1=3310002|Tue, 21 Jan 2014 15:30:21 GMT;"
|
| - "CrVar2=3310003|Tue, 21 Jan 2014 15:30:21 GMT;"
|
| - "CrVar3=3310004|Tue, 21 Jan 2014 15:30:21 GMT",
|
| - ""},
|
| - // Empty values
|
| - {"gcapi_brand=123|Tue, 21 Jan 2014 15:30:21 GMT;"
|
| - "CrVar1=3310002|Tue, 21 Jan 2014 15:30:21 GMT",
|
| - "gcapi_brand=123|Tue, 21 Jan 2014 15:30:21 GMT"},
|
| - // Trailing semicolon
|
| - {"gcapi_brand=123|Tue, 21 Jan 2014 15:30:21 GMT;"
|
| - "CrVar1=3310002|Tue, 21 Jan 2014 15:30:21 GMT;", // Note the semi here.
|
| - "gcapi_brand=123|Tue, 21 Jan 2014 15:30:21 GMT"},
|
| - // Semis
|
| - {";;;;", ""},
|
| - };
|
| -
|
| - for (size_t i = 0; i < ARRAYSIZE_UNSAFE(test_cases); ++i) {
|
| - std::string non_variation_labels = UTF16ToUTF8(
|
| - ExtractNonVariationLabels(ASCIIToUTF16(test_cases[i].input_label)));
|
| - EXPECT_EQ(test_cases[i].expected_output, non_variation_labels);
|
| - }
|
| -}
|
| -
|
| -} // namespace chrome_variations
|
| +// Copyright 2013 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 "chrome/common/metrics/variations/experiment_labels_win.h"
|
| +
|
| +#include <set>
|
| +#include <string>
|
| +#include <vector>
|
| +
|
| +#include "base/basictypes.h"
|
| +#include "base/metrics/field_trial.h"
|
| +#include "base/strings/string_split.h"
|
| +#include "base/strings/utf_string_conversions.h"
|
| +#include "components/variations/variations_associated_data.h"
|
| +#include "testing/gtest/include/gtest/gtest.h"
|
| +
|
| +namespace chrome_variations {
|
| +
|
| +TEST(ExperimentLabelsTest, BuildGoogleUpdateExperimentLabel) {
|
| + const VariationID TEST_VALUE_A = 3300200;
|
| + const VariationID TEST_VALUE_B = 3300201;
|
| + const VariationID TEST_VALUE_C = 3300202;
|
| + const VariationID TEST_VALUE_D = 3300203;
|
| +
|
| + struct {
|
| + const char* active_group_pairs;
|
| + const char* expected_ids;
|
| + } test_cases[] = {
|
| + // Empty group.
|
| + {"", ""},
|
| + // Group of 1.
|
| + {"FieldTrialA#Default", "3300200"},
|
| + // Group of 1, doesn't have an associated ID.
|
| + {"FieldTrialA#DoesNotExist", ""},
|
| + // Group of 3.
|
| + {"FieldTrialA#Default#FieldTrialB#Group1#FieldTrialC#Default",
|
| + "3300200#3300201#3300202"},
|
| + // Group of 3, one doesn't have an associated ID.
|
| + {"FieldTrialA#Default#FieldTrialB#DoesNotExist#FieldTrialC#Default",
|
| + "3300200#3300202"},
|
| + // Group of 3, all three don't have an associated ID.
|
| + {"FieldTrialX#Default#FieldTrialB#DoesNotExist#FieldTrialC#Default",
|
| + "3300202"},
|
| + };
|
| +
|
| + // Register a few VariationIDs.
|
| + AssociateGoogleVariationID(GOOGLE_UPDATE_SERVICE, "FieldTrialA", "Default",
|
| + TEST_VALUE_A);
|
| + AssociateGoogleVariationID(GOOGLE_UPDATE_SERVICE, "FieldTrialB", "Group1",
|
| + TEST_VALUE_B);
|
| + AssociateGoogleVariationID(GOOGLE_UPDATE_SERVICE, "FieldTrialC", "Default",
|
| + TEST_VALUE_C);
|
| + AssociateGoogleVariationID(GOOGLE_UPDATE_SERVICE, "FieldTrialD", "Default",
|
| + TEST_VALUE_D); // Not actually used.
|
| +
|
| + for (size_t i = 0; i < ARRAYSIZE_UNSAFE(test_cases); ++i) {
|
| + // Parse the input groups.
|
| + base::FieldTrial::ActiveGroups groups;
|
| + std::vector<std::string> group_data;
|
| + base::SplitString(test_cases[i].active_group_pairs, '#', &group_data);
|
| + ASSERT_EQ(0U, group_data.size() % 2);
|
| + for (size_t j = 0; j < group_data.size(); j += 2) {
|
| + base::FieldTrial::ActiveGroup group;
|
| + group.trial_name = group_data[j];
|
| + group.group_name = group_data[j + 1];
|
| + groups.push_back(group);
|
| + }
|
| +
|
| + // Parse the expected output.
|
| + std::vector<std::string> expected_ids_list;
|
| + base::SplitString(test_cases[i].expected_ids, '#', &expected_ids_list);
|
| +
|
| + std::string experiment_labels_string = UTF16ToUTF8(
|
| + BuildGoogleUpdateExperimentLabel(groups));
|
| +
|
| + // Split the VariationIDs from the labels for verification below.
|
| + std::vector<std::string> split_labels;
|
| + std::set<std::string> parsed_ids;
|
| + base::SplitString(experiment_labels_string, ';', &split_labels);
|
| + for (std::vector<std::string>::const_iterator it = split_labels.begin();
|
| + it != split_labels.end(); ++it) {
|
| + // The ID is precisely between the '=' and '|' characters in each label.
|
| + size_t index_of_equals = it->find('=');
|
| + size_t index_of_pipe = it->find('|');
|
| + ASSERT_NE(std::string::npos, index_of_equals);
|
| + ASSERT_NE(std::string::npos, index_of_pipe);
|
| + ASSERT_GT(index_of_pipe, index_of_equals);
|
| + parsed_ids.insert(it->substr(index_of_equals + 1,
|
| + index_of_pipe - index_of_equals - 1));
|
| + }
|
| +
|
| + // Verify that the resulting string contains each of the expected labels,
|
| + // and nothing more. Note that the date is stripped out and ignored.
|
| + for (std::vector<std::string>::const_iterator it =
|
| + expected_ids_list.begin(); it != expected_ids_list.end(); ++it) {
|
| + std::set<std::string>::iterator it2 = parsed_ids.find(*it);
|
| + EXPECT_TRUE(parsed_ids.end() != it2);
|
| + parsed_ids.erase(it2);
|
| + }
|
| + EXPECT_TRUE(parsed_ids.empty());
|
| + } // for
|
| +}
|
| +
|
| +TEST(ExperimentLabelsTest, CombineExperimentLabels) {
|
| + struct {
|
| + const char* variations_labels;
|
| + const char* other_labels;
|
| + const char* expected_label;
|
| + } test_cases[] = {
|
| + {"A=B|Tue, 21 Jan 2014 15:30:21 GMT",
|
| + "C=D|Tue, 21 Jan 2014 15:30:21 GMT",
|
| + "C=D|Tue, 21 Jan 2014 15:30:21 GMT;A=B|Tue, 21 Jan 2014 15:30:21 GMT"},
|
| + {"A=B|Tue, 21 Jan 2014 15:30:21 GMT",
|
| + "",
|
| + "A=B|Tue, 21 Jan 2014 15:30:21 GMT"},
|
| + {"",
|
| + "A=B|Tue, 21 Jan 2014 15:30:21 GMT",
|
| + "A=B|Tue, 21 Jan 2014 15:30:21 GMT"},
|
| + {"A=B|Tue, 21 Jan 2014 15:30:21 GMT;C=D|Tue, 21 Jan 2014 15:30:21 GMT",
|
| + "P=Q|Tue, 21 Jan 2014 15:30:21 GMT;X=Y|Tue, 21 Jan 2014 15:30:21 GMT",
|
| + "P=Q|Tue, 21 Jan 2014 15:30:21 GMT;X=Y|Tue, 21 Jan 2014 15:30:21 GMT;"
|
| + "A=B|Tue, 21 Jan 2014 15:30:21 GMT;C=D|Tue, 21 Jan 2014 15:30:21 GMT"},
|
| + {"",
|
| + "",
|
| + ""},
|
| + };
|
| +
|
| + for (size_t i = 0; i < ARRAYSIZE_UNSAFE(test_cases); ++i) {
|
| + std::string result = UTF16ToUTF8(CombineExperimentLabels(
|
| + ASCIIToUTF16(test_cases[i].variations_labels),
|
| + ASCIIToUTF16(test_cases[i].other_labels)));
|
| + EXPECT_EQ(test_cases[i].expected_label, result);
|
| + }
|
| +}
|
| +
|
| +TEST(ExperimentLabelsTest, ExtractNonVariationLabels) {
|
| + struct {
|
| + const char* input_label;
|
| + const char* expected_output;
|
| + } test_cases[] = {
|
| + // Empty
|
| + {"", ""},
|
| + // One
|
| + {"gcapi_brand=123|Tue, 21 Jan 2014 15:30:21 GMT",
|
| + "gcapi_brand=123|Tue, 21 Jan 2014 15:30:21 GMT"},
|
| + // Three
|
| + {"CrVar1=123|Tue, 21 Jan 2014 15:30:21 GMT;"
|
| + "experiment1=456|Tue, 21 Jan 2014 15:30:21 GMT;"
|
| + "experiment2=789|Tue, 21 Jan 2014 15:30:21 GMT;"
|
| + "CrVar1=123|Tue, 21 Jan 2014 15:30:21 GMT",
|
| + "experiment1=456|Tue, 21 Jan 2014 15:30:21 GMT;"
|
| + "experiment2=789|Tue, 21 Jan 2014 15:30:21 GMT"},
|
| + // One and one Variation
|
| + {"gcapi_brand=123|Tue, 21 Jan 2014 15:30:21 GMT;"
|
| + "CrVar1=3310002|Tue, 21 Jan 2014 15:30:21 GMT",
|
| + "gcapi_brand=123|Tue, 21 Jan 2014 15:30:21 GMT"},
|
| + // One and one Variation, flipped
|
| + {"CrVar1=3310002|Tue, 21 Jan 2014 15:30:21 GMT;"
|
| + "gcapi_brand=123|Tue, 21 Jan 2014 15:30:21 GMT",
|
| + "gcapi_brand=123|Tue, 21 Jan 2014 15:30:21 GMT"},
|
| + // Sandwiched
|
| + {"CrVar1=3310002|Tue, 21 Jan 2014 15:30:21 GMT;"
|
| + "gcapi_brand=123|Tue, 21 Jan 2014 15:30:21 GMT;"
|
| + "CrVar2=3310003|Tue, 21 Jan 2014 15:30:21 GMT;"
|
| + "CrVar3=3310004|Tue, 21 Jan 2014 15:30:21 GMT",
|
| + "gcapi_brand=123|Tue, 21 Jan 2014 15:30:21 GMT"},
|
| + // Only Variations
|
| + {"CrVar1=3310002|Tue, 21 Jan 2014 15:30:21 GMT;"
|
| + "CrVar2=3310003|Tue, 21 Jan 2014 15:30:21 GMT;"
|
| + "CrVar3=3310004|Tue, 21 Jan 2014 15:30:21 GMT",
|
| + ""},
|
| + // Empty values
|
| + {"gcapi_brand=123|Tue, 21 Jan 2014 15:30:21 GMT;"
|
| + "CrVar1=3310002|Tue, 21 Jan 2014 15:30:21 GMT",
|
| + "gcapi_brand=123|Tue, 21 Jan 2014 15:30:21 GMT"},
|
| + // Trailing semicolon
|
| + {"gcapi_brand=123|Tue, 21 Jan 2014 15:30:21 GMT;"
|
| + "CrVar1=3310002|Tue, 21 Jan 2014 15:30:21 GMT;", // Note the semi here.
|
| + "gcapi_brand=123|Tue, 21 Jan 2014 15:30:21 GMT"},
|
| + // Semis
|
| + {";;;;", ""},
|
| + };
|
| +
|
| + for (size_t i = 0; i < ARRAYSIZE_UNSAFE(test_cases); ++i) {
|
| + std::string non_variation_labels = UTF16ToUTF8(
|
| + ExtractNonVariationLabels(ASCIIToUTF16(test_cases[i].input_label)));
|
| + EXPECT_EQ(test_cases[i].expected_output, non_variation_labels);
|
| + }
|
| +}
|
| +
|
| +} // namespace chrome_variations
|
|
|