| Index: ash/display/display_util_x11_unittest.cc
|
| diff --git a/ash/display/display_util_x11_unittest.cc b/ash/display/display_util_x11_unittest.cc
|
| index f534a28dcbbb3b978160ac898cf5cc7383172357..f48a50e729023f620d4e31d9ca6275741062c992 100644
|
| --- a/ash/display/display_util_x11_unittest.cc
|
| +++ b/ash/display/display_util_x11_unittest.cc
|
| @@ -10,9 +10,12 @@
|
| #undef Bool
|
| #undef None
|
|
|
| +#include "chromeos/display/output_configurator.h"
|
| #include "chromeos/display/output_util.h"
|
| #include "testing/gtest/include/gtest/gtest.h"
|
|
|
| +using chromeos::OutputConfigurator;
|
| +
|
| typedef testing::Test DisplayUtilX11Test;
|
|
|
| namespace ash {
|
| @@ -31,48 +34,32 @@ TEST_F(DisplayUtilX11Test, TestBlackListedDisplay) {
|
| }
|
|
|
| TEST_F(DisplayUtilX11Test, GetResolutionList) {
|
| - XRRScreenResources resources = {0};
|
| - RROutput outputs[] = {1};
|
| - resources.noutput = arraysize(outputs);
|
| - resources.outputs = outputs;
|
| - XRRModeInfo modes[] = {
|
| - // id, width, height, interlaced, refresh rate
|
| - chromeos::test::CreateModeInfo(11, 1920, 1200, false, 60.0f),
|
| -
|
| - // different rates
|
| - chromeos::test::CreateModeInfo(12, 1920, 1080, false, 30.0f),
|
| - chromeos::test::CreateModeInfo(13, 1920, 1080, false, 50.0f),
|
| - chromeos::test::CreateModeInfo(14, 1920, 1080, false, 40.0f),
|
| -
|
| - // interlace vs non interlace
|
| - chromeos::test::CreateModeInfo(15, 1280, 720, true, 60.0f),
|
| - chromeos::test::CreateModeInfo(16, 1280, 720, false, 40.0f),
|
| -
|
| - // interlace only
|
| - chromeos::test::CreateModeInfo(17, 1024, 768, true, 40.0f),
|
| - chromeos::test::CreateModeInfo(18, 1024, 768, true, 60.0f),
|
| -
|
| - // mixed
|
| - chromeos::test::CreateModeInfo(19, 1024, 600, true, 60.0f),
|
| - chromeos::test::CreateModeInfo(20, 1024, 600, false, 40.0f),
|
| - chromeos::test::CreateModeInfo(21, 1024, 600, false, 50.0f),
|
| -
|
| - // just one interlaced mode
|
| - chromeos::test::CreateModeInfo(22, 640, 480, true, 60.0f),
|
| - };
|
| - resources.nmode = arraysize(modes);
|
| - resources.modes = modes;
|
| -
|
| - XRROutputInfo output_info = {0};
|
| - RRMode output_modes[] = {
|
| - 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22
|
| - };
|
| - output_info.nmode = arraysize(output_modes);
|
| - output_info.modes = output_modes;
|
| -
|
| - std::vector<Resolution> resolutions =
|
| - GetResolutionList(&resources, &output_info);
|
| - EXPECT_EQ(6u, resolutions.size());
|
| + OutputConfigurator::OutputSnapshot output;
|
| + output.mode_infos[11] = OutputConfigurator::ModeInfo(1920, 1200, false);
|
| +
|
| + // All non-interlaced (as would be seen with different refresh rates).
|
| + output.mode_infos[12] = OutputConfigurator::ModeInfo(1920, 1080, false);
|
| + output.mode_infos[13] = OutputConfigurator::ModeInfo(1920, 1080, false);
|
| + output.mode_infos[14] = OutputConfigurator::ModeInfo(1920, 1080, false);
|
| +
|
| + // Interlaced vs non-interlaced.
|
| + output.mode_infos[15] = OutputConfigurator::ModeInfo(1280, 720, true);
|
| + output.mode_infos[16] = OutputConfigurator::ModeInfo(1280, 720, false);
|
| +
|
| + // Interlaced only.
|
| + output.mode_infos[17] = OutputConfigurator::ModeInfo(1024, 768, true);
|
| + output.mode_infos[18] = OutputConfigurator::ModeInfo(1024, 768, true);
|
| +
|
| + // Mixed.
|
| + output.mode_infos[19] = OutputConfigurator::ModeInfo(1024, 600, true);
|
| + output.mode_infos[20] = OutputConfigurator::ModeInfo(1024, 600, false);
|
| + output.mode_infos[21] = OutputConfigurator::ModeInfo(1024, 600, false);
|
| +
|
| + // Just one interlaced mode.
|
| + output.mode_infos[22] = OutputConfigurator::ModeInfo(640, 480, true);
|
| +
|
| + std::vector<Resolution> resolutions = GetResolutionList(output);
|
| + ASSERT_EQ(6u, resolutions.size());
|
| EXPECT_EQ("1920x1200", resolutions[0].size.ToString());
|
| EXPECT_FALSE(resolutions[0].interlaced);
|
|
|
| @@ -91,12 +78,9 @@ TEST_F(DisplayUtilX11Test, GetResolutionList) {
|
| EXPECT_EQ("640x480", resolutions[5].size.ToString());
|
| EXPECT_TRUE(resolutions[5].interlaced);
|
|
|
| - // Empty output shouldn't crash.
|
| - RRMode empty_output_modes[] = {};
|
| - output_info.nmode = 0;
|
| - output_info.modes = empty_output_modes;
|
| -
|
| - resolutions = GetResolutionList(&resources, &output_info);
|
| + // Outputs without any modes shouldn't cause a crash.
|
| + output.mode_infos.clear();
|
| + resolutions = GetResolutionList(output);
|
| EXPECT_EQ(0u, resolutions.size());
|
| }
|
|
|
|
|