tests: Make monitor unit tests create initial config
This way we have both the test setup and testing in the same file. https://bugzilla.gnome.org/show_bug.cgi?id=777732
This commit is contained in:
parent
95c101a0ba
commit
c6d940d3b2
@ -21,74 +21,42 @@
|
|||||||
|
|
||||||
#include "tests/meta-monitor-manager-test.h"
|
#include "tests/meta-monitor-manager-test.h"
|
||||||
|
|
||||||
#define ALL_TRANSFORMS ((1 << (META_MONITOR_TRANSFORM_FLIPPED_270 + 1)) - 1)
|
|
||||||
|
|
||||||
struct _MetaMonitorManagerTest
|
struct _MetaMonitorManagerTest
|
||||||
{
|
{
|
||||||
MetaMonitorManager parent;
|
MetaMonitorManager parent;
|
||||||
|
|
||||||
|
MetaMonitorTestSetup *test_setup;
|
||||||
};
|
};
|
||||||
|
|
||||||
G_DEFINE_TYPE (MetaMonitorManagerTest, meta_monitor_manager_test,
|
G_DEFINE_TYPE (MetaMonitorManagerTest, meta_monitor_manager_test,
|
||||||
META_TYPE_MONITOR_MANAGER)
|
META_TYPE_MONITOR_MANAGER)
|
||||||
|
|
||||||
|
static MetaMonitorTestSetup *_initial_test_setup = NULL;
|
||||||
|
|
||||||
|
void
|
||||||
|
meta_monitor_manager_test_init_test_setup (MetaMonitorTestSetup *test_setup)
|
||||||
|
{
|
||||||
|
_initial_test_setup = test_setup;
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
meta_monitor_manager_test_read_current (MetaMonitorManager *manager)
|
meta_monitor_manager_test_read_current (MetaMonitorManager *manager)
|
||||||
{
|
{
|
||||||
int n_monitors = 2;
|
MetaMonitorManagerTest *manager_test = META_MONITOR_MANAGER_TEST (manager);
|
||||||
int i;
|
|
||||||
|
|
||||||
manager->max_screen_width = 65535;
|
manager->max_screen_width = 65535;
|
||||||
manager->max_screen_height = 65535;
|
manager->max_screen_height = 65535;
|
||||||
manager->screen_width = 1024;
|
|
||||||
manager->screen_height = 768;
|
|
||||||
|
|
||||||
manager->modes = g_new0 (MetaMonitorMode, 1);
|
g_assert (manager_test->test_setup);
|
||||||
manager->n_modes = 1;
|
|
||||||
|
|
||||||
manager->modes[0].mode_id = 0;
|
manager->modes = manager_test->test_setup->modes;
|
||||||
manager->modes[0].width = 1024;
|
manager->n_modes = manager_test->test_setup->n_modes;
|
||||||
manager->modes[0].height = 768;
|
|
||||||
manager->modes[0].refresh_rate = 60.0;
|
|
||||||
|
|
||||||
manager->crtcs = g_new0 (MetaCRTC, n_monitors);
|
manager->crtcs = manager_test->test_setup->crtcs;
|
||||||
manager->n_crtcs = n_monitors;
|
manager->n_crtcs = manager_test->test_setup->n_crtcs;
|
||||||
manager->outputs = g_new0 (MetaOutput, n_monitors);
|
|
||||||
manager->n_outputs = n_monitors;
|
|
||||||
|
|
||||||
for (i = 0; i < n_monitors; i++)
|
manager->outputs = manager_test->test_setup->outputs;
|
||||||
{
|
manager->n_outputs = manager_test->test_setup->n_outputs;
|
||||||
manager->crtcs[i].crtc_id = i + 1;
|
|
||||||
manager->crtcs[i].current_mode = &manager->modes[0];
|
|
||||||
manager->crtcs[i].transform = META_MONITOR_TRANSFORM_NORMAL;
|
|
||||||
manager->crtcs[i].all_transforms = ALL_TRANSFORMS;
|
|
||||||
|
|
||||||
|
|
||||||
manager->outputs[i].crtc = &manager->crtcs[i];
|
|
||||||
manager->outputs[i].winsys_id = i + 1;
|
|
||||||
manager->outputs[i].name = g_strdup_printf ("LVDS%d", i + 1);
|
|
||||||
manager->outputs[i].vendor = g_strdup ("MetaProducts Inc.");
|
|
||||||
manager->outputs[i].product = g_strdup ("unknown");
|
|
||||||
manager->outputs[i].serial = g_strdup ("0xC0FFEE");
|
|
||||||
manager->outputs[i].suggested_x = -1;
|
|
||||||
manager->outputs[i].suggested_y = -1;
|
|
||||||
manager->outputs[i].width_mm = 222;
|
|
||||||
manager->outputs[i].height_mm = 125;
|
|
||||||
manager->outputs[i].subpixel_order = COGL_SUBPIXEL_ORDER_UNKNOWN;
|
|
||||||
manager->outputs[i].preferred_mode = &manager->modes[0];
|
|
||||||
manager->outputs[i].n_modes = 1;
|
|
||||||
manager->outputs[i].modes = g_new0 (MetaMonitorMode *, 1);
|
|
||||||
manager->outputs[i].modes[0] = &manager->modes[0];
|
|
||||||
manager->outputs[i].n_possible_crtcs = 1;
|
|
||||||
manager->outputs[i].possible_crtcs = g_new0 (MetaCRTC *, 1);
|
|
||||||
manager->outputs[i].possible_crtcs[0] = &manager->crtcs[i];
|
|
||||||
manager->outputs[i].n_possible_clones = 0;
|
|
||||||
manager->outputs[i].possible_clones = g_new0 (MetaOutput *, 0);
|
|
||||||
manager->outputs[i].backlight = -1;
|
|
||||||
manager->outputs[i].backlight_min = 0;
|
|
||||||
manager->outputs[i].backlight_max = 0;
|
|
||||||
manager->outputs[i].connector_type = META_CONNECTOR_TYPE_LVDS;
|
|
||||||
manager->outputs[i].scale = 1;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -208,6 +176,9 @@ meta_monitor_manager_test_apply_configuration (MetaMonitorManager *manager,
|
|||||||
static void
|
static void
|
||||||
meta_monitor_manager_test_init (MetaMonitorManagerTest *manager_test)
|
meta_monitor_manager_test_init (MetaMonitorManagerTest *manager_test)
|
||||||
{
|
{
|
||||||
|
g_assert (_initial_test_setup);
|
||||||
|
|
||||||
|
manager_test->test_setup = _initial_test_setup;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -22,8 +22,20 @@
|
|||||||
|
|
||||||
#include "backends/meta-monitor-manager-private.h"
|
#include "backends/meta-monitor-manager-private.h"
|
||||||
|
|
||||||
|
typedef struct _MetaMonitorTestSetup
|
||||||
|
{
|
||||||
|
MetaMonitorMode *modes;
|
||||||
|
int n_modes;
|
||||||
|
MetaOutput *outputs;
|
||||||
|
int n_outputs;
|
||||||
|
MetaCRTC *crtcs;
|
||||||
|
int n_crtcs;
|
||||||
|
} MetaMonitorTestSetup;
|
||||||
|
|
||||||
#define META_TYPE_MONITOR_MANAGER_TEST (meta_monitor_manager_test_get_type ())
|
#define META_TYPE_MONITOR_MANAGER_TEST (meta_monitor_manager_test_get_type ())
|
||||||
G_DECLARE_FINAL_TYPE (MetaMonitorManagerTest, meta_monitor_manager_test,
|
G_DECLARE_FINAL_TYPE (MetaMonitorManagerTest, meta_monitor_manager_test,
|
||||||
META, MONITOR_MANAGER_TEST, MetaMonitorManager)
|
META, MONITOR_MANAGER_TEST, MetaMonitorManager)
|
||||||
|
|
||||||
|
void meta_monitor_manager_test_init_test_setup (MetaMonitorTestSetup *test_setup);
|
||||||
|
|
||||||
#endif /* META_MONITOR_MANAGER_TEST_H */
|
#endif /* META_MONITOR_MANAGER_TEST_H */
|
||||||
|
@ -22,6 +22,11 @@
|
|||||||
#include "tests/monitor-unit-tests.h"
|
#include "tests/monitor-unit-tests.h"
|
||||||
|
|
||||||
#include "backends/meta-backend-private.h"
|
#include "backends/meta-backend-private.h"
|
||||||
|
#include "tests/meta-monitor-manager-test.h"
|
||||||
|
|
||||||
|
#define ALL_TRANSFORMS ((1 << (META_MONITOR_TRANSFORM_FLIPPED_270 + 1)) - 1)
|
||||||
|
|
||||||
|
static MetaMonitorTestSetup *current_test_setup = NULL;
|
||||||
|
|
||||||
static void
|
static void
|
||||||
meta_test_monitor_linear_config (void)
|
meta_test_monitor_linear_config (void)
|
||||||
@ -60,9 +65,69 @@ meta_test_monitor_linear_config (void)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
setup_initial_monitor_test_setup (void)
|
||||||
|
{
|
||||||
|
MetaMonitorTestSetup *test_setup;
|
||||||
|
int n_monitors = 2;
|
||||||
|
int i;
|
||||||
|
|
||||||
|
test_setup = g_new0 (MetaMonitorTestSetup, 1);
|
||||||
|
|
||||||
|
test_setup->n_modes = 1;
|
||||||
|
test_setup->modes = g_new0 (MetaMonitorMode, 1);
|
||||||
|
test_setup->modes[0].mode_id = 0;
|
||||||
|
test_setup->modes[0].width = 1024;
|
||||||
|
test_setup->modes[0].height = 768;
|
||||||
|
test_setup->modes[0].refresh_rate = 60.0;
|
||||||
|
|
||||||
|
test_setup->n_crtcs = n_monitors;
|
||||||
|
test_setup->crtcs = g_new0 (MetaCRTC, n_monitors);
|
||||||
|
|
||||||
|
test_setup->n_outputs = n_monitors;
|
||||||
|
test_setup->outputs = g_new0 (MetaOutput, n_monitors);
|
||||||
|
|
||||||
|
for (i = 0; i < n_monitors; i++)
|
||||||
|
{
|
||||||
|
test_setup->crtcs[i].crtc_id = i + 1;
|
||||||
|
test_setup->crtcs[i].current_mode = &test_setup->modes[0];
|
||||||
|
test_setup->crtcs[i].transform = META_MONITOR_TRANSFORM_NORMAL;
|
||||||
|
test_setup->crtcs[i].all_transforms = ALL_TRANSFORMS;
|
||||||
|
|
||||||
|
test_setup->outputs[i].crtc = &test_setup->crtcs[i];
|
||||||
|
test_setup->outputs[i].winsys_id = i + 1;
|
||||||
|
test_setup->outputs[i].name = g_strdup_printf ("LVDS%d", i + 1);
|
||||||
|
test_setup->outputs[i].vendor = g_strdup ("MetaProducts Inc.");
|
||||||
|
test_setup->outputs[i].product = g_strdup ("unknown");
|
||||||
|
test_setup->outputs[i].serial = g_strdup ("0xC0FFEE");
|
||||||
|
test_setup->outputs[i].suggested_x = -1;
|
||||||
|
test_setup->outputs[i].suggested_y = -1;
|
||||||
|
test_setup->outputs[i].width_mm = 222;
|
||||||
|
test_setup->outputs[i].height_mm = 125;
|
||||||
|
test_setup->outputs[i].subpixel_order = COGL_SUBPIXEL_ORDER_UNKNOWN;
|
||||||
|
test_setup->outputs[i].preferred_mode = &test_setup->modes[0];
|
||||||
|
test_setup->outputs[i].n_modes = 1;
|
||||||
|
test_setup->outputs[i].modes = g_new0 (MetaMonitorMode *, 1);
|
||||||
|
test_setup->outputs[i].modes[0] = &test_setup->modes[0];
|
||||||
|
test_setup->outputs[i].n_possible_crtcs = 1;
|
||||||
|
test_setup->outputs[i].possible_crtcs = g_new0 (MetaCRTC *, 1);
|
||||||
|
test_setup->outputs[i].possible_crtcs[0] = &test_setup->crtcs[i];
|
||||||
|
test_setup->outputs[i].n_possible_clones = 0;
|
||||||
|
test_setup->outputs[i].possible_clones = NULL;
|
||||||
|
test_setup->outputs[i].backlight = -1;
|
||||||
|
test_setup->outputs[i].connector_type = META_CONNECTOR_TYPE_LVDS;
|
||||||
|
test_setup->outputs[i].scale = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
meta_monitor_manager_test_init_test_setup (test_setup);
|
||||||
|
current_test_setup = test_setup;
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
init_monitor_tests (void)
|
init_monitor_tests (void)
|
||||||
{
|
{
|
||||||
|
setup_initial_monitor_test_setup ();
|
||||||
|
|
||||||
g_test_add_func ("/backends/monitor/linear-config",
|
g_test_add_func ("/backends/monitor/linear-config",
|
||||||
meta_test_monitor_linear_config);
|
meta_test_monitor_linear_config);
|
||||||
}
|
}
|
||||||
|
@ -221,6 +221,8 @@ main (int argc, char *argv[])
|
|||||||
|
|
||||||
g_option_context_free (ctx);
|
g_option_context_free (ctx);
|
||||||
|
|
||||||
|
init_tests (argc, argv);
|
||||||
|
|
||||||
meta_plugin_manager_load ("default");
|
meta_plugin_manager_load ("default");
|
||||||
|
|
||||||
meta_override_compositor_configuration (META_COMPOSITOR_TYPE_WAYLAND,
|
meta_override_compositor_configuration (META_COMPOSITOR_TYPE_WAYLAND,
|
||||||
@ -230,7 +232,6 @@ main (int argc, char *argv[])
|
|||||||
meta_init ();
|
meta_init ();
|
||||||
meta_register_with_session ();
|
meta_register_with_session ();
|
||||||
|
|
||||||
init_tests (argc, argv);
|
|
||||||
g_idle_add (run_tests, NULL);
|
g_idle_add (run_tests, NULL);
|
||||||
|
|
||||||
return meta_run ();
|
return meta_run ();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user