Chromium Code Reviews| Index: ui/gfx/display_change_notifier_unittest.cc |
| diff --git a/ui/gfx/display_change_notifier_unittest.cc b/ui/gfx/display_change_notifier_unittest.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..be2147d494278ea21d8f3b496302c161d830a237 |
| --- /dev/null |
| +++ b/ui/gfx/display_change_notifier_unittest.cc |
| @@ -0,0 +1,514 @@ |
| +// Copyright 2014 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 "ui/gfx/display_change_notifier.h" |
| + |
| +#include "testing/gtest/include/gtest/gtest.h" |
| +#include "ui/gfx/display.h" |
| +#include "ui/gfx/display_observer.h" |
| + |
| +using gfx::Display; |
| +using gfx::DisplayObserver; |
| + |
| +#if 0 |
| +class DisplayChangeNotifierTest : public testing::Test { |
| + protected: |
| + virtual void SetUp() OVERRIDE {} |
| + virtual void TearDown() OVERRIDE {} |
| +}; |
| +#endif // 0 |
|
oshima
2014/07/11 19:13:25
remove this?
mlamouri (slow - plz ping)
2014/07/13 15:20:40
Done.
|
| + |
| +class MockDisplayObserver : public DisplayObserver { |
| + public: |
| + MockDisplayObserver() |
| + : display_added_(0) |
| + , display_removed_(0) |
|
oshima
2014/07/11 19:13:25
move ","s to previous line. Or you can just run "g
mlamouri (slow - plz ping)
2014/07/13 15:20:40
Done.
|
| + , display_changed_(0) |
| + , latest_metrics_change_(DisplayObserver::DISPLAY_METRIC_NONE) |
| + {} |
| + |
| + virtual void OnDisplayAdded(const Display& display) OVERRIDE { |
| + display_added_++; |
| + } |
| + |
| + virtual void OnDisplayRemoved(const Display& display) OVERRIDE { |
| + display_removed_++; |
| + } |
| + |
| + virtual void OnDisplayMetricsChanged(const Display& display, |
| + uint32_t metrics) OVERRIDE { |
| + display_changed_++; |
| + latest_metrics_change_ = metrics; |
| + } |
| + |
| + int display_added() const { |
| + return display_added_; |
| + } |
| + |
| + int display_removed() const { |
| + return display_removed_; |
| + } |
| + |
| + int display_changed() const { |
| + return display_changed_; |
| + } |
| + |
| + uint32_t latest_metrics_change() const { |
| + return latest_metrics_change_; |
| + } |
| + |
| + protected: |
| + int display_added_; |
| + int display_removed_; |
| + int display_changed_; |
| + uint32_t latest_metrics_change_; |
| +}; |
|
oshima
2014/07/11 19:13:25
DISALLOW_COPY_AND_ASSIGN
mlamouri (slow - plz ping)
2014/07/13 15:20:40
Done.
|
| + |
| +namespace { |
|
oshima
2014/07/11 19:13:25
Don't put tests in anonymous namespace because tes
mlamouri (slow - plz ping)
2014/07/13 15:20:40
Done.
|
| + |
| +TEST(DisplayChangeNotifierTest, AddObserver_Smoke) { |
| + gfx::DisplayChangeNotifier change_notifier; |
| + MockDisplayObserver observer; |
| + |
| + change_notifier.NotifyDisplaysChanged( |
| + std::vector<gfx::Display>(), std::vector<Display>(1, gfx::Display())); |
| + EXPECT_EQ(0, observer.display_added()); |
| + |
| + change_notifier.AddObserver(&observer); |
| + change_notifier.NotifyDisplaysChanged( |
| + std::vector<gfx::Display>(), std::vector<Display>(1, gfx::Display())); |
| + EXPECT_EQ(1, observer.display_added()); |
| +} |
| + |
| +TEST(DisplayChangeNotifierTest, AddObserver_Null) { |
| + gfx::DisplayChangeNotifier change_notifier; |
| + |
| + change_notifier.AddObserver(NULL); |
| + // Should not crash. |
| +} |
| + |
| +TEST(DisplayChangeNotifierTest, AddObserver_Twice) { |
| + gfx::DisplayChangeNotifier change_notifier; |
| + MockDisplayObserver observer; |
| + |
| + change_notifier.AddObserver(&observer); |
| + ASSERT_DEATH(change_notifier.AddObserver(&observer), |
| + "Observers can only be added once!"); |
|
oshima
2014/07/11 19:13:25
Null/Twice/Unknowns are covered by ObserverList's
mlamouri (slow - plz ping)
2014/07/13 15:20:40
ObserverList's tests should indeed cover that but
|
| +} |
| + |
| +TEST(DisplayChangeNotifier, RemoveObserver_Smoke) { |
| + gfx::DisplayChangeNotifier change_notifier; |
| + MockDisplayObserver observer; |
| + |
| + change_notifier.NotifyDisplaysChanged( |
| + std::vector<gfx::Display>(), std::vector<Display>(1, gfx::Display())); |
| + EXPECT_EQ(0, observer.display_added()); |
| + |
| + change_notifier.AddObserver(&observer); |
| + change_notifier.RemoveObserver(&observer); |
| + |
| + change_notifier.NotifyDisplaysChanged( |
| + std::vector<gfx::Display>(), std::vector<Display>(1, gfx::Display())); |
| + EXPECT_EQ(0, observer.display_added()); |
| +} |
| + |
| +TEST(DisplayChangeNotifierTest, RemoveObserver_Null) { |
| + gfx::DisplayChangeNotifier change_notifier; |
| + |
| + change_notifier.RemoveObserver(NULL); |
| + // Should not crash. |
| +} |
| + |
| +TEST(DisplayChangeNotifierTest, RemoveObserver_Unknown) { |
| + gfx::DisplayChangeNotifier change_notifier; |
| + MockDisplayObserver observer; |
| + |
| + change_notifier.RemoveObserver(&observer); |
| + // Should not crash. |
| +} |
| + |
| +TEST(DisplayChangeNotifierTest, NotifyDisplaysChanged_Removed) { |
| + gfx::DisplayChangeNotifier change_notifier; |
| + |
| + // If the previous display array is empty, no removal. |
| + { |
| + MockDisplayObserver observer; |
| + change_notifier.AddObserver(&observer); |
| + |
| + std::vector<Display> old_displays, new_displays; |
| + new_displays.push_back(gfx::Display()); |
| + |
| + change_notifier.NotifyDisplaysChanged(old_displays, new_displays); |
| + EXPECT_EQ(0, observer.display_removed()); |
| + |
| + change_notifier.RemoveObserver(&observer); |
| + } |
| + |
| + // If the previous and new display array are empty, no removal. |
| + { |
| + MockDisplayObserver observer; |
| + change_notifier.AddObserver(&observer); |
| + |
| + std::vector<Display> old_displays, new_displays; |
| + |
| + change_notifier.NotifyDisplaysChanged(old_displays, new_displays); |
| + EXPECT_EQ(0, observer.display_removed()); |
| + |
| + change_notifier.RemoveObserver(&observer); |
| + } |
| + |
| + // If the new display array is empty, there are as many removal as old |
| + // displays. |
| + { |
| + MockDisplayObserver observer; |
| + change_notifier.AddObserver(&observer); |
| + |
| + std::vector<Display> old_displays, new_displays; |
| + old_displays.push_back(Display()); |
| + old_displays.push_back(Display()); |
| + old_displays.push_back(Display()); |
| + |
| + change_notifier.NotifyDisplaysChanged(old_displays, new_displays); |
| + EXPECT_EQ(3, observer.display_removed()); |
| + |
| + change_notifier.RemoveObserver(&observer); |
| + } |
| + |
| + // If displays don't use ids, as long as the new display array has one |
| + // element, there are no removals. |
| + { |
| + MockDisplayObserver observer; |
| + change_notifier.AddObserver(&observer); |
| + |
| + std::vector<Display> old_displays, new_displays; |
| + old_displays.push_back(Display()); |
| + old_displays.push_back(Display()); |
| + old_displays.push_back(Display()); |
| + new_displays.push_back(Display()); |
| + |
| + change_notifier.NotifyDisplaysChanged(old_displays, new_displays); |
| + EXPECT_EQ(0, observer.display_removed()); |
| + |
| + change_notifier.RemoveObserver(&observer); |
| + } |
| + |
| + // If displays use ids (and they are unique), ids not present in the new |
| + // display array will be marked as removed. |
| + { |
| + MockDisplayObserver observer; |
| + change_notifier.AddObserver(&observer); |
| + |
| + std::vector<Display> old_displays, new_displays; |
| + old_displays.push_back(Display(1)); |
| + old_displays.push_back(Display(2)); |
| + old_displays.push_back(Display(3)); |
| + new_displays.push_back(Display(2)); |
| + |
| + change_notifier.NotifyDisplaysChanged(old_displays, new_displays); |
| + EXPECT_EQ(2, observer.display_removed()); |
| + |
| + change_notifier.RemoveObserver(&observer); |
| + } |
| +} |
| + |
| +TEST(DisplayChangeNotifierTest, NotifyDisplaysChanged_Added) { |
| + gfx::DisplayChangeNotifier change_notifier; |
| + |
| + // If the new display array is empty, no addition. |
| + { |
| + MockDisplayObserver observer; |
| + change_notifier.AddObserver(&observer); |
| + |
| + std::vector<Display> old_displays, new_displays; |
| + old_displays.push_back(gfx::Display()); |
| + |
| + change_notifier.NotifyDisplaysChanged(old_displays, new_displays); |
| + EXPECT_EQ(0, observer.display_added()); |
| + |
| + change_notifier.RemoveObserver(&observer); |
| + } |
| + |
| + // If the old and new display arrays are empty, no addition. |
| + { |
| + MockDisplayObserver observer; |
| + change_notifier.AddObserver(&observer); |
| + |
| + std::vector<Display> old_displays, new_displays; |
| + |
| + change_notifier.NotifyDisplaysChanged(old_displays, new_displays); |
| + EXPECT_EQ(0, observer.display_added()); |
| + |
| + change_notifier.RemoveObserver(&observer); |
| + } |
| + |
| + // If the old display array is empty, there are as many addition as new |
| + // displays. |
| + { |
| + MockDisplayObserver observer; |
| + change_notifier.AddObserver(&observer); |
| + |
| + std::vector<Display> old_displays, new_displays; |
| + new_displays.push_back(Display()); |
| + new_displays.push_back(Display()); |
| + new_displays.push_back(Display()); |
| + |
| + change_notifier.NotifyDisplaysChanged(old_displays, new_displays); |
| + EXPECT_EQ(3, observer.display_added()); |
| + |
| + change_notifier.RemoveObserver(&observer); |
| + } |
| + |
| + // If displays don't use ids, as long as the old display array has one |
| + // element, there are no additions. |
| + { |
| + MockDisplayObserver observer; |
| + change_notifier.AddObserver(&observer); |
| + |
| + std::vector<Display> old_displays, new_displays; |
| + old_displays.push_back(Display()); |
| + new_displays.push_back(Display()); |
| + new_displays.push_back(Display()); |
| + new_displays.push_back(Display()); |
| + |
| + change_notifier.NotifyDisplaysChanged(old_displays, new_displays); |
| + EXPECT_EQ(0, observer.display_added()); |
| + |
| + change_notifier.RemoveObserver(&observer); |
| + } |
| + |
| + // If displays use ids (and they are unique), ids not present in the old |
| + // display array will be marked as added. |
| + { |
| + MockDisplayObserver observer; |
| + change_notifier.AddObserver(&observer); |
| + |
| + std::vector<Display> old_displays, new_displays; |
| + old_displays.push_back(Display(1)); |
| + new_displays.push_back(Display(1)); |
| + new_displays.push_back(Display(2)); |
| + new_displays.push_back(Display(3)); |
| + |
| + change_notifier.NotifyDisplaysChanged(old_displays, new_displays); |
| + EXPECT_EQ(2, observer.display_added()); |
| + |
| + change_notifier.RemoveObserver(&observer); |
| + } |
| +} |
| + |
| +TEST(DisplayChangeNotifierTest, NotifyDisplaysChanged_Changed_Smoke) { |
| + gfx::DisplayChangeNotifier change_notifier; |
| + |
| + // If the old display array is empty, no change. |
| + { |
| + MockDisplayObserver observer; |
| + change_notifier.AddObserver(&observer); |
| + |
| + std::vector<Display> old_displays, new_displays; |
| + new_displays.push_back(gfx::Display()); |
| + |
| + change_notifier.NotifyDisplaysChanged(old_displays, new_displays); |
| + EXPECT_EQ(0, observer.display_changed()); |
| + |
| + change_notifier.RemoveObserver(&observer); |
| + } |
| + |
| + // If the new display array is empty, no change. |
| + { |
| + MockDisplayObserver observer; |
| + change_notifier.AddObserver(&observer); |
| + |
| + std::vector<Display> old_displays, new_displays; |
| + old_displays.push_back(gfx::Display()); |
| + |
| + change_notifier.NotifyDisplaysChanged(old_displays, new_displays); |
| + EXPECT_EQ(0, observer.display_changed()); |
| + |
| + change_notifier.RemoveObserver(&observer); |
| + } |
| + |
| + // If the old and new display arrays are empty, no change. |
| + { |
| + MockDisplayObserver observer; |
| + change_notifier.AddObserver(&observer); |
| + |
| + std::vector<Display> old_displays, new_displays; |
| + |
| + change_notifier.NotifyDisplaysChanged(old_displays, new_displays); |
| + EXPECT_EQ(0, observer.display_changed()); |
| + |
| + change_notifier.RemoveObserver(&observer); |
| + } |
| + |
| + // If there is an intersection between old and new displays but there are no |
| + // metrics changes, there is no display change. |
| + { |
| + MockDisplayObserver observer; |
| + change_notifier.AddObserver(&observer); |
| + |
| + std::vector<Display> old_displays, new_displays; |
| + old_displays.push_back(Display(1)); |
| + new_displays.push_back(Display(1)); |
| + new_displays.push_back(Display(2)); |
| + new_displays.push_back(Display(3)); |
| + |
| + change_notifier.NotifyDisplaysChanged(old_displays, new_displays); |
| + EXPECT_EQ(0, observer.display_changed()); |
| + |
| + change_notifier.RemoveObserver(&observer); |
| + } |
| +} |
| + |
| +TEST(DisplayChangeNotifierTest, NotifyDisplaysChanged_Changed_Bounds) { |
| + gfx::DisplayChangeNotifier change_notifier; |
| + |
| + { |
| + MockDisplayObserver observer; |
| + change_notifier.AddObserver(&observer); |
| + |
| + std::vector<Display> old_displays, new_displays; |
| + old_displays.push_back(Display(1, gfx::Rect(0, 0, 200, 200))); |
| + new_displays.push_back(Display(1, gfx::Rect(0, 0, 200, 200))); |
| + |
| + change_notifier.NotifyDisplaysChanged(old_displays, new_displays); |
| + EXPECT_EQ(0, observer.display_changed()); |
| + |
| + change_notifier.RemoveObserver(&observer); |
| + } |
| + |
| + { |
| + MockDisplayObserver observer; |
| + change_notifier.AddObserver(&observer); |
| + |
| + std::vector<Display> old_displays, new_displays; |
| + old_displays.push_back(Display(1, gfx::Rect(0, 0, 200, 200))); |
| + new_displays.push_back(Display(1, gfx::Rect(10, 10, 300, 300))); |
| + |
| + change_notifier.NotifyDisplaysChanged(old_displays, new_displays); |
| + EXPECT_EQ(1, observer.display_changed()); |
| + uint32_t metrics_change = DisplayObserver::DISPLAY_METRIC_BOUNDS | |
| + DisplayObserver::DISPLAY_METRIC_WORK_AREA; |
| + EXPECT_EQ(metrics_change, observer.latest_metrics_change()); |
| + |
| + change_notifier.RemoveObserver(&observer); |
| + } |
| + |
| + { |
| + MockDisplayObserver observer; |
| + change_notifier.AddObserver(&observer); |
| + |
| + std::vector<Display> old_displays, new_displays; |
| + old_displays.push_back(Display(1, gfx::Rect(0, 0, 200, 200))); |
| + new_displays.push_back(Display(1, gfx::Rect(0, 0, 200, 200))); |
| + new_displays[0].set_bounds(gfx::Rect(10, 10, 300, 300)); |
| + |
| + change_notifier.NotifyDisplaysChanged(old_displays, new_displays); |
| + EXPECT_EQ(1, observer.display_changed()); |
| + EXPECT_EQ(DisplayObserver::DISPLAY_METRIC_BOUNDS, |
| + observer.latest_metrics_change()); |
| + |
| + change_notifier.RemoveObserver(&observer); |
| + } |
| +} |
| + |
| +TEST(DisplayChangeNotifierTest, NotifyDisplaysChanged_Changed_Rotation) { |
| + gfx::DisplayChangeNotifier change_notifier; |
| + MockDisplayObserver observer; |
| + change_notifier.AddObserver(&observer); |
| + |
| + std::vector<Display> old_displays, new_displays; |
| + old_displays.push_back(Display(1)); |
| + old_displays[0].SetRotationAsDegree(0); |
| + new_displays.push_back(Display(1)); |
| + new_displays[0].SetRotationAsDegree(180); |
| + |
| + change_notifier.NotifyDisplaysChanged(old_displays, new_displays); |
| + EXPECT_EQ(1, observer.display_changed()); |
| + EXPECT_EQ(DisplayObserver::DISPLAY_METRIC_ROTATION, |
| + observer.latest_metrics_change()); |
| +} |
| + |
| +TEST(DisplayChangeNotifierTest, NotifyDisplaysChanged_Changed_WorkArea) { |
| + gfx::DisplayChangeNotifier change_notifier; |
| + MockDisplayObserver observer; |
| + change_notifier.AddObserver(&observer); |
| + |
| + std::vector<Display> old_displays, new_displays; |
| + old_displays.push_back(Display(1)); |
| + old_displays[0].set_work_area(gfx::Rect(0, 0, 200, 200)); |
| + new_displays.push_back(Display(1)); |
| + new_displays[0].set_work_area(gfx::Rect(20, 20, 300, 300)); |
| + |
| + change_notifier.NotifyDisplaysChanged(old_displays, new_displays); |
| + EXPECT_EQ(1, observer.display_changed()); |
| + EXPECT_EQ(DisplayObserver::DISPLAY_METRIC_WORK_AREA, |
| + observer.latest_metrics_change()); |
| +} |
| + |
| +TEST(DisplayChangeNotifierTest, NotifyDisplaysChanged_Changed_DSF) { |
| + gfx::DisplayChangeNotifier change_notifier; |
| + MockDisplayObserver observer; |
| + change_notifier.AddObserver(&observer); |
| + |
| + std::vector<Display> old_displays, new_displays; |
| + old_displays.push_back(Display(1)); |
| + old_displays[0].set_device_scale_factor(1.f); |
| + new_displays.push_back(Display(1)); |
| + new_displays[0].set_device_scale_factor(2.f); |
| + |
| + change_notifier.NotifyDisplaysChanged(old_displays, new_displays); |
| + EXPECT_EQ(1, observer.display_changed()); |
| + EXPECT_EQ(DisplayObserver::DISPLAY_METRIC_DEVICE_SCALE_FACTOR, |
| + observer.latest_metrics_change()); |
| +} |
| + |
| +TEST(DisplayChangeNotifierTest, NotifyDisplaysChanged_Changed_Multi_Displays) { |
| + gfx::DisplayChangeNotifier change_notifier; |
| + MockDisplayObserver observer; |
| + change_notifier.AddObserver(&observer); |
| + |
| + std::vector<Display> old_displays, new_displays; |
| + old_displays.push_back(Display(1)); |
| + old_displays.push_back(Display(2)); |
| + old_displays.push_back(Display(3)); |
| + new_displays.push_back(Display(1)); |
| + new_displays.push_back(Display(2)); |
| + new_displays.push_back(Display(3)); |
| + |
| + old_displays[0].set_device_scale_factor(1.f); |
| + new_displays[0].set_device_scale_factor(2.f); |
| + |
| + old_displays[1].set_bounds(gfx::Rect(0, 0, 200, 200)); |
| + new_displays[1].set_bounds(gfx::Rect(0, 0, 400, 400)); |
| + |
| + old_displays[2].SetRotationAsDegree(0); |
| + new_displays[2].SetRotationAsDegree(90); |
| + |
| + change_notifier.NotifyDisplaysChanged(old_displays, new_displays); |
| + EXPECT_EQ(3, observer.display_changed()); |
| +} |
| + |
| +TEST(DisplayChangeNotifierTest, NotifyDisplaysChanged_Changed_Multi_Metrics) { |
| + gfx::DisplayChangeNotifier change_notifier; |
| + MockDisplayObserver observer; |
| + change_notifier.AddObserver(&observer); |
| + |
| + std::vector<Display> old_displays, new_displays; |
| + old_displays.push_back(Display(1, gfx::Rect(0, 0, 200, 200))); |
| + old_displays[0].set_device_scale_factor(1.f); |
| + old_displays[0].SetRotationAsDegree(0); |
| + |
| + new_displays.push_back(Display(1, gfx::Rect(100, 100, 200, 200))); |
| + new_displays[0].set_device_scale_factor(2.f); |
| + new_displays[0].SetRotationAsDegree(90); |
| + |
| + change_notifier.NotifyDisplaysChanged(old_displays, new_displays); |
| + EXPECT_EQ(1, observer.display_changed()); |
| + uint32_t metrics = DisplayObserver::DISPLAY_METRIC_BOUNDS | |
| + DisplayObserver::DISPLAY_METRIC_ROTATION | |
| + DisplayObserver::DISPLAY_METRIC_WORK_AREA | |
| + DisplayObserver::DISPLAY_METRIC_DEVICE_SCALE_FACTOR; |
| + EXPECT_EQ(metrics, observer.latest_metrics_change()); |
| +} |
| + |
| +} |