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

Side by Side Diff: components/mus/ws/window_finder_unittest.cc

Issue 2119963002: Move mus to //services/ui (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: . Created 4 years, 5 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 unified diff | Download patch
« no previous file with comments | « components/mus/ws/window_finder.cc ('k') | components/mus/ws/window_manager_access_policy.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 // Copyright 2015 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "components/mus/ws/window_finder.h"
6
7 #include "components/mus/ws/server_window.h"
8 #include "components/mus/ws/server_window_surface_manager.h"
9 #include "components/mus/ws/server_window_surface_manager_test_api.h"
10 #include "components/mus/ws/test_server_window_delegate.h"
11 #include "components/mus/ws/window_finder.h"
12 #include "testing/gtest/include/gtest/gtest.h"
13
14 namespace mus {
15 namespace ws {
16
17 TEST(WindowFinderTest, FindDeepestVisibleWindow) {
18 TestServerWindowDelegate window_delegate;
19 ServerWindow root(&window_delegate, WindowId(1, 2));
20 window_delegate.set_root_window(&root);
21 root.SetVisible(true);
22 root.SetBounds(gfx::Rect(0, 0, 100, 100));
23
24 ServerWindow child1(&window_delegate, WindowId(1, 3));
25 root.Add(&child1);
26 EnableHitTest(&child1);
27 child1.SetVisible(true);
28 child1.SetBounds(gfx::Rect(10, 10, 20, 20));
29
30 ServerWindow child2(&window_delegate, WindowId(1, 4));
31 root.Add(&child2);
32 EnableHitTest(&child2);
33 child2.SetVisible(true);
34 child2.SetBounds(gfx::Rect(15, 15, 20, 20));
35
36 gfx::Point local_point(16, 16);
37 EXPECT_EQ(&child2, FindDeepestVisibleWindowForEvents(&root, &local_point));
38 EXPECT_EQ(gfx::Point(1, 1), local_point);
39
40 local_point.SetPoint(13, 14);
41 EXPECT_EQ(&child1, FindDeepestVisibleWindowForEvents(&root, &local_point));
42 EXPECT_EQ(gfx::Point(3, 4), local_point);
43
44 child2.set_extended_hit_test_region(gfx::Insets(10, 10, 10, 10));
45 local_point.SetPoint(13, 14);
46 EXPECT_EQ(&child2, FindDeepestVisibleWindowForEvents(&root, &local_point));
47 EXPECT_EQ(gfx::Point(-2, -1), local_point);
48 }
49
50 TEST(WindowFinderTest, FindDeepestVisibleWindowHitTestMask) {
51 TestServerWindowDelegate window_delegate;
52 ServerWindow root(&window_delegate, WindowId(1, 2));
53 window_delegate.set_root_window(&root);
54 EnableHitTest(&root);
55 root.SetVisible(true);
56 root.SetBounds(gfx::Rect(0, 0, 100, 100));
57
58 ServerWindow child_with_mask(&window_delegate, WindowId(1, 4));
59 root.Add(&child_with_mask);
60 EnableHitTest(&child_with_mask);
61 child_with_mask.SetVisible(true);
62 child_with_mask.SetBounds(gfx::Rect(10, 10, 20, 20));
63 child_with_mask.SetHitTestMask(gfx::Rect(2, 2, 16, 16));
64
65 // Test a point inside the window but outside the mask.
66 gfx::Point point_outside_mask(11, 11);
67 EXPECT_EQ(&root,
68 FindDeepestVisibleWindowForEvents(&root, &point_outside_mask));
69 EXPECT_EQ(gfx::Point(11, 11), point_outside_mask);
70
71 // Test a point inside the window and inside the mask.
72 gfx::Point point_inside_mask(15, 15);
73 EXPECT_EQ(&child_with_mask,
74 FindDeepestVisibleWindowForEvents(&root, &point_inside_mask));
75 EXPECT_EQ(gfx::Point(5, 5), point_inside_mask);
76 }
77
78 } // namespace ws
79 } // namespace mus
OLDNEW
« no previous file with comments | « components/mus/ws/window_finder.cc ('k') | components/mus/ws/window_manager_access_policy.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698