diff --git a/src/tests/monitor-configs/fractional-scale.xml b/src/tests/monitor-configs/fractional-scale.xml new file mode 100644 index 000000000..eeb49b6bc --- /dev/null +++ b/src/tests/monitor-configs/fractional-scale.xml @@ -0,0 +1,23 @@ + + + + 0 + 0 + yes + 1.5 + + + DP-1 + MetaProduct's Inc. + MetaMonitor + 0x123456 + + + 1200 + 900 + 60.000495910644531 + + + + + diff --git a/src/tests/monitor-store-unit-tests.c b/src/tests/monitor-store-unit-tests.c index b9a879891..ea6fa509d 100644 --- a/src/tests/monitor-store-unit-tests.c +++ b/src/tests/monitor-store-unit-tests.c @@ -521,6 +521,62 @@ meta_test_monitor_store_scale (void) check_monitor_configurations (&expect); } +static void +meta_test_monitor_store_fractional_scale (void) +{ + MonitorStoreTestExpect expect = { + .configurations = { + { + .logical_monitors = { + { + .layout = { + .x = 0, + .y = 0, + .width = 800, + .height = 600 + }, + .scale = 1.5, + .is_primary = TRUE, + .is_presentation = FALSE, + .monitors = { + { + .connector = "DP-1", + .vendor = "MetaProduct's Inc.", + .product = "MetaMonitor", + .serial = "0x123456", + .mode = { + .width = 1200, + .height = 900, + .refresh_rate = 60.000495910644531 + } + } + }, + .n_monitors = 1, + } + }, + .n_logical_monitors = 1 + } + }, + .n_configurations = 1 + }; + + if (!is_using_monitor_config_manager ()) + { + g_test_skip ("Not using MetaMonitorConfigManager"); + return; + } + + if (!meta_is_stage_views_enabled ()) + { + g_test_skip ("Not using stage views"); + return; + } + + set_custom_monitor_config ("fractional-scale.xml"); + + check_monitor_configurations (&expect); +} + static void meta_test_monitor_store_mirrored (void) { @@ -748,6 +804,8 @@ init_monitor_store_tests (void) meta_test_monitor_store_underscanning); g_test_add_func ("/backends/monitor-store/scale", meta_test_monitor_store_scale); + g_test_add_func ("/backends/monitor-store/fractional-scale", + meta_test_monitor_store_fractional_scale); g_test_add_func ("/backends/monitor-store/mirrored", meta_test_monitor_store_mirrored); g_test_add_func ("/backends/monitor-store/first-rotated", diff --git a/src/tests/monitor-unit-tests.c b/src/tests/monitor-unit-tests.c index aadd162f9..f3563cd8c 100644 --- a/src/tests/monitor-unit-tests.c +++ b/src/tests/monitor-unit-tests.c @@ -102,7 +102,7 @@ typedef struct _MonitorTestCaseOutput int width_mm; int height_mm; MetaTileInfo tile_info; - int scale; + float scale; gboolean is_laptop_panel; gboolean is_underscanning; } MonitorTestCaseOutput; @@ -152,7 +152,7 @@ typedef struct _MonitorTestCaseMonitor typedef struct _MonitorTestCaseLogicalMonitor { MetaRectangle layout; - int scale; + float scale; int monitors[MAX_N_MONITORS]; int n_monitors; MetaMonitorTransform transform; @@ -3009,6 +3009,108 @@ meta_test_monitor_custom_scale_config (void) check_monitor_configuration (&test_case); } +static void +meta_test_monitor_custom_fractional_scale_config (void) +{ + MonitorTestCase test_case = { + .setup = { + .modes = { + { + .width = 1200, + .height = 900, + .refresh_rate = 60.000495910644531 + } + }, + .n_modes = 1, + .outputs = { + { + .crtc = 0, + .modes = { 0 }, + .n_modes = 1, + .preferred_mode = 0, + .possible_crtcs = { 0 }, + .n_possible_crtcs = 1, + .width_mm = 222, + .height_mm = 125 + }, + }, + .n_outputs = 1, + .crtcs = { + { + .current_mode = 0 + }, + }, + .n_crtcs = 1 + }, + + .expect = { + .monitors = { + { + .outputs = { 0 }, + .n_outputs = 1, + .modes = { + { + .width = 1200, + .height = 900, + .crtc_modes = { + { + .output = 0, + .crtc_mode = 0 + } + } + } + }, + .n_modes = 1, + .current_mode = 0, + .width_mm = 222, + .height_mm = 125, + } + }, + .n_monitors = 1, + .logical_monitors = { + { + .monitors = { 0 }, + .n_monitors = 1, + .layout = { .x = 0, .y = 0, .width = 800, .height = 600 }, + .scale = 1.5 + } + }, + .n_logical_monitors = 1, + .primary_logical_monitor = 0, + .n_outputs = 1, + .crtcs = { + { + .current_mode = 0, + } + }, + .n_crtcs = 1, + .n_tiled_monitors = 0, + .screen_width = 800, + .screen_height = 600 + } + }; + MetaMonitorTestSetup *test_setup; + + if (!is_using_monitor_config_manager ()) + { + g_test_skip ("Not using MetaMonitorConfigManager"); + return; + } + + if (!meta_is_stage_views_enabled ()) + { + g_test_skip ("Not using stage views"); + return; + } + + test_setup = create_monitor_test_setup (&test_case, + MONITOR_TEST_FLAG_NONE); + set_custom_monitor_config ("fractional-scale.xml"); + emulate_hotplug (test_setup); + + check_monitor_configuration (&test_case); +} + static void meta_test_monitor_custom_tiled_config (void) { @@ -4288,6 +4390,8 @@ init_monitor_tests (void) meta_test_monitor_custom_underscanning_config); g_test_add_func ("/backends/monitor/custom/scale-config", meta_test_monitor_custom_scale_config); + g_test_add_func ("/backends/monitor/custom/fractional-scale-config", + meta_test_monitor_custom_fractional_scale_config); g_test_add_func ("/backends/monitor/custom/tiled-config", meta_test_monitor_custom_tiled_config); g_test_add_func ("/backends/monitor/custom/tiled-custom-resolution-config",