| 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 ui { |
| 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 ui |
| OLD | NEW |