Index: ash/material_design/material_design_controller_unittest.cc |
diff --git a/ash/material_design/material_design_controller_unittest.cc b/ash/material_design/material_design_controller_unittest.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..5c4a0635c24e9c9fb07ac70b61198912daab81a4 |
--- /dev/null |
+++ b/ash/material_design/material_design_controller_unittest.cc |
@@ -0,0 +1,115 @@ |
+// 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 <string> |
+ |
+#include "ash/ash_switches.h" |
+#include "ash/material_design/material_design_controller.h" |
+#include "ash/test/material_design_controller_test_api.h" |
+#include "base/command_line.h" |
+#include "base/macros.h" |
+#include "testing/gtest/include/gtest/gtest.h" |
+ |
+namespace ash { |
+namespace { |
+ |
+// Test fixture for the MaterialDesignController class. |
+class MaterialDesignControllerTest : public testing::Test { |
+ public: |
+ MaterialDesignControllerTest(); |
+ ~MaterialDesignControllerTest() override; |
+ |
+ protected: |
+ // testing::Test: |
+ void SetUp() override; |
+ void TearDown() override; |
+ |
+ private: |
+ DISALLOW_COPY_AND_ASSIGN(MaterialDesignControllerTest); |
+}; |
+ |
+MaterialDesignControllerTest::MaterialDesignControllerTest() {} |
+ |
+MaterialDesignControllerTest::~MaterialDesignControllerTest() {} |
+ |
+void MaterialDesignControllerTest::SetUp() { |
+ testing::Test::SetUp(); |
+ MaterialDesignController::Initialize(); |
+} |
+ |
+void MaterialDesignControllerTest::TearDown() { |
+ test::MaterialDesignControllerTestAPI::Uninitialize(); |
+ testing::Test::TearDown(); |
+} |
+ |
+class MaterialDesignControllerTestMaterial |
+ : public MaterialDesignControllerTest { |
+ public: |
+ MaterialDesignControllerTestMaterial() { |
+ base::CommandLine::ForCurrentProcess()->AppendSwitch( |
+ switches::kAshEnableMaterialDesign); |
oshima
2016/04/26 16:06:58
These additional flags will be carried over to oth
varkha
2016/04/27 21:00:09
Done.
|
+ } |
+ |
+ private: |
+ DISALLOW_COPY_AND_ASSIGN(MaterialDesignControllerTestMaterial); |
+}; |
+ |
+class MaterialDesignControllerTestNonMaterial |
+ : public MaterialDesignControllerTest { |
+ public: |
+ MaterialDesignControllerTestNonMaterial() { |
+ base::CommandLine::ForCurrentProcess()->AppendSwitch( |
+ switches::kAshDisableMaterialDesign); |
+ } |
+ |
+ private: |
+ DISALLOW_COPY_AND_ASSIGN(MaterialDesignControllerTestNonMaterial); |
+}; |
+ |
+class MaterialDesignControllerTestBothEnabledAndDisabled |
+ : public MaterialDesignControllerTest { |
+ public: |
+ MaterialDesignControllerTestBothEnabledAndDisabled() { |
+ base::CommandLine::ForCurrentProcess()->AppendSwitch( |
+ switches::kAshEnableMaterialDesign); |
+ base::CommandLine::ForCurrentProcess()->AppendSwitch( |
+ switches::kAshDisableMaterialDesign); |
+ } |
+ |
+ private: |
+ DISALLOW_COPY_AND_ASSIGN(MaterialDesignControllerTestBothEnabledAndDisabled); |
+}; |
+ |
+} // namespace |
+ |
+// Verify the current mode is reported as the default mode when no command line |
+// flag is added. |
+TEST_F(MaterialDesignControllerTest, NoCommandLineSwitchMapsToDefaultMode) { |
+ ASSERT_FALSE(base::CommandLine::ForCurrentProcess()->HasSwitch( |
+ switches::kAshEnableMaterialDesign)); |
+ ASSERT_FALSE(base::CommandLine::ForCurrentProcess()->HasSwitch( |
+ switches::kAshDisableMaterialDesign)); |
+ EXPECT_EQ(test::MaterialDesignControllerTestAPI::DefaultMode(), |
+ MaterialDesignController::IsMaterial()); |
+} |
+ |
+// Verify that MaterialDesignController::IsModeMaterial() will be true when |
+// initialized with command line flag "ash-enable-md". |
+TEST_F(MaterialDesignControllerTestMaterial, CommandLineSwitch) { |
+ EXPECT_TRUE(MaterialDesignController::IsMaterial()); |
+} |
+ |
+// Verify that MaterialDesignController::IsModeMaterial() will be false when |
+// initialized with command line flag "ash-disable-md". |
+TEST_F(MaterialDesignControllerTestNonMaterial, CommandLineSwitch) { |
+ EXPECT_FALSE(MaterialDesignController::IsMaterial()); |
+} |
+ |
+// Verify that MaterialDesignController::IsModeMaterial() will be false when |
+// initialized with both command line flags "ash-enable-md --ash-disable-md". |
+TEST_F(MaterialDesignControllerTestBothEnabledAndDisabled, CommandLineSwitch) { |
+ EXPECT_FALSE(MaterialDesignController::IsMaterial()); |
+} |
+ |
+} // namespace ash |