headless-start-test: Ignore frame counter warnings

When running in slow or busy machines (hey CI!) or under valgrind headless
tests could fail because of a non fatal warning during initialization.

So define a fatal handler that ignores the frame counter warning.

https://gitlab.gnome.org/GNOME/mutter/merge_requests/581
This commit is contained in:
Marco Trevisan (Treviño) 2019-05-17 17:35:30 -05:00
parent c1059df7f9
commit f869e4d54b

View File

@ -32,6 +32,7 @@
#include "wayland/meta-wayland.h" #include "wayland/meta-wayland.h"
#define ALL_TRANSFORMS ((1 << (META_MONITOR_TRANSFORM_FLIPPED_270 + 1)) - 1) #define ALL_TRANSFORMS ((1 << (META_MONITOR_TRANSFORM_FLIPPED_270 + 1)) - 1)
#define FRAME_WARNING "Frame has assigned frame counter but no frame drawn time"
static gboolean static gboolean
run_tests (gpointer data) run_tests (gpointer data)
@ -40,6 +41,8 @@ run_tests (gpointer data)
MetaSettings *settings = meta_backend_get_settings (backend); MetaSettings *settings = meta_backend_get_settings (backend);
gboolean ret; gboolean ret;
g_test_log_set_fatal_handler (NULL, NULL);
meta_settings_override_experimental_features (settings); meta_settings_override_experimental_features (settings);
meta_settings_enable_experimental_feature ( meta_settings_enable_experimental_feature (
@ -53,6 +56,20 @@ run_tests (gpointer data)
return FALSE; return FALSE;
} }
static gboolean
ignore_frame_counter_warning (const gchar *log_domain,
GLogLevelFlags log_level,
const gchar *message,
gpointer user_data)
{
if ((log_level & G_LOG_LEVEL_WARNING) &&
g_strcmp0 (log_domain, "mutter") == 0 &&
g_str_has_suffix (message, FRAME_WARNING))
return FALSE;
return TRUE;
}
static void static void
meta_test_headless_start (void) meta_test_headless_start (void)
{ {
@ -193,6 +210,8 @@ main (int argc, char *argv[])
meta_init (); meta_init ();
meta_register_with_session (); meta_register_with_session ();
g_test_log_set_fatal_handler (ignore_frame_counter_warning, NULL);
g_idle_add (run_tests, NULL); g_idle_add (run_tests, NULL);
return meta_run (); return meta_run ();