Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(522)

Unified Diff: chrome/browser/chromeos/ui/accessibility_focus_ring_controller_unittest.cc

Issue 2432583002: Make cursor highlighting feature work across multiple displays (Closed)
Patch Set: Add unit test Created 4 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « chrome/browser/chromeos/ui/accessibility_focus_ring_controller.h ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/chromeos/ui/accessibility_focus_ring_controller_unittest.cc
diff --git a/chrome/browser/chromeos/ui/accessibility_focus_ring_controller_unittest.cc b/chrome/browser/chromeos/ui/accessibility_focus_ring_controller_unittest.cc
index 4b1e0790937c091e4d98d6025069f5e9d7de3b62..a42bca951fdbfad07187bb056f63e8c972f48b22 100644
--- a/chrome/browser/chromeos/ui/accessibility_focus_ring_controller_unittest.cc
+++ b/chrome/browser/chromeos/ui/accessibility_focus_ring_controller_unittest.cc
@@ -2,9 +2,16 @@
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
+#include "ash/display/window_tree_host_manager.h"
+#include "ash/shell.h"
+#include "ash/test/ash_test_base.h"
+#include "chrome/browser/chromeos/accessibility/accessibility_highlight_manager.h"
+#include "chrome/browser/chromeos/ui/accessibility_cursor_ring_layer.h"
#include "chrome/browser/chromeos/ui/accessibility_focus_ring_controller.h"
-
#include "testing/gtest/include/gtest/gtest.h"
+#include "ui/display/screen.h"
+#include "ui/events/event.h"
+#include "ui/events/event_utils.h"
namespace chromeos {
@@ -28,7 +35,7 @@ class TestableAccessibilityFocusRingController
int margin_;
};
-class AccessibilityFocusRingControllerTest : public testing::Test {
+class AccessibilityFocusRingControllerTest : public ash::test::AshTestBase {
public:
AccessibilityFocusRingControllerTest() {}
~AccessibilityFocusRingControllerTest() override {}
@@ -128,4 +135,51 @@ TEST_F(AccessibilityFocusRingControllerTest, RectsToRingsParagraphShape) {
EXPECT_EQ(gfx::Point(0, 100), points[35]);
}
+TEST_F(AccessibilityFocusRingControllerTest, CursorWorksOnMultipleDisplays) {
+ if (!SupportsMultipleDisplays())
+ return;
+ UpdateDisplay("400x400,500x500");
+ std::vector<display::Display> displays =
+ display::Screen::GetScreen()->GetAllDisplays();
+ ASSERT_EQ(2u, displays.size());
+ auto* manager = ash::Shell::GetInstance()->window_tree_host_manager();
+ aura::Window* root_window0 =
+ manager->GetRootWindowForDisplayId(displays[0].id());
+ aura::Window* root_window1 =
+ manager->GetRootWindowForDisplayId(displays[1].id());
oshima 2016/10/19 21:13:51 you can use Shell::GetAllRootWindows()
dmazzoni 2016/10/19 22:36:49 Thanks, that's simpler.
+ LOG(ERROR) << root_window0;
+ LOG(ERROR) << root_window1;
oshima 2016/10/19 21:13:51 nit: remove debug logs.
dmazzoni 2016/10/19 22:36:49 Done.
+
+ AccessibilityHighlightManager highlight_manager;
+ highlight_manager.HighlightCursor(true);
+ gfx::Point location(90, 90);
+ std::unique_ptr<ui::MouseEvent> event(new ui::MouseEvent(
+ ui::ET_MOUSE_MOVED, location, location, ui::EventTimeForNow(), 0, 0));
oshima 2016/10/19 21:13:51 you can just create a instance on a stack.
dmazzoni 2016/10/19 22:36:49 Done.
+ ui::Event::DispatcherApi event_mod(event.get());
+ event_mod.set_target(root_window0);
+ highlight_manager.OnMouseEvent(event.get());
+
+ AccessibilityFocusRingController* controller =
+ AccessibilityFocusRingController::GetInstance();
+ AccessibilityCursorRingLayer* cursor_layer = controller->cursor_layer_.get();
+ EXPECT_EQ(root_window0, cursor_layer->root_window());
+ EXPECT_LT(abs(cursor_layer->layer()->GetTargetBounds().x() - location.x()),
+ 50);
+ EXPECT_LT(abs(cursor_layer->layer()->GetTargetBounds().y() - location.y()),
+ 50);
+
+ std::unique_ptr<ui::MouseEvent> event1(new ui::MouseEvent(
+ ui::ET_MOUSE_MOVED, location, location, ui::EventTimeForNow(), 0, 0));
+ ui::Event::DispatcherApi event_mod1(event.get());
+ event_mod1.set_target(root_window1);
+ highlight_manager.OnMouseEvent(event.get());
+
+ cursor_layer = controller->cursor_layer_.get();
+ EXPECT_EQ(root_window1, cursor_layer->root_window());
+ EXPECT_LT(abs(cursor_layer->layer()->GetTargetBounds().x() - location.x()),
+ 50);
+ EXPECT_LT(abs(cursor_layer->layer()->GetTargetBounds().y() - location.y()),
+ 50);
+}
+
} // namespace chromeos
« no previous file with comments | « chrome/browser/chromeos/ui/accessibility_focus_ring_controller.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698