OLD | NEW |
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "ash/common/display/display_info.h" | 5 #include "ui/display/manager/managed_display_info.h" |
6 | 6 |
7 #include "testing/gtest/include/gtest/gtest.h" | 7 #include "testing/gtest/include/gtest/gtest.h" |
8 | 8 |
9 namespace ash { | 9 namespace display { |
10 namespace { | 10 namespace { |
11 | 11 |
12 std::string GetModeSizeInDIP(const gfx::Size& size, | 12 std::string GetModeSizeInDIP(const gfx::Size& size, |
13 float device_scale_factor, | 13 float device_scale_factor, |
14 float ui_scale, | 14 float ui_scale, |
15 bool is_internal) { | 15 bool is_internal) { |
16 scoped_refptr<ManagedDisplayMode> mode = new ManagedDisplayMode( | 16 scoped_refptr<ManagedDisplayMode> mode = new ManagedDisplayMode( |
17 size, 0.0 /* refresh_rate */, false /* interlaced */, false /* native */, | 17 size, 0.0 /* refresh_rate */, false /* interlaced */, false /* native */, |
18 ui_scale, device_scale_factor); | 18 ui_scale, device_scale_factor); |
19 return mode->GetSizeInDIP(is_internal).ToString(); | 19 return mode->GetSizeInDIP(is_internal).ToString(); |
20 } | 20 } |
21 | 21 |
22 } // namespace | 22 } // namespace |
23 | 23 |
24 typedef testing::Test DisplayInfoTest; | 24 typedef testing::Test DisplayInfoTest; |
25 | 25 |
26 TEST_F(DisplayInfoTest, CreateFromSpec) { | 26 TEST_F(DisplayInfoTest, CreateFromSpec) { |
27 DisplayInfo info = DisplayInfo::CreateFromSpecWithID("200x100", 10); | 27 ManagedDisplayInfo info = |
| 28 ManagedDisplayInfo::CreateFromSpecWithID("200x100", 10); |
28 EXPECT_EQ(10, info.id()); | 29 EXPECT_EQ(10, info.id()); |
29 EXPECT_EQ("0,0 200x100", info.bounds_in_native().ToString()); | 30 EXPECT_EQ("0,0 200x100", info.bounds_in_native().ToString()); |
30 EXPECT_EQ("200x100", info.size_in_pixel().ToString()); | 31 EXPECT_EQ("200x100", info.size_in_pixel().ToString()); |
31 EXPECT_EQ(display::Display::ROTATE_0, info.GetActiveRotation()); | 32 EXPECT_EQ(display::Display::ROTATE_0, info.GetActiveRotation()); |
32 EXPECT_EQ("0,0,0,0", info.overscan_insets_in_dip().ToString()); | 33 EXPECT_EQ("0,0,0,0", info.overscan_insets_in_dip().ToString()); |
33 EXPECT_EQ(1.0f, info.configured_ui_scale()); | 34 EXPECT_EQ(1.0f, info.configured_ui_scale()); |
34 | 35 |
35 info = DisplayInfo::CreateFromSpecWithID("10+20-300x400*2/o", 10); | 36 info = ManagedDisplayInfo::CreateFromSpecWithID("10+20-300x400*2/o", 10); |
36 EXPECT_EQ("10,20 300x400", info.bounds_in_native().ToString()); | 37 EXPECT_EQ("10,20 300x400", info.bounds_in_native().ToString()); |
37 EXPECT_EQ("288x380", info.size_in_pixel().ToString()); | 38 EXPECT_EQ("288x380", info.size_in_pixel().ToString()); |
38 EXPECT_EQ(display::Display::ROTATE_0, info.GetActiveRotation()); | 39 EXPECT_EQ(display::Display::ROTATE_0, info.GetActiveRotation()); |
39 EXPECT_EQ("5,3,5,3", info.overscan_insets_in_dip().ToString()); | 40 EXPECT_EQ("5,3,5,3", info.overscan_insets_in_dip().ToString()); |
40 | 41 |
41 info = DisplayInfo::CreateFromSpecWithID("10+20-300x400*2/ob", 10); | 42 info = ManagedDisplayInfo::CreateFromSpecWithID("10+20-300x400*2/ob", 10); |
42 EXPECT_EQ("10,20 300x400", info.bounds_in_native().ToString()); | 43 EXPECT_EQ("10,20 300x400", info.bounds_in_native().ToString()); |
43 EXPECT_EQ("288x380", info.size_in_pixel().ToString()); | 44 EXPECT_EQ("288x380", info.size_in_pixel().ToString()); |
44 EXPECT_EQ(display::Display::ROTATE_0, info.GetActiveRotation()); | 45 EXPECT_EQ(display::Display::ROTATE_0, info.GetActiveRotation()); |
45 EXPECT_EQ("5,3,5,3", info.overscan_insets_in_dip().ToString()); | 46 EXPECT_EQ("5,3,5,3", info.overscan_insets_in_dip().ToString()); |
46 | 47 |
47 info = DisplayInfo::CreateFromSpecWithID("10+20-300x400*2/or", 10); | 48 info = ManagedDisplayInfo::CreateFromSpecWithID("10+20-300x400*2/or", 10); |
48 EXPECT_EQ("10,20 300x400", info.bounds_in_native().ToString()); | 49 EXPECT_EQ("10,20 300x400", info.bounds_in_native().ToString()); |
49 EXPECT_EQ("380x288", info.size_in_pixel().ToString()); | 50 EXPECT_EQ("380x288", info.size_in_pixel().ToString()); |
50 EXPECT_EQ(display::Display::ROTATE_90, info.GetActiveRotation()); | 51 EXPECT_EQ(display::Display::ROTATE_90, info.GetActiveRotation()); |
51 // TODO(oshima): This should be rotated too. Fix this. | 52 // TODO(oshima): This should be rotated too. Fix this. |
52 EXPECT_EQ("5,3,5,3", info.overscan_insets_in_dip().ToString()); | 53 EXPECT_EQ("5,3,5,3", info.overscan_insets_in_dip().ToString()); |
53 | 54 |
54 info = DisplayInfo::CreateFromSpecWithID("10+20-300x400*2/l@1.5", 10); | 55 info = ManagedDisplayInfo::CreateFromSpecWithID("10+20-300x400*2/l@1.5", 10); |
55 EXPECT_EQ("10,20 300x400", info.bounds_in_native().ToString()); | 56 EXPECT_EQ("10,20 300x400", info.bounds_in_native().ToString()); |
56 EXPECT_EQ(display::Display::ROTATE_270, info.GetActiveRotation()); | 57 EXPECT_EQ(display::Display::ROTATE_270, info.GetActiveRotation()); |
57 EXPECT_EQ(1.5f, info.configured_ui_scale()); | 58 EXPECT_EQ(1.5f, info.configured_ui_scale()); |
58 | 59 |
59 info = DisplayInfo::CreateFromSpecWithID( | 60 info = ManagedDisplayInfo::CreateFromSpecWithID( |
60 "200x200#300x200|200x200%59.9|100x100%60|150x100*2|150x150*1.25%30", 10); | 61 "200x200#300x200|200x200%59.9|100x100%60|150x100*2|150x150*1.25%30", 10); |
61 | 62 |
62 EXPECT_EQ("0,0 200x200", info.bounds_in_native().ToString()); | 63 EXPECT_EQ("0,0 200x200", info.bounds_in_native().ToString()); |
63 EXPECT_EQ(5u, info.display_modes().size()); | 64 EXPECT_EQ(5u, info.display_modes().size()); |
64 // Modes are sorted in DIP for external display. | 65 // Modes are sorted in DIP for external display. |
65 EXPECT_EQ("150x100", info.display_modes()[0]->size().ToString()); | 66 EXPECT_EQ("150x100", info.display_modes()[0]->size().ToString()); |
66 EXPECT_EQ("100x100", info.display_modes()[1]->size().ToString()); | 67 EXPECT_EQ("100x100", info.display_modes()[1]->size().ToString()); |
67 EXPECT_EQ("150x150", info.display_modes()[2]->size().ToString()); | 68 EXPECT_EQ("150x150", info.display_modes()[2]->size().ToString()); |
68 EXPECT_EQ("200x200", info.display_modes()[3]->size().ToString()); | 69 EXPECT_EQ("200x200", info.display_modes()[3]->size().ToString()); |
69 EXPECT_EQ("300x200", info.display_modes()[4]->size().ToString()); | 70 EXPECT_EQ("300x200", info.display_modes()[4]->size().ToString()); |
(...skipping 48 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
118 } | 119 } |
119 | 120 |
120 TEST_F(DisplayInfoTest, ManagedDisplayModeGetSizeForExternal4K) { | 121 TEST_F(DisplayInfoTest, ManagedDisplayModeGetSizeForExternal4K) { |
121 gfx::Size size(3840, 2160); | 122 gfx::Size size(3840, 2160); |
122 EXPECT_EQ("1920x1080", GetModeSizeInDIP(size, 2.0f, 1.0f, false)); | 123 EXPECT_EQ("1920x1080", GetModeSizeInDIP(size, 2.0f, 1.0f, false)); |
123 EXPECT_EQ("3072x1728", GetModeSizeInDIP(size, 1.25f, 1.0f, false)); | 124 EXPECT_EQ("3072x1728", GetModeSizeInDIP(size, 1.25f, 1.0f, false)); |
124 EXPECT_EQ("3840x2160", GetModeSizeInDIP(size, 1.0f, 1.0f, false)); | 125 EXPECT_EQ("3840x2160", GetModeSizeInDIP(size, 1.0f, 1.0f, false)); |
125 } | 126 } |
126 | 127 |
127 TEST_F(DisplayInfoTest, InputDevicesTest) { | 128 TEST_F(DisplayInfoTest, InputDevicesTest) { |
128 DisplayInfo info = DisplayInfo::CreateFromSpecWithID("200x100", 10); | 129 ManagedDisplayInfo info = |
| 130 ManagedDisplayInfo::CreateFromSpecWithID("200x100", 10); |
129 | 131 |
130 EXPECT_EQ(0u, info.input_devices().size()); | 132 EXPECT_EQ(0u, info.input_devices().size()); |
131 | 133 |
132 info.AddInputDevice(10); | 134 info.AddInputDevice(10); |
133 EXPECT_EQ(1u, info.input_devices().size()); | 135 EXPECT_EQ(1u, info.input_devices().size()); |
134 EXPECT_EQ(10, info.input_devices()[0]); | 136 EXPECT_EQ(10, info.input_devices()[0]); |
135 info.AddInputDevice(11); | 137 info.AddInputDevice(11); |
136 EXPECT_EQ(2u, info.input_devices().size()); | 138 EXPECT_EQ(2u, info.input_devices().size()); |
137 EXPECT_EQ(10, info.input_devices()[0]); | 139 EXPECT_EQ(10, info.input_devices()[0]); |
138 EXPECT_EQ(11, info.input_devices()[1]); | 140 EXPECT_EQ(11, info.input_devices()[1]); |
139 | 141 |
140 DisplayInfo copy_info = DisplayInfo::CreateFromSpecWithID("200x100", 10); | 142 ManagedDisplayInfo copy_info = |
| 143 ManagedDisplayInfo::CreateFromSpecWithID("200x100", 10); |
141 copy_info.Copy(info); | 144 copy_info.Copy(info); |
142 EXPECT_EQ(2u, copy_info.input_devices().size()); | 145 EXPECT_EQ(2u, copy_info.input_devices().size()); |
143 copy_info.ClearInputDevices(); | 146 copy_info.ClearInputDevices(); |
144 EXPECT_EQ(0u, copy_info.input_devices().size()); | 147 EXPECT_EQ(0u, copy_info.input_devices().size()); |
145 } | 148 } |
146 | 149 |
147 } // namespace ash | 150 } // namespace display |
OLD | NEW |