Index: ash/common/shelf/shelf_background_animator_unittest.cc |
diff --git a/ash/common/shelf/shelf_background_animator_unittest.cc b/ash/common/shelf/shelf_background_animator_unittest.cc |
index 6a395cae45b82e1c0d72539f23f17e0bb47efc14..9665ca876ca2373e9a2d3855839b2b393a46b1f0 100644 |
--- a/ash/common/shelf/shelf_background_animator_unittest.cc |
+++ b/ash/common/shelf/shelf_background_animator_unittest.cc |
@@ -8,17 +8,14 @@ |
#include "ash/common/shelf/shelf_background_animator_observer.h" |
#include "ash/common/shelf/shelf_constants.h" |
-#include "ash/common/test/material_design_controller_test_api.h" |
#include "base/bind.h" |
#include "base/macros.h" |
#include "base/test/test_mock_time_task_runner.h" |
#include "base/threading/thread_task_runner_handle.h" |
#include "testing/gtest/include/gtest/gtest.h" |
+#include "ui/gfx/animation/slide_animation.h" |
namespace ash { |
- |
-using test::MaterialDesignControllerTestAPI; |
- |
namespace { |
const int kMaxAlpha = 255; |
@@ -33,23 +30,23 @@ class TestShelfBackgroundObserver : public ShelfBackgroundAnimatorObserver { |
TestShelfBackgroundObserver() {} |
~TestShelfBackgroundObserver() override {} |
- int opaque_background_alpha() const { return opaque_background_alpha_; } |
+ int background_alpha() const { return background_alpha_; } |
int item_background_alpha() const { return item_background_alpha_; } |
// ShelfBackgroundObserver: |
- void UpdateShelfOpaqueBackground(int alpha) override; |
+ void UpdateShelfBackground(int alpha) override; |
void UpdateShelfItemBackground(int alpha) override; |
private: |
- int opaque_background_alpha_ = 0; |
+ int background_alpha_ = 0; |
int item_background_alpha_ = 0; |
DISALLOW_COPY_AND_ASSIGN(TestShelfBackgroundObserver); |
}; |
-void TestShelfBackgroundObserver::UpdateShelfOpaqueBackground(int alpha) { |
- opaque_background_alpha_ = alpha; |
+void TestShelfBackgroundObserver::UpdateShelfBackground(int alpha) { |
+ background_alpha_ = alpha; |
} |
void TestShelfBackgroundObserver::UpdateShelfItemBackground(int alpha) { |
@@ -70,15 +67,9 @@ class ShelfBackgroundAnimatorTestApi { |
return animator_->previous_background_type_; |
} |
- BackgroundAnimator* opaque_background_animator() const { |
- return animator_->opaque_background_animator_.get(); |
- } |
- |
- BackgroundAnimator* item_background_animator() const { |
- return animator_->item_background_animator_.get(); |
- } |
+ gfx::SlideAnimation* animator() const { return animator_->animator_.get(); } |
- bool can_reuse_animators() const { return animator_->can_reuse_animators_; } |
+ bool can_reuse_animator() const { return animator_->can_reuse_animator_; } |
private: |
// The instance to provide internal access to. |
@@ -87,24 +78,17 @@ class ShelfBackgroundAnimatorTestApi { |
DISALLOW_COPY_AND_ASSIGN(ShelfBackgroundAnimatorTestApi); |
}; |
-// Note: this is not a parameterized test (like other MD tests) because the |
-// behavior is so different and not all tests need to be run for both MD and |
-// non-MD variants. |
-class ShelfBackgroundAnimatorTestBase : public testing::Test { |
+class ShelfBackgroundAnimatorTest : public testing::Test { |
public: |
- ShelfBackgroundAnimatorTestBase() {} |
- ~ShelfBackgroundAnimatorTestBase() override {} |
- |
- virtual MaterialDesignController::Mode GetMaterialDesignMode() = 0; |
- |
- int expected_translucent_alpha() const { return expected_translucent_alpha_; } |
+ ShelfBackgroundAnimatorTest() {} |
+ ~ShelfBackgroundAnimatorTest() override {} |
// testing::Test: |
void SetUp() override; |
protected: |
// Convenience wrapper for |animator_|'s PaintBackground() that always uses |
- // BACKGROUND_CHANGE_IMMEDIATE. |
+ // gfx::ANIMATION_CHANGE_IMMEDIATE. |
void PaintBackground(ShelfBackgroundType background_type); |
// Set all of the alpha values for the |observer_|. |
@@ -127,104 +111,36 @@ class ShelfBackgroundAnimatorTestBase : public testing::Test { |
private: |
std::unique_ptr<base::ThreadTaskRunnerHandle> task_runner_handle_; |
- std::unique_ptr<MaterialDesignControllerTestAPI> material_mode_test_api_; |
- |
- // The expected alpha value for translucent items. Cannot be a constant |
- // because it is different for material design and non-material. |
- int expected_translucent_alpha_ = 0; |
- |
- DISALLOW_COPY_AND_ASSIGN(ShelfBackgroundAnimatorTestBase); |
+ DISALLOW_COPY_AND_ASSIGN(ShelfBackgroundAnimatorTest); |
}; |
-void ShelfBackgroundAnimatorTestBase::SetUp() { |
+void ShelfBackgroundAnimatorTest::SetUp() { |
task_runner_ = new base::TestMockTimeTaskRunner(); |
task_runner_handle_.reset(new base::ThreadTaskRunnerHandle(task_runner_)); |
- |
- material_mode_test_api_.reset( |
- new MaterialDesignControllerTestAPI(GetMaterialDesignMode())); |
animator_.reset( |
new ShelfBackgroundAnimator(SHELF_BACKGROUND_DEFAULT, nullptr)); |
animator_->AddObserver(&observer_); |
test_api_.reset(new ShelfBackgroundAnimatorTestApi(animator_.get())); |
- |
- // Initialized after the Material Design mode because GetShelfConstant() |
- // depends on the mode. |
- expected_translucent_alpha_ = GetShelfConstant(SHELF_BACKGROUND_ALPHA); |
} |
-void ShelfBackgroundAnimatorTestBase::PaintBackground( |
+void ShelfBackgroundAnimatorTest::PaintBackground( |
ShelfBackgroundType background_type) { |
- animator_->PaintBackground(background_type, BACKGROUND_CHANGE_IMMEDIATE); |
+ animator_->PaintBackground(background_type, gfx::ANIMATION_CHANGE_IMMEDIATE); |
} |
-void ShelfBackgroundAnimatorTestBase::SetAlphaValuesOnObserver(int alpha) { |
- observer_.UpdateShelfOpaqueBackground(alpha); |
+void ShelfBackgroundAnimatorTest::SetAlphaValuesOnObserver(int alpha) { |
+ observer_.UpdateShelfBackground(alpha); |
observer_.UpdateShelfItemBackground(alpha); |
} |
-void ShelfBackgroundAnimatorTestBase::CompleteAnimations() { |
+void ShelfBackgroundAnimatorTest::CompleteAnimations() { |
task_runner_->FastForwardUntilNoTasksRemain(); |
} |
-class ShelfBackgroundAnimatorNonMDTest |
- : public ShelfBackgroundAnimatorTestBase { |
- public: |
- ShelfBackgroundAnimatorNonMDTest() {} |
- ~ShelfBackgroundAnimatorNonMDTest() override {} |
- |
- MaterialDesignController::Mode GetMaterialDesignMode() override { |
- return MaterialDesignController::NON_MATERIAL; |
- } |
- |
- private: |
- DISALLOW_COPY_AND_ASSIGN(ShelfBackgroundAnimatorNonMDTest); |
-}; |
- |
-// Verify the alpha values for the SHELF_BACKGROUND_DEFAULT state. |
-TEST_F(ShelfBackgroundAnimatorNonMDTest, DefaultBackground) { |
- PaintBackground(SHELF_BACKGROUND_DEFAULT); |
- |
- EXPECT_EQ(SHELF_BACKGROUND_DEFAULT, animator_->target_background_type()); |
- EXPECT_EQ(0, observer_.opaque_background_alpha()); |
- EXPECT_EQ(expected_translucent_alpha(), observer_.item_background_alpha()); |
-} |
- |
-// Verify the alpha values for the SHELF_BACKGROUND_OVERLAP state. |
-TEST_F(ShelfBackgroundAnimatorNonMDTest, OverlapBackground) { |
- PaintBackground(SHELF_BACKGROUND_OVERLAP); |
- |
- EXPECT_EQ(SHELF_BACKGROUND_OVERLAP, animator_->target_background_type()); |
- EXPECT_EQ(0, observer_.opaque_background_alpha()); |
- EXPECT_EQ(expected_translucent_alpha(), observer_.item_background_alpha()); |
-} |
- |
-// Verify the alpha values for the SHELF_BACKGROUND_MAXIMIZED state. |
-TEST_F(ShelfBackgroundAnimatorNonMDTest, MaximizedBackground) { |
- PaintBackground(SHELF_BACKGROUND_MAXIMIZED); |
- |
- EXPECT_EQ(SHELF_BACKGROUND_MAXIMIZED, animator_->target_background_type()); |
- EXPECT_EQ(kMaxAlpha, observer_.opaque_background_alpha()); |
- EXPECT_EQ(kMaxAlpha, observer_.item_background_alpha()); |
-} |
- |
-class ShelfBackgroundAnimatorMDTest : public ShelfBackgroundAnimatorTestBase { |
- public: |
- ShelfBackgroundAnimatorMDTest() {} |
- ~ShelfBackgroundAnimatorMDTest() override {} |
- |
- MaterialDesignController::Mode GetMaterialDesignMode() override { |
- return MaterialDesignController::MATERIAL_EXPERIMENTAL; |
- } |
- |
- private: |
- DISALLOW_COPY_AND_ASSIGN(ShelfBackgroundAnimatorMDTest); |
-}; |
- |
// Verify the |previous_background_type_| and |target_background_type_| values |
// when animating to the same target type multiple times. |
-TEST_F(ShelfBackgroundAnimatorMDTest, |
- BackgroundTypesWhenAnimatingToSameTarget) { |
+TEST_F(ShelfBackgroundAnimatorTest, BackgroundTypesWhenAnimatingToSameTarget) { |
PaintBackground(SHELF_BACKGROUND_MAXIMIZED); |
EXPECT_EQ(SHELF_BACKGROUND_MAXIMIZED, animator_->target_background_type()); |
@@ -238,143 +154,131 @@ TEST_F(ShelfBackgroundAnimatorMDTest, |
} |
// Verify subsequent calls to PaintBackground() using the |
-// BACKGROUND_CHANGE_ANIMATE change type are ignored. |
-TEST_F(ShelfBackgroundAnimatorMDTest, |
+// gfx::ANIMATION_CHANGE_ANIMATE change type are ignored. |
+TEST_F(ShelfBackgroundAnimatorTest, |
MultipleAnimateCallsToSameTargetAreIgnored) { |
PaintBackground(SHELF_BACKGROUND_MAXIMIZED); |
SetAlphaValuesOnObserver(kDummyAlpha); |
animator_->PaintBackground(SHELF_BACKGROUND_DEFAULT, |
- BACKGROUND_CHANGE_ANIMATE); |
+ gfx::ANIMATION_CHANGE_ANIMATE); |
CompleteAnimations(); |
- EXPECT_NE(observer_.opaque_background_alpha(), kDummyAlpha); |
+ EXPECT_NE(observer_.background_alpha(), kDummyAlpha); |
EXPECT_NE(observer_.item_background_alpha(), kDummyAlpha); |
SetAlphaValuesOnObserver(kDummyAlpha); |
animator_->PaintBackground(SHELF_BACKGROUND_DEFAULT, |
- BACKGROUND_CHANGE_ANIMATE); |
+ gfx::ANIMATION_CHANGE_ANIMATE); |
CompleteAnimations(); |
- EXPECT_EQ(observer_.opaque_background_alpha(), kDummyAlpha); |
+ EXPECT_EQ(observer_.background_alpha(), kDummyAlpha); |
EXPECT_EQ(observer_.item_background_alpha(), kDummyAlpha); |
} |
// Verify observers are updated with the current values when they are added. |
-TEST_F(ShelfBackgroundAnimatorMDTest, ObserversUpdatedWhenAdded) { |
+TEST_F(ShelfBackgroundAnimatorTest, ObserversUpdatedWhenAdded) { |
animator_->RemoveObserver(&observer_); |
SetAlphaValuesOnObserver(kDummyAlpha); |
animator_->AddObserver(&observer_); |
- EXPECT_NE(observer_.opaque_background_alpha(), kDummyAlpha); |
+ EXPECT_NE(observer_.background_alpha(), kDummyAlpha); |
EXPECT_NE(observer_.item_background_alpha(), kDummyAlpha); |
} |
// Verify the alpha values for the SHELF_BACKGROUND_DEFAULT state. |
-TEST_F(ShelfBackgroundAnimatorMDTest, DefaultBackground) { |
+TEST_F(ShelfBackgroundAnimatorTest, DefaultBackground) { |
PaintBackground(SHELF_BACKGROUND_DEFAULT); |
EXPECT_EQ(SHELF_BACKGROUND_DEFAULT, animator_->target_background_type()); |
- EXPECT_EQ(0, observer_.opaque_background_alpha()); |
- EXPECT_EQ(expected_translucent_alpha(), observer_.item_background_alpha()); |
+ EXPECT_EQ(0, observer_.background_alpha()); |
+ EXPECT_EQ(kShelfTranslucentAlpha, observer_.item_background_alpha()); |
} |
// Verify the alpha values for the SHELF_BACKGROUND_OVERLAP state. |
-TEST_F(ShelfBackgroundAnimatorMDTest, OverlapBackground) { |
+TEST_F(ShelfBackgroundAnimatorTest, OverlapBackground) { |
PaintBackground(SHELF_BACKGROUND_OVERLAP); |
EXPECT_EQ(SHELF_BACKGROUND_OVERLAP, animator_->target_background_type()); |
- EXPECT_EQ(expected_translucent_alpha(), observer_.opaque_background_alpha()); |
+ EXPECT_EQ(kShelfTranslucentAlpha, observer_.background_alpha()); |
EXPECT_EQ(0, observer_.item_background_alpha()); |
} |
// Verify the alpha values for the SHELF_BACKGROUND_MAXIMIZED state. |
-TEST_F(ShelfBackgroundAnimatorMDTest, MaximizedBackground) { |
+TEST_F(ShelfBackgroundAnimatorTest, MaximizedBackground) { |
PaintBackground(SHELF_BACKGROUND_MAXIMIZED); |
EXPECT_EQ(SHELF_BACKGROUND_MAXIMIZED, animator_->target_background_type()); |
- EXPECT_EQ(kMaxAlpha, observer_.opaque_background_alpha()); |
+ EXPECT_EQ(kMaxAlpha, observer_.background_alpha()); |
EXPECT_EQ(0, observer_.item_background_alpha()); |
} |
-// Verify that existing animators are used when animating to the previous state. |
-TEST_F(ShelfBackgroundAnimatorMDTest, ExistingAnimatorsAreReused) { |
+// Verify that existing animator is used when animating to the previous state. |
+TEST_F(ShelfBackgroundAnimatorTest, ExistingAnimatorIsReused) { |
PaintBackground(SHELF_BACKGROUND_DEFAULT); |
PaintBackground(SHELF_BACKGROUND_MAXIMIZED); |
- EXPECT_TRUE(test_api_->can_reuse_animators()); |
+ EXPECT_TRUE(test_api_->can_reuse_animator()); |
- const BackgroundAnimator* opaque_animator = |
- test_api_->opaque_background_animator(); |
- const BackgroundAnimator* item_animator = |
- test_api_->item_background_animator(); |
+ const gfx::SlideAnimation* animator = test_api_->animator(); |
PaintBackground(SHELF_BACKGROUND_DEFAULT); |
- EXPECT_EQ(opaque_animator, test_api_->opaque_background_animator()); |
- EXPECT_EQ(item_animator, test_api_->item_background_animator()); |
+ EXPECT_EQ(animator, test_api_->animator()); |
} |
-// Verify that existing animators are not re-used when the previous animation |
+// Verify that existing animator is not re-used when the previous animation |
// didn't complete. |
-TEST_F(ShelfBackgroundAnimatorMDTest, |
- ExistingAnimatorsNotReusedWhenPreviousAnimationsDontComplete) { |
+TEST_F(ShelfBackgroundAnimatorTest, |
+ ExistingAnimatorNotReusedWhenPreviousAnimationsDontComplete) { |
EXPECT_NE(SHELF_BACKGROUND_OVERLAP, test_api_->previous_background_type()); |
animator_->PaintBackground(SHELF_BACKGROUND_OVERLAP, |
- BACKGROUND_CHANGE_ANIMATE); |
+ gfx::ANIMATION_CHANGE_ANIMATE); |
animator_->PaintBackground(SHELF_BACKGROUND_MAXIMIZED, |
- BACKGROUND_CHANGE_ANIMATE); |
- EXPECT_FALSE(test_api_->can_reuse_animators()); |
+ gfx::ANIMATION_CHANGE_ANIMATE); |
+ EXPECT_FALSE(test_api_->can_reuse_animator()); |
- const BackgroundAnimator* opaque_animator = |
- test_api_->opaque_background_animator(); |
- const BackgroundAnimator* item_animator = |
- test_api_->item_background_animator(); |
+ const gfx::SlideAnimation* animator = test_api_->animator(); |
EXPECT_EQ(SHELF_BACKGROUND_OVERLAP, test_api_->previous_background_type()); |
animator_->PaintBackground(SHELF_BACKGROUND_OVERLAP, |
- BACKGROUND_CHANGE_ANIMATE); |
+ gfx::ANIMATION_CHANGE_ANIMATE); |
- EXPECT_NE(opaque_animator, test_api_->opaque_background_animator()); |
- EXPECT_NE(item_animator, test_api_->item_background_animator()); |
+ EXPECT_NE(animator, test_api_->animator()); |
} |
-// Verify that existing animators are not re-used when the target background |
-// isn't the same as the previous background. |
-TEST_F(ShelfBackgroundAnimatorMDTest, |
- ExistingAnimatorsNotReusedWhenTargetBackgroundNotPreviousBackground) { |
+// Verify that existing animator is not re-used when the target background isn't |
+// the same as the previous background. |
+TEST_F(ShelfBackgroundAnimatorTest, |
+ ExistingAnimatorNotReusedWhenTargetBackgroundNotPreviousBackground) { |
PaintBackground(SHELF_BACKGROUND_DEFAULT); |
PaintBackground(SHELF_BACKGROUND_MAXIMIZED); |
- EXPECT_TRUE(test_api_->can_reuse_animators()); |
+ EXPECT_TRUE(test_api_->can_reuse_animator()); |
- const BackgroundAnimator* opaque_animator = |
- test_api_->opaque_background_animator(); |
- const BackgroundAnimator* item_animator = |
- test_api_->item_background_animator(); |
+ const gfx::SlideAnimation* animator = test_api_->animator(); |
EXPECT_NE(SHELF_BACKGROUND_OVERLAP, test_api_->previous_background_type()); |
PaintBackground(SHELF_BACKGROUND_OVERLAP); |
- EXPECT_NE(opaque_animator, test_api_->opaque_background_animator()); |
- EXPECT_NE(item_animator, test_api_->item_background_animator()); |
+ EXPECT_NE(animator, test_api_->animator()); |
} |
-// Verify animators are not re-used after snapping to the same background type. |
-TEST_F(ShelfBackgroundAnimatorMDTest, |
- ExistingAnimatorsNotUsedWhenSnappingToSameTargetBackground) { |
+// Verify animator is not re-used after snapping to the same background type. |
+TEST_F(ShelfBackgroundAnimatorTest, |
+ ExistingAnimatorNotUsedWhenSnappingToSameTargetBackground) { |
PaintBackground(SHELF_BACKGROUND_DEFAULT); |
PaintBackground(SHELF_BACKGROUND_DEFAULT); |
- EXPECT_FALSE(test_api_->can_reuse_animators()); |
+ EXPECT_FALSE(test_api_->can_reuse_animator()); |
} |
// Verify observers are always notified, even when alpha values don't change. |
-TEST_F(ShelfBackgroundAnimatorMDTest, |
+TEST_F(ShelfBackgroundAnimatorTest, |
ObserversAreNotifiedWhenSnappingToSameTargetBackground) { |
PaintBackground(SHELF_BACKGROUND_DEFAULT); |
SetAlphaValuesOnObserver(kDummyAlpha); |
PaintBackground(SHELF_BACKGROUND_DEFAULT); |
- EXPECT_NE(observer_.opaque_background_alpha(), kDummyAlpha); |
+ EXPECT_NE(observer_.background_alpha(), kDummyAlpha); |
EXPECT_NE(observer_.item_background_alpha(), kDummyAlpha); |
} |