Index: base/metrics/feature_list_unittest.cc |
diff --git a/base/metrics/feature_list_unittest.cc b/base/metrics/feature_list_unittest.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..29a46d612357e804cb1a02cee40e3629c229effd |
--- /dev/null |
+++ b/base/metrics/feature_list_unittest.cc |
@@ -0,0 +1,96 @@ |
+// Copyright 2015 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/feature_list.h" |
+ |
+#include "testing/gtest/include/gtest/gtest.h" |
+ |
+namespace base { |
+ |
+namespace { |
+ |
+const char kFeatureOnName[] = "Example1"; |
Ilya Sherman
2015/09/01 03:55:26
I think the tests would be easier to follow if thi
Alexei Svitkine (slow)
2015/09/01 15:53:44
Done.
|
+struct Feature kExampleFeatureOn { |
+ kFeatureOnName, true |
+}; |
+ |
+const char kFeatureOffName[] = "Example2"; |
+struct Feature kExampleFeatureOff { |
+ kFeatureOffName, false |
+}; |
+ |
+class FeatureListTest : public testing::Test { |
Ilya Sherman
2015/09/01 03:55:26
nit: The test harness class should be declared out
Alexei Svitkine (slow)
2015/09/01 15:53:44
Done.
|
+ public: |
+ FeatureListTest() : feature_list_(new FeatureList) { |
+ RegisterFeatureListInstance(); |
+ } |
+ ~FeatureListTest() override { ClearFeatureListInstance(); } |
+ |
+ void RegisterFeatureListInstance() { |
+ FeatureList::SetInstance(make_scoped_ptr(feature_list_)); |
+ } |
Ilya Sherman
2015/09/01 03:55:26
This doesn't make much sense as a public method if
Alexei Svitkine (slow)
2015/09/01 15:53:44
Done.
|
+ void ClearFeatureListInstance() { FeatureList::ClearInstanceForTesting(); } |
+ |
+ FeatureList* feature_list() { return feature_list_; } |
Ilya Sherman
2015/09/01 03:55:26
This can return a pointer to freed memory if Clear
Alexei Svitkine (slow)
2015/09/01 15:53:44
Done.
|
+ |
+ private: |
+ // Weak. Owned by the FeatureList::SetInstance(). |
+ FeatureList* feature_list_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(FeatureListTest); |
+}; |
+ |
+} // namespace |
+ |
+TEST_F(FeatureListTest, DefaultStates) { |
+ EXPECT_TRUE(FeatureList::IsEnabled(kExampleFeatureOn)); |
+ EXPECT_FALSE(FeatureList::IsEnabled(kExampleFeatureOff)); |
+} |
+ |
+TEST_F(FeatureListTest, InitializeFromCommandLine) { |
+ struct { |
+ const char* enable_features; |
+ const char* disable_features; |
+ bool expected_feature_on_state; |
+ bool expected_feature_off_state; |
+ } test_cases[] = { |
+ {"", "", true, false}, |
+ {"Example2", "", true, true}, |
+ {"Example2", "Example1", false, true}, |
+ {"Example1,Example2", "", true, true}, |
+ {"", "Example1,Example2", false, false}, |
+ // In the case an entry is both, disable takes precedence. |
+ {"Example1", "Example1,Example2", false, false}, |
+ }; |
+ |
+ for (size_t i = 0; i < arraysize(test_cases); i++) { |
Ilya Sherman
2015/09/01 03:55:26
nit: ++i
Alexei Svitkine (slow)
2015/09/01 15:53:44
Done.
|
+ const auto& test_case = test_cases[i]; |
+ |
+ FeatureList feature_list; |
+ feature_list.InitializeFromCommandLine(test_case.enable_features, |
+ test_case.disable_features); |
+ feature_list.FinalizeInitialization(); |
Ilya Sherman
2015/09/01 03:55:26
It seems more appropriate to set the singleton, an
Alexei Svitkine (slow)
2015/09/01 15:53:44
Done. I was originally thinking to keep the class
|
+ |
+ EXPECT_EQ(test_case.expected_feature_on_state, |
+ feature_list.IsFeatureEnabled(kExampleFeatureOn)) |
+ << i; |
+ EXPECT_EQ(test_case.expected_feature_off_state, |
+ feature_list.IsFeatureEnabled(kExampleFeatureOff)) |
+ << i; |
+ } |
+} |
+ |
+TEST_F(FeatureListTest, CheckFeatureIdentity) { |
Ilya Sherman
2015/09/01 03:55:26
This purpose of this test is not immediately obvio
Alexei Svitkine (slow)
2015/09/01 15:53:44
I don't think a test using the public API is possi
Ilya Sherman
2015/09/01 20:17:17
I was thinking we could use a gtest Death Test: [
Alexei Svitkine (slow)
2015/09/01 21:18:38
Right, then the test would have to only be enabled
|
+ EXPECT_TRUE(feature_list()->CheckFeatureIdentity(kExampleFeatureOn)); |
+ EXPECT_TRUE(feature_list()->CheckFeatureIdentity(kExampleFeatureOn)); |
+ EXPECT_TRUE(feature_list()->CheckFeatureIdentity(kExampleFeatureOff)); |
+ EXPECT_TRUE(feature_list()->CheckFeatureIdentity(kExampleFeatureOff)); |
Ilya Sherman
2015/09/01 03:55:26
Why are these lines written twice each?
Alexei Svitkine (slow)
2015/09/01 15:53:44
The first time would register it and the second ti
|
+ |
+ struct Feature kExampleFeatureOn2 { |
+ kFeatureOnName, true |
+ }; |
+ EXPECT_FALSE(feature_list()->CheckFeatureIdentity(kExampleFeatureOn2)); |
+} |
+ |
+} // namespace base |