| Index: ash/display/display_change_observer_chromeos_unittest.cc
|
| diff --git a/ash/display/display_change_observer_chromeos_unittest.cc b/ash/display/display_change_observer_chromeos_unittest.cc
|
| index b0df4ae43eb31ca9dba9e192469166b3a983d154..d274764d765daf99a63e899ffc47f745f83baa19 100644
|
| --- a/ash/display/display_change_observer_chromeos_unittest.cc
|
| +++ b/ash/display/display_change_observer_chromeos_unittest.cc
|
| @@ -17,7 +17,7 @@ typedef testing::Test DisplayChangeObserverTest;
|
|
|
| namespace ash {
|
|
|
| -TEST_F(DisplayChangeObserverTest, GetDisplayModeList) {
|
| +TEST_F(DisplayChangeObserverTest, GetExternalDisplayModeList) {
|
| ScopedVector<const ui::DisplayMode> modes;
|
| modes.push_back(new ui::DisplayMode(gfx::Size(1920, 1200), false, 60));
|
|
|
| @@ -48,37 +48,168 @@ TEST_F(DisplayChangeObserverTest, GetDisplayModeList) {
|
| output.display = &display_snapshot;
|
|
|
| std::vector<DisplayMode> display_modes =
|
| - DisplayChangeObserver::GetDisplayModeList(output);
|
| + DisplayChangeObserver::GetExternalDisplayModeList(output);
|
| ASSERT_EQ(6u, display_modes.size());
|
| - EXPECT_EQ("1920x1200", display_modes[0].size.ToString());
|
| - EXPECT_FALSE(display_modes[0].interlaced);
|
| + EXPECT_EQ("640x480", display_modes[0].size.ToString());
|
| + EXPECT_TRUE(display_modes[0].interlaced);
|
| EXPECT_EQ(display_modes[0].refresh_rate, 60);
|
|
|
| - EXPECT_EQ("1920x1080", display_modes[1].size.ToString());
|
| + EXPECT_EQ("1024x600", display_modes[1].size.ToString());
|
| EXPECT_FALSE(display_modes[1].interlaced);
|
| - EXPECT_EQ(display_modes[1].refresh_rate, 80);
|
| + EXPECT_EQ(display_modes[1].refresh_rate, 70);
|
|
|
| - EXPECT_EQ("1280x720", display_modes[2].size.ToString());
|
| - EXPECT_FALSE(display_modes[2].interlaced);
|
| - EXPECT_EQ(display_modes[2].refresh_rate, 60);
|
| + EXPECT_EQ("1024x768", display_modes[2].size.ToString());
|
| + EXPECT_TRUE(display_modes[2].interlaced);
|
| + EXPECT_EQ(display_modes[2].refresh_rate, 70);
|
|
|
| - EXPECT_EQ("1024x768", display_modes[3].size.ToString());
|
| - EXPECT_TRUE(display_modes[3].interlaced);
|
| - EXPECT_EQ(display_modes[3].refresh_rate, 70);
|
| + EXPECT_EQ("1280x720", display_modes[3].size.ToString());
|
| + EXPECT_FALSE(display_modes[3].interlaced);
|
| + EXPECT_EQ(display_modes[3].refresh_rate, 60);
|
|
|
| - EXPECT_EQ("1024x600", display_modes[4].size.ToString());
|
| + EXPECT_EQ("1920x1080", display_modes[4].size.ToString());
|
| EXPECT_FALSE(display_modes[4].interlaced);
|
| - EXPECT_EQ(display_modes[4].refresh_rate, 70);
|
| + EXPECT_EQ(display_modes[4].refresh_rate, 80);
|
|
|
| - EXPECT_EQ("640x480", display_modes[5].size.ToString());
|
| - EXPECT_TRUE(display_modes[5].interlaced);
|
| + EXPECT_EQ("1920x1200", display_modes[5].size.ToString());
|
| + EXPECT_FALSE(display_modes[5].interlaced);
|
| EXPECT_EQ(display_modes[5].refresh_rate, 60);
|
|
|
| // Outputs without any modes shouldn't cause a crash.
|
| modes.clear();
|
| display_snapshot.set_modes(modes.get());
|
|
|
| - display_modes = DisplayChangeObserver::GetDisplayModeList(output);
|
| + display_modes = DisplayChangeObserver::GetExternalDisplayModeList(output);
|
| + EXPECT_EQ(0u, display_modes.size());
|
| +}
|
| +
|
| +TEST_F(DisplayChangeObserverTest, GetInternalDisplayModeList) {
|
| + ScopedVector<const ui::DisplayMode> modes;
|
| + // Data picked from peppy.
|
| + modes.push_back(new ui::DisplayMode(gfx::Size(1366, 768), false, 60));
|
| + modes.push_back(new ui::DisplayMode(gfx::Size(1024, 768), false, 60));
|
| + modes.push_back(new ui::DisplayMode(gfx::Size(800, 600), false, 60));
|
| + modes.push_back(new ui::DisplayMode(gfx::Size(600, 600), false, 56.2));
|
| + modes.push_back(new ui::DisplayMode(gfx::Size(640, 480), false, 59.9));
|
| +
|
| + ui::TestDisplaySnapshot display_snapshot;
|
| + display_snapshot.set_modes(modes.get());
|
| + display_snapshot.set_native_mode(modes[0]);
|
| + DisplayConfigurator::DisplayState output;
|
| + output.display = &display_snapshot;
|
| +
|
| + DisplayInfo info;
|
| + info.SetBounds(gfx::Rect(0, 0, 1366, 768));
|
| +
|
| + std::vector<DisplayMode> display_modes =
|
| + DisplayChangeObserver::GetInternalDisplayModeList(info, output);
|
| + ASSERT_EQ(5u, display_modes.size());
|
| + EXPECT_EQ("1366x768", display_modes[0].size.ToString());
|
| + EXPECT_FALSE(display_modes[0].native);
|
| + EXPECT_NEAR(display_modes[0].ui_scale, 0.5, 0.01);
|
| + EXPECT_EQ(display_modes[0].refresh_rate, 60);
|
| +
|
| + EXPECT_EQ("1366x768", display_modes[1].size.ToString());
|
| + EXPECT_FALSE(display_modes[1].native);
|
| + EXPECT_NEAR(display_modes[1].ui_scale, 0.6, 0.01);
|
| + EXPECT_EQ(display_modes[1].refresh_rate, 60);
|
| +
|
| + EXPECT_EQ("1366x768", display_modes[2].size.ToString());
|
| + EXPECT_FALSE(display_modes[2].native);
|
| + EXPECT_NEAR(display_modes[2].ui_scale, 0.75, 0.01);
|
| + EXPECT_EQ(display_modes[2].refresh_rate, 60);
|
| +
|
| + EXPECT_EQ("1366x768", display_modes[3].size.ToString());
|
| + EXPECT_TRUE(display_modes[3].native);
|
| + EXPECT_NEAR(display_modes[3].ui_scale, 1.0, 0.01);
|
| + EXPECT_EQ(display_modes[3].refresh_rate, 60);
|
| +
|
| + EXPECT_EQ("1366x768", display_modes[4].size.ToString());
|
| + EXPECT_FALSE(display_modes[4].native);
|
| + EXPECT_NEAR(display_modes[4].ui_scale, 1.125, 0.01);
|
| + EXPECT_EQ(display_modes[4].refresh_rate, 60);
|
| +}
|
| +
|
| +TEST_F(DisplayChangeObserverTest, GetExternalDisplayModeList4K) {
|
| + ScopedVector<const ui::DisplayMode> modes;
|
| + modes.push_back(new ui::DisplayMode(gfx::Size(3840, 2160), false, 30));
|
| + modes.push_back(new ui::DisplayMode(gfx::Size(1920, 1200), false, 60));
|
| +
|
| + // All non-interlaced (as would be seen with different refresh rates).
|
| + modes.push_back(new ui::DisplayMode(gfx::Size(1920, 1080), false, 80));
|
| + modes.push_back(new ui::DisplayMode(gfx::Size(1920, 1080), false, 70));
|
| + modes.push_back(new ui::DisplayMode(gfx::Size(1920, 1080), false, 60));
|
| +
|
| + // Interlaced vs non-interlaced.
|
| + modes.push_back(new ui::DisplayMode(gfx::Size(1280, 720), true, 60));
|
| + modes.push_back(new ui::DisplayMode(gfx::Size(1280, 720), false, 60));
|
| +
|
| + // Interlaced only.
|
| + modes.push_back(new ui::DisplayMode(gfx::Size(1024, 768), true, 70));
|
| + modes.push_back(new ui::DisplayMode(gfx::Size(1024, 768), true, 60));
|
| +
|
| + // Mixed.
|
| + modes.push_back(new ui::DisplayMode(gfx::Size(1024, 600), true, 60));
|
| + modes.push_back(new ui::DisplayMode(gfx::Size(1024, 600), false, 70));
|
| + modes.push_back(new ui::DisplayMode(gfx::Size(1024, 600), false, 60));
|
| +
|
| + // Just one interlaced mode.
|
| + modes.push_back(new ui::DisplayMode(gfx::Size(640, 480), true, 60));
|
| +
|
| + ui::TestDisplaySnapshot display_snapshot;
|
| + display_snapshot.set_modes(modes.get());
|
| + display_snapshot.set_native_mode(modes[0]);
|
| + DisplayConfigurator::DisplayState output;
|
| + output.display = &display_snapshot;
|
| +
|
| + std::vector<DisplayMode> display_modes =
|
| + DisplayChangeObserver::GetExternalDisplayModeList(output);
|
| + ASSERT_EQ(9u, display_modes.size());
|
| + EXPECT_EQ("640x480", display_modes[0].size.ToString());
|
| + EXPECT_TRUE(display_modes[0].interlaced);
|
| + EXPECT_EQ(display_modes[0].refresh_rate, 60);
|
| +
|
| + EXPECT_EQ("1024x600", display_modes[1].size.ToString());
|
| + EXPECT_FALSE(display_modes[1].interlaced);
|
| + EXPECT_EQ(display_modes[1].refresh_rate, 70);
|
| +
|
| + EXPECT_EQ("1024x768", display_modes[2].size.ToString());
|
| + EXPECT_TRUE(display_modes[2].interlaced);
|
| + EXPECT_EQ(display_modes[2].refresh_rate, 70);
|
| +
|
| + EXPECT_EQ("1280x720", display_modes[3].size.ToString());
|
| + EXPECT_FALSE(display_modes[3].interlaced);
|
| + EXPECT_EQ(display_modes[3].refresh_rate, 60);
|
| +
|
| + EXPECT_EQ("1920x1080", display_modes[4].size.ToString());
|
| + EXPECT_FALSE(display_modes[4].interlaced);
|
| + EXPECT_EQ(display_modes[4].refresh_rate, 80);
|
| +
|
| + EXPECT_EQ("3840x2160", display_modes[5].size.ToString());
|
| + EXPECT_FALSE(display_modes[5].interlaced);
|
| + EXPECT_FALSE(display_modes[5].native);
|
| + EXPECT_EQ(display_modes[5].refresh_rate, 30);
|
| + EXPECT_EQ(display_modes[5].device_scale_factor, 2.0);
|
| +
|
| + EXPECT_EQ("1920x1200", display_modes[6].size.ToString());
|
| + EXPECT_FALSE(display_modes[6].interlaced);
|
| + EXPECT_EQ(display_modes[6].refresh_rate, 60);
|
| +
|
| + EXPECT_EQ("3840x2160", display_modes[7].size.ToString());
|
| + EXPECT_FALSE(display_modes[7].interlaced);
|
| + EXPECT_FALSE(display_modes[7].native);
|
| + EXPECT_EQ(display_modes[7].refresh_rate, 30);
|
| + EXPECT_EQ(display_modes[7].device_scale_factor, 1.25);
|
| +
|
| + EXPECT_EQ("3840x2160", display_modes[8].size.ToString());
|
| + EXPECT_FALSE(display_modes[8].interlaced);
|
| + EXPECT_TRUE(display_modes[8].native);
|
| + EXPECT_EQ(display_modes[8].refresh_rate, 30);
|
| +
|
| + // Outputs without any modes shouldn't cause a crash.
|
| + modes.clear();
|
| + display_snapshot.set_modes(modes.get());
|
| +
|
| + display_modes = DisplayChangeObserver::GetExternalDisplayModeList(output);
|
| EXPECT_EQ(0u, display_modes.size());
|
| }
|
|
|
|
|