testing: Use Cairo calls instead of gdk_draw_line() to test server sync

This commit is contained in:
Benjamin Otte 2010-07-15 01:08:03 +02:00
parent 188884a9b1
commit 761b0ea3ae

View File

@ -142,16 +142,19 @@ test_xserver_sync (void)
gtk_widget_show_now (window); gtk_widget_show_now (window);
while (repeat--) while (repeat--)
{ {
gint i, many = 100; gint i, many = 200;
double nosync_time, sync_time; double nosync_time, sync_time;
cairo_t *cr;
while (gtk_events_pending ()) while (gtk_events_pending ())
gtk_main_iteration (); gtk_main_iteration ();
cr = gdk_cairo_create (darea->window);
cairo_set_source_rgba (cr, 0, 1, 0, 0.1);
/* run a number of consecutive drawing requests, just using drawing queue */ /* run a number of consecutive drawing requests, just using drawing queue */
g_timer_start (gtimer); g_timer_start (gtimer);
for (i = 0; i < many; i++) for (i = 0; i < many; i++)
{ {
gdk_draw_line (darea->window, darea->style->black_gc, 0, 0, 320, 200); cairo_paint (cr);
gdk_draw_line (darea->window, darea->style->black_gc, 320, 0, 0, 200);
} }
g_timer_stop (gtimer); g_timer_stop (gtimer);
nosync_time = g_timer_elapsed (gtimer, NULL); nosync_time = g_timer_elapsed (gtimer, NULL);
@ -162,8 +165,7 @@ test_xserver_sync (void)
/* run a number of consecutive drawing requests with intermediate drawing syncs */ /* run a number of consecutive drawing requests with intermediate drawing syncs */
for (i = 0; i < many; i++) for (i = 0; i < many; i++)
{ {
gdk_draw_line (darea->window, darea->style->black_gc, 0, 0, 320, 200); cairo_paint (cr);
gdk_draw_line (darea->window, darea->style->black_gc, 320, 0, 0, 200);
gdk_test_render_sync (darea->window); gdk_test_render_sync (darea->window);
} }
g_timer_stop (gtimer); g_timer_stop (gtimer);