Index: ui/views/view_targeter_unittest.cc |
diff --git a/ui/views/view_targeter_unittest.cc b/ui/views/view_targeter_unittest.cc |
index e6f7eeb38f8c59120e1a14ff7e587ce793cfef68..5757793df161c468c30fb36ba5e95733bd1ad036 100644 |
--- a/ui/views/view_targeter_unittest.cc |
+++ b/ui/views/view_targeter_unittest.cc |
@@ -208,140 +208,6 @@ TEST_F(ViewTargeterTest, ViewTargeterForScrollEvents) { |
EXPECT_EQ(content, static_cast<View*>(current_target)); |
} |
-// Tests the basic functionality of the method |
-// ViewTargeter::SubtreeShouldBeExploredForEvent(). |
-TEST_F(ViewTargeterTest, SubtreeShouldBeExploredForEvent) { |
- Widget widget; |
- Widget::InitParams params = CreateParams(Widget::InitParams::TYPE_POPUP); |
- params.ownership = views::Widget::InitParams::WIDGET_OWNS_NATIVE_WIDGET; |
- params.bounds = gfx::Rect(0, 0, 650, 650); |
- widget.Init(params); |
- |
- internal::RootView* root_view = |
- static_cast<internal::RootView*>(widget.GetRootView()); |
- ViewTargeter* targeter = new ViewTargeter(root_view); |
- root_view->SetEventTargeter(make_scoped_ptr(targeter)); |
- |
- // The coordinates used for SetBounds() are in the parent coordinate space. |
- View v1, v2, v3; |
- v1.SetBounds(0, 0, 300, 300); |
- v2.SetBounds(100, 100, 100, 100); |
- v3.SetBounds(0, 0, 10, 10); |
- v3.SetVisible(false); |
- root_view->AddChildView(&v1); |
- v1.AddChildView(&v2); |
- v2.AddChildView(&v3); |
- |
- // Note that the coordinates used below are in |v1|'s coordinate space, |
- // and that SubtreeShouldBeExploredForEvent() expects the event location |
- // to be in the coordinate space of the target's parent. |v1| and |
- // its parent share a common coordinate space. |
- |
- // Event located within |v1| only. |
- gfx::Point point(10, 10); |
- ui::MouseEvent event(ui::ET_MOUSE_PRESSED, point, point, |
- ui::EF_LEFT_MOUSE_BUTTON, ui::EF_LEFT_MOUSE_BUTTON); |
- EXPECT_TRUE(targeter->SubtreeShouldBeExploredForEvent(&v1, event)); |
- EXPECT_FALSE(targeter->SubtreeShouldBeExploredForEvent(&v2, event)); |
- v1.ConvertEventToTarget(&v2, &event); |
- EXPECT_FALSE(targeter->SubtreeShouldBeExploredForEvent(&v3, event)); |
- |
- // Event located within |v1| and |v2| only. |
- event.set_location(gfx::Point(150, 150)); |
- EXPECT_TRUE(targeter->SubtreeShouldBeExploredForEvent(&v1, event)); |
- EXPECT_TRUE(targeter->SubtreeShouldBeExploredForEvent(&v2, event)); |
- v1.ConvertEventToTarget(&v2, &event); |
- EXPECT_FALSE(targeter->SubtreeShouldBeExploredForEvent(&v3, event)); |
- |
- // Event located within |v1|, |v2|, and |v3|. Note that |v3| is not |
- // visible, so it cannot handle the event. |
- event.set_location(gfx::Point(105, 105)); |
- EXPECT_TRUE(targeter->SubtreeShouldBeExploredForEvent(&v1, event)); |
- EXPECT_TRUE(targeter->SubtreeShouldBeExploredForEvent(&v2, event)); |
- v1.ConvertEventToTarget(&v2, &event); |
- EXPECT_FALSE(targeter->SubtreeShouldBeExploredForEvent(&v3, event)); |
- |
- // Event located outside the bounds of all views. |
- event.set_location(gfx::Point(400, 400)); |
- EXPECT_FALSE(targeter->SubtreeShouldBeExploredForEvent(&v1, event)); |
- EXPECT_FALSE(targeter->SubtreeShouldBeExploredForEvent(&v2, event)); |
- v1.ConvertEventToTarget(&v2, &event); |
- EXPECT_FALSE(targeter->SubtreeShouldBeExploredForEvent(&v3, event)); |
-} |
- |
-// Tests that FindTargetForEvent() returns the correct target when some |
-// views in the view tree return false when CanProcessEventsWithinSubtree() |
-// is called on them. |
-TEST_F(ViewTargeterTest, CanProcessEventsWithinSubtree) { |
- Widget widget; |
- Widget::InitParams params = CreateParams(Widget::InitParams::TYPE_POPUP); |
- params.ownership = views::Widget::InitParams::WIDGET_OWNS_NATIVE_WIDGET; |
- params.bounds = gfx::Rect(0, 0, 650, 650); |
- widget.Init(params); |
- |
- internal::RootView* root_view = |
- static_cast<internal::RootView*>(widget.GetRootView()); |
- ViewTargeter* view_targeter = new ViewTargeter(root_view); |
- ui::EventTargeter* targeter = view_targeter; |
- root_view->SetEventTargeter(make_scoped_ptr(view_targeter)); |
- |
- // The coordinates used for SetBounds() are in the parent coordinate space. |
- TestingView v1, v2, v3; |
- v1.SetBounds(0, 0, 300, 300); |
- v2.SetBounds(100, 100, 100, 100); |
- v3.SetBounds(0, 0, 10, 10); |
- root_view->AddChildView(&v1); |
- v1.AddChildView(&v2); |
- v2.AddChildView(&v3); |
- |
- // Note that the coordinates used below are in the coordinate space of |
- // the root view. |
- |
- // Define |scroll| to be (105, 105) (in the coordinate space of the root |
- // view). This is located within all of |v1|, |v2|, and |v3|. |
- gfx::Point scroll_point(105, 105); |
- ui::ScrollEvent scroll( |
- ui::ET_SCROLL, scroll_point, ui::EventTimeForNow(), 0, 0, 3, 0, 3, 2); |
- |
- // If CanProcessEventsWithinSubtree() returns true for each view, |
- // |scroll| should be targeted at the deepest view in the hierarchy, |
- // which is |v3|. |
- ui::EventTarget* current_target = |
- targeter->FindTargetForEvent(root_view, &scroll); |
- EXPECT_EQ(&v3, current_target); |
- |
- // If CanProcessEventsWithinSubtree() returns |false| when called |
- // on |v3|, then |v3| cannot be the target of |scroll| (this should |
- // instead be |v2|). Note we need to reset the location of |scroll| |
- // because it may have been mutated by the previous call to |
- // FindTargetForEvent(). |
- scroll.set_location(scroll_point); |
- v3.set_can_process_events_within_subtree(false); |
- current_target = targeter->FindTargetForEvent(root_view, &scroll); |
- EXPECT_EQ(&v2, current_target); |
- |
- // If CanProcessEventsWithinSubtree() returns |false| when called |
- // on |v2|, then neither |v2| nor |v3| can be the target of |scroll| |
- // (this should instead be |v1|). |
- scroll.set_location(scroll_point); |
- v3.Reset(); |
- v2.set_can_process_events_within_subtree(false); |
- current_target = targeter->FindTargetForEvent(root_view, &scroll); |
- EXPECT_EQ(&v1, current_target); |
- |
- // If CanProcessEventsWithinSubtree() returns |false| when called |
- // on |v1|, then none of |v1|, |v2| or |v3| can be the target of |scroll| |
- // (this should instead be the root view itself). |
- scroll.set_location(scroll_point); |
- v2.Reset(); |
- v1.set_can_process_events_within_subtree(false); |
- current_target = targeter->FindTargetForEvent(root_view, &scroll); |
- EXPECT_EQ(root_view, current_target); |
- |
- // TODO(tdanderson): We should also test that targeting works correctly |
- // with gestures. See crbug.com/375822. |
-} |
- |
// Tests that the functions ViewTargeterDelegate::DoesIntersectRect() |
// and MaskedTargeterDelegate::DoesIntersectRect() work as intended when |
// called on views which are derived from ViewTargeterDelegate. |