summaryrefslogtreecommitdiff
path: root/testsuite
diff options
context:
space:
mode:
authorBenjamin Otte <otte@redhat.com>2015-11-04 04:50:18 +0100
committerBenjamin Otte <otte@redhat.com>2015-11-04 05:06:23 +0100
commit61db7da2efff78f5f61f4285e091fd2fd37c2952 (patch)
treebfe07967f68f1b82459c0a5fa881d305d92ae34c /testsuite
parent24391634b5ac78ddf431da1a50ca1e0ca16795c5 (diff)
downloadgtk+-61db7da2efff78f5f61f4285e091fd2fd37c2952.tar.gz
testsuite: Remove a bunch of broken tests
These tests have either been commented out for way too long or use APIs that we don't want to support.
Diffstat (limited to 'testsuite')
-rw-r--r--testsuite/gtk/Makefile.am11
-rw-r--r--testsuite/gtk/crossingevents.c628
-rw-r--r--testsuite/gtk/expander.c109
-rw-r--r--testsuite/gtk/filechooser.c2487
-rw-r--r--testsuite/gtk/testing.c304
-rw-r--r--testsuite/gtk/treeview-scrolling.c1473
6 files changed, 0 insertions, 5012 deletions
diff --git a/testsuite/gtk/Makefile.am b/testsuite/gtk/Makefile.am
index 517492a6c0..79f494654e 100644
--- a/testsuite/gtk/Makefile.am
+++ b/testsuite/gtk/Makefile.am
@@ -44,7 +44,6 @@ TEST_PROGS += \
cssprovider \
defaultvalue \
entry \
- expander \
firefox-stylecontext \
floating \
focus \
@@ -79,16 +78,6 @@ if OS_UNIX
#TEST_PROGS += defaultvalue
endif
-#TEST_PROGS += testing
-#TEST_PROGS += treeview-scrolling
-#TEST_PROGS += object
-#TEST_PROGS += filechooser
-
-# this doesn't work in make distcheck, since running
-# on a naked X server creates slightly different event
-# sequences than running on a normal desktop
-# TEST_PROGS += crossingevents
-
treemodel_SOURCES = \
treemodel.h \
treemodel.c \
diff --git a/testsuite/gtk/crossingevents.c b/testsuite/gtk/crossingevents.c
deleted file mode 100644
index be210f3c17..0000000000
--- a/testsuite/gtk/crossingevents.c
+++ /dev/null
@@ -1,628 +0,0 @@
-/*
- * crossingevents.c: A test for crossing events
- *
- * Copyright (C) 2008 Cody Russell
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 2 of the License, or (at your option) any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library. If not, see <http://www.gnu.org/licenses/>.
- */
-
-#include <gtk/gtk.h>
-#include <string.h>
-
-typedef struct {
- GtkWidget *window;
- GtkWidget *eventbox;
- GtkWidget *frame;
- GtkWidget *button;
- GtkWidget *check;
- gboolean events_connected;
- GQueue *queue;
-} CrossingTest;
-
-typedef struct {
- gboolean entered;
- gchar *name;
- gboolean synthesized;
- GdkCrossingMode mode;
- GdkNotifyType detail;
-} CrossingEventData;
-
-#define SLEEP_DURATION 100
-
-void start_events (CrossingTest *test);
-void stop_events (CrossingTest *test);
-
-static gboolean
-sleep_timeout_cb (gpointer data)
-{
- gtk_main_quit ();
- return FALSE;
-}
-
-static void
-sleep_in_main_loop (double fraction)
-{
- /* process all pending idles and events */
- while (g_main_context_pending (NULL))
- g_main_context_iteration (NULL, FALSE);
- /* sleeping probably isn't strictly necessary here */
- gdk_threads_add_timeout_full (G_MAXINT, fraction * SLEEP_DURATION, sleep_timeout_cb, NULL, NULL);
- gtk_main ();
- /* process any pending idles or events that arrived during sleep */
- while (g_main_context_pending (NULL))
- g_main_context_iteration (NULL, FALSE);
-}
-
-void
-set_cursor (GtkWidget *widget)
-{
- int x, y, w, h;
-
- gdk_window_get_origin (widget->window, &x, &y);
-
- x += widget->allocation.x;
- y += widget->allocation.y;
- w = widget->allocation.width;
- h = widget->allocation.height;
-
- gdk_display_warp_pointer (gtk_widget_get_display (widget),
- gtk_widget_get_screen (widget),
- x + w / 2,
- y + h / 2);
-
- sleep_in_main_loop (0.5);
-}
-
-static gboolean
-on_enter (GtkWidget *widget, GdkEventCrossing *event, gpointer user_data)
-{
- CrossingTest *test = (CrossingTest*)user_data;
-
- CrossingEventData *evt = g_slice_new0 (CrossingEventData);
- evt->entered = TRUE;
- evt->name = g_strdup (gtk_widget_get_name (widget));
- evt->synthesized = event->send_event;
- evt->mode = event->mode;
- evt->detail = event->detail;
-
- if (!test->queue)
- test->queue = g_queue_new ();
-
- g_queue_push_tail (test->queue, evt);
-
- return FALSE;
-}
-
-static gboolean
-on_leave (GtkWidget *widget, GdkEventCrossing *event, gpointer user_data)
-{
- CrossingTest *test = (CrossingTest*)user_data;
-
- CrossingEventData *evt = g_slice_new0 (CrossingEventData);
- evt->entered = FALSE;
- evt->name = g_strdup (gtk_widget_get_name (widget));
- evt->synthesized = event->send_event;
- evt->mode = event->mode;
- evt->detail = event->detail;
-
- if (!test->queue)
- test->queue = g_queue_new ();
-
- g_queue_push_tail (test->queue, evt);
-
- return FALSE;
-}
-
-static void
-on_check_toggled (GtkWidget *toggle, GtkWidget *button)
-{
- gtk_widget_set_sensitive (button, gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (toggle)));
-}
-
-static void
-sensitivity_setup (CrossingTest *test,
- gconstpointer user_data)
-{
- GtkWidget *frame;
-
- test->window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
- gtk_widget_set_name (test->window, "W");
- frame = gtk_frame_new ("Crossing Events");
- test->eventbox = gtk_event_box_new ();
- gtk_widget_set_name (test->eventbox, "E");
-
- GtkWidget *vbox = gtk_box_new (GTK_ORIENTATION_VERTICAL, FALSE, 10);
- gtk_container_add (GTK_CONTAINER (test->window), frame);
- gtk_container_add (GTK_CONTAINER (frame), test->eventbox);
- gtk_container_add (GTK_CONTAINER (test->eventbox), vbox);
-
- test->button = gtk_button_new_with_label ("Click me!");
- gtk_widget_set_name (test->button, "B");
- gtk_box_pack_start (GTK_BOX (vbox), test->button, FALSE, TRUE, 0);
-
- test->check = gtk_check_button_new_with_label ("Sensitive?");
- gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (test->check), TRUE);
- g_signal_connect (G_OBJECT (test->check),
- "toggled", G_CALLBACK (on_check_toggled), test->button);
- gtk_widget_set_name (test->check, "C");
- gtk_box_pack_start (GTK_BOX (vbox), test->check, FALSE, TRUE, 0);
-
- gtk_widget_show_all (test->window);
-
- gtk_window_move (GTK_WINDOW (test->window), 0, 0);
-
- sleep_in_main_loop (0.5);
-}
-
-static void
-sensitivity_teardown (CrossingTest *test,
- gconstpointer user_data)
-{
- stop_events (test);
- gtk_widget_destroy (test->window);
-
- if (test->queue != NULL)
- {
- g_queue_clear (test->queue);
- test->queue = NULL;
- }
-}
-
-void
-start_events (CrossingTest *test)
-{
- if (!test->events_connected)
- {
- g_object_connect (G_OBJECT (test->window),
- "signal::destroy", gtk_main_quit, NULL,
- "signal::enter-notify-event", on_enter, test,
- "signal::leave-notify-event", on_leave, test,
- NULL);
- g_object_connect (G_OBJECT (test->eventbox),
- "signal::enter-notify-event", on_enter, test,
- "signal::leave-notify-event", on_leave, test,
- NULL);
- g_object_connect (G_OBJECT (test->button),
- "signal::enter-notify-event", on_enter, test,
- "signal::leave-notify-event", on_leave, test,
- NULL);
- g_object_connect (G_OBJECT (test->check),
- "signal::enter-notify-event", on_enter, test,
- "signal::leave-notify-event", on_leave, test,
- NULL);
- test->events_connected = TRUE;
- }
-
- sleep_in_main_loop (0.5);
-}
-
-void
-stop_events (CrossingTest *test)
-{
- if (test->events_connected)
- {
- g_object_disconnect (G_OBJECT (test->window),
- "any_signal", gtk_main_quit, NULL,
- "any_signal", on_enter, test,
- "any_signal", on_leave, test,
- NULL);
- g_object_disconnect (G_OBJECT (test->eventbox),
- "any_signal", on_enter, test,
- "any_signal", on_leave, test,
- NULL);
- g_object_disconnect (G_OBJECT (test->button),
- "any_signal", on_enter, test,
- "any_signal", on_leave, test,
- NULL);
- g_object_disconnect (G_OBJECT (test->check),
- "any_signal", G_CALLBACK (on_check_toggled), test->button,
- "any_signal", on_enter, test,
- "any_signal", on_leave, test,
- NULL);
- test->events_connected = FALSE;
- }
-}
-
-void
-move_cursor_away (CrossingTest *test)
-{
- gdk_display_warp_pointer (gtk_widget_get_display (test->window),
- gtk_widget_get_screen (test->window),
- 1000, -1000);
-
- sleep_in_main_loop (0.5);
-}
-
-void
-check_event (CrossingTest *test,
- const gchar *name,
- gboolean entered,
- gboolean synthesized,
- GdkCrossingMode mode,
- GdkNotifyType detail)
-{
- CrossingEventData *evt;
-
- g_assert (test->queue != NULL);
-
- evt = g_queue_pop_head (test->queue);
-
- g_assert (evt->entered == entered);
- g_assert (strcmp (evt->name, name) == 0);
- g_assert (evt->synthesized == synthesized);
- g_assert (evt->mode == mode);
-
- if (evt->detail != detail)
- g_print ("%s %s event, detail %d, expected detail %d\n",
- synthesized ? "synthesized" : "native",
- entered ? "enter" : "leave",
- evt->detail, detail);
-
- g_assert (evt->detail == detail);
-}
-
-/* Verify crossing events when moving into and out of a sensitive widget */
-static void
-cursor_on_sensitive (CrossingTest *test,
- gconstpointer user_data)
-{
- move_cursor_away (test);
-
- start_events (test);
-
- set_cursor (test->button);
-
- check_event (test,
- "W",
- TRUE,
- FALSE, /* native */
- GDK_CROSSING_NORMAL,
- GDK_NOTIFY_NONLINEAR_VIRTUAL);
-
- check_event (test,
- "E",
- TRUE,
- FALSE, /* native */
- GDK_CROSSING_NORMAL,
- GDK_NOTIFY_NONLINEAR_VIRTUAL);
-
- check_event (test,
- "B",
- TRUE,
- FALSE, /* native */
- GDK_CROSSING_NORMAL,
- GDK_NOTIFY_NONLINEAR);
-
- g_assert (g_queue_is_empty (test->queue));
-
- move_cursor_away (test);
-
- check_event (test,
- "B",
- FALSE,
- FALSE, /* native */
- GDK_CROSSING_NORMAL,
- GDK_NOTIFY_NONLINEAR);
-
- check_event (test,
- "E",
- FALSE,
- FALSE, /* native */
- GDK_CROSSING_NORMAL,
- GDK_NOTIFY_NONLINEAR_VIRTUAL);
-
- check_event (test,
- "W",
- FALSE,
- FALSE, /* native */
- GDK_CROSSING_NORMAL,
- GDK_NOTIFY_NONLINEAR_VIRTUAL);
-
- g_assert (g_queue_is_empty (test->queue));
-
- stop_events (test);
-}
-
-static void
-change_sensitive_to_insensitive (CrossingTest *test,
- gconstpointer user_data)
-{
- move_cursor_away (test);
- set_cursor (test->button);
-
- start_events (test);
-
- gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (test->check), FALSE);
-
- check_event (test,
- "B",
- FALSE,
- TRUE, /* synthesized */
- GDK_CROSSING_STATE_CHANGED,
- GDK_NOTIFY_ANCESTOR);
-
- check_event (test,
- "E",
- FALSE,
- TRUE, /* synthesized */
- GDK_CROSSING_STATE_CHANGED,
- GDK_NOTIFY_VIRTUAL);
-
- check_event (test,
- "W",
- FALSE,
- TRUE, /* synthesized */
- GDK_CROSSING_STATE_CHANGED,
- GDK_NOTIFY_VIRTUAL);
-
- g_assert (g_queue_is_empty (test->queue));
-
- stop_events (test);
-}
-
-static void
-change_insensitive_to_sensitive (CrossingTest *test,
- gconstpointer user_data)
-{
- move_cursor_away (test);
- set_cursor (test->button);
- gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (test->check), FALSE);
-
- start_events (test);
-
- gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (test->check), TRUE);
-
- check_event (test,
- "W",
- TRUE,
- TRUE, /* synthesized */
- GDK_CROSSING_STATE_CHANGED,
- GDK_NOTIFY_VIRTUAL);
-
- check_event (test,
- "E",
- TRUE,
- TRUE, /* synthesized */
- GDK_CROSSING_STATE_CHANGED,
- GDK_NOTIFY_VIRTUAL);
-
- check_event (test,
- "B",
- TRUE,
- TRUE, /* synthesized */
- GDK_CROSSING_STATE_CHANGED,
- GDK_NOTIFY_ANCESTOR);
-
- g_assert (g_queue_is_empty (test->queue));
-
- stop_events (test);
-}
-
-static void
-cursor_from_insensitive_to_sensitive (CrossingTest *test,
- gconstpointer user_data)
-{
- set_cursor (test->button);
- gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (test->check), FALSE);
-
- start_events (test);
-
- set_cursor (test->check);
-
- check_event (test,
- "C",
- TRUE,
- FALSE, /* native */
- GDK_CROSSING_NORMAL,
- GDK_NOTIFY_NONLINEAR);
-
- g_assert (g_queue_is_empty (test->queue));
-
- stop_events (test);
-}
-
-static void
-cursor_from_sensitive_to_insensitive (CrossingTest *test,
- gconstpointer user_data)
-{
- set_cursor (test->check);
- gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (test->check), FALSE);
-
- start_events (test);
-
- set_cursor (test->button);
-
- check_event (test,
- "C",
- FALSE,
- FALSE, /* native */
- GDK_CROSSING_NORMAL,
- GDK_NOTIFY_NONLINEAR);
-
- g_assert (g_queue_is_empty (test->queue));
-
- stop_events (test);
-}
-
-static void
-add_gtk_grab (CrossingTest *test,
- gconstpointer user_data)
-{
- set_cursor (test->button);
-
- start_events (test);
-
- gtk_grab_add (test->check);
-
- check_event (test,
- "B",
- FALSE,
- TRUE, /* synthesized */
- GDK_CROSSING_GTK_GRAB,
- GDK_NOTIFY_ANCESTOR);
-
- check_event (test,
- "E",
- FALSE,
- TRUE, /* synthesized */
- GDK_CROSSING_GTK_GRAB,
- GDK_NOTIFY_ANCESTOR);
-
- check_event (test,
- "W",
- FALSE,
- TRUE, /* synthesized */
- GDK_CROSSING_GTK_GRAB,
- GDK_NOTIFY_ANCESTOR);
-
- g_assert (g_queue_is_empty (test->queue));
-
- stop_events (test);
-}
-
-static void
-remove_gtk_grab (CrossingTest *test,
- gconstpointer user_data)
-{
- set_cursor (test->button);
-
- gtk_grab_add (test->check);
-
- start_events (test);
-
- gtk_grab_remove (test->check);
-
- check_event (test,
- "B",
- TRUE,
- TRUE, /* synthesized */
- GDK_CROSSING_GTK_UNGRAB,
- GDK_NOTIFY_ANCESTOR);
-
- check_event (test,
- "E",
- TRUE,
- TRUE, /* synthesized */
- GDK_CROSSING_GTK_UNGRAB,
- GDK_NOTIFY_ANCESTOR);
-
- check_event (test,
- "W",
- TRUE,
- TRUE, /* synthesized */
- GDK_CROSSING_GTK_UNGRAB,
- GDK_NOTIFY_ANCESTOR);
-
- g_assert (g_queue_is_empty (test->queue));
-
- stop_events (test);
-}
-
-static void
-cursor_from_shadowed_to_unshadowed (CrossingTest *test,
- gconstpointer user_data)
-{
- set_cursor (test->button);
-
- gtk_grab_add (test->check);
-
- start_events (test);
-
- set_cursor (test->check);
-
- check_event (test,
- "C",
- FALSE,
- FALSE, /* native */
- GDK_CROSSING_NORMAL,
- GDK_NOTIFY_NONLINEAR);
-
- check_event (test,
- "C",
- TRUE,
- FALSE, /* native */
- GDK_CROSSING_NORMAL,
- GDK_NOTIFY_NONLINEAR);
-
- g_assert (g_queue_is_empty (test->queue));
-
- stop_events (test);
-}
-
-static void
-cursor_from_unshadowed_to_shadowed (CrossingTest *test,
- gconstpointer user_data)
-{
- set_cursor (test->check);
-
- gtk_grab_add (test->check);
-
- start_events (test);
-
- set_cursor (test->button);
-
- check_event (test,
- "C",
- FALSE,
- FALSE, /* native */
- GDK_CROSSING_NORMAL,
- GDK_NOTIFY_NONLINEAR);
-
- check_event (test,
- "C",
- TRUE,
- FALSE, /* native */
- GDK_CROSSING_NORMAL,
- GDK_NOTIFY_NONLINEAR);
-
- g_assert (g_queue_is_empty (test->queue));
-
- stop_events (test);
-}
-
-int
-main (int argc,
- char **argv)
-{
- gtk_test_init (&argc, &argv, NULL);
-
- g_test_add ("/crossings/cursor-on-sensitive", CrossingTest, NULL,
- sensitivity_setup, cursor_on_sensitive, sensitivity_teardown);
-
- g_test_add ("/crossings/change-sensitive-to-insensitive", CrossingTest, NULL,
- sensitivity_setup, change_sensitive_to_insensitive, sensitivity_teardown);
-
- g_test_add ("/crossings/cursor-from-insensitive-to-sensitive", CrossingTest, NULL,
- sensitivity_setup, cursor_from_insensitive_to_sensitive, sensitivity_teardown);
-
- g_test_add ("/crossings/cursor-from-sensitive-to-insensitive", CrossingTest, NULL,
- sensitivity_setup, cursor_from_sensitive_to_insensitive, sensitivity_teardown);
-
- g_test_add ("/crossings/change-insensitive-to-sensitive", CrossingTest, NULL,
- sensitivity_setup, change_insensitive_to_sensitive, sensitivity_teardown);
-
- g_test_add ("/crossings/add-gtk-grab", CrossingTest, NULL,
- sensitivity_setup, add_gtk_grab, sensitivity_teardown);
-
- g_test_add ("/crossings/remove-gtk-grab", CrossingTest, NULL,
- sensitivity_setup, remove_gtk_grab, sensitivity_teardown);
-
- g_test_add ("/crossings/cursor-from-shadowed-to-unshadowed", CrossingTest, NULL,
- sensitivity_setup, cursor_from_shadowed_to_unshadowed, sensitivity_teardown);
-
- g_test_add ("/crossings/cursor-from-unshadowed-to-shadowed", CrossingTest, NULL,
- sensitivity_setup, cursor_from_unshadowed_to_shadowed, sensitivity_teardown);
-
- return g_test_run ();
-}
diff --git a/testsuite/gtk/expander.c b/testsuite/gtk/expander.c
deleted file mode 100644
index fc49bc0e76..0000000000
--- a/testsuite/gtk/expander.c
+++ /dev/null
@@ -1,109 +0,0 @@
-/* GTK - The GIMP Toolkit
- * Copyright (C) 1995-1997 Peter Mattis, Spencer Kimball and Josh MacDonald
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 2 of the License, or (at your option) any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/*
- * Modified by the GTK+ Team and others 1997-2001. See the AUTHORS
- * file for a list of people on the GTK+ Team. See the ChangeLog
- * files for a list of changes. These files are distributed with
- * GTK+ at ftp://ftp.gtk.org/pub/gtk/.
- */
-#include <gtk/gtk.h>
-
-#ifdef GDK_WINDOWING_X11
-#include <gdk/gdkx.h>
-#endif
-
-static void
-test_click_expander (void)
-{
- GtkWidget *window = gtk_test_create_simple_window ("Test Window", "Test click on expander");
- GtkWidget *expander = gtk_expander_new ("Test Expander");
- GtkWidget *label = gtk_label_new ("Test Label");
- gboolean expanded;
- gboolean simsuccess;
- gtk_container_add (GTK_CONTAINER (expander), label);
- gtk_container_add (GTK_CONTAINER (gtk_bin_get_child (GTK_BIN (window))), expander);
- gtk_widget_show (expander);
- gtk_widget_show (label);
- gtk_widget_show_now (window);
- /* check initial expander state */
- expanded = gtk_expander_get_expanded (GTK_EXPANDER (expander));
- g_assert (!expanded);
- /* check expanding */
- simsuccess = gtk_test_widget_click (expander, 1, 0);
- g_assert (simsuccess == TRUE);
-
- gtk_test_widget_wait_for_draw (expander);
-
- expanded = gtk_expander_get_expanded (GTK_EXPANDER (expander));
- g_assert (expanded);
- /* check collapsing */
- simsuccess = gtk_test_widget_click (expander, 1, 0);
- g_assert (simsuccess == TRUE);
-
- gtk_test_widget_wait_for_draw (expander);
-
- expanded = gtk_expander_get_expanded (GTK_EXPANDER (expander));
- g_assert (!expanded);
-}
-
-static void
-test_click_content_widget (void)
-{
- GtkWidget *window = gtk_test_create_simple_window ("Test Window", "Test click on content widget");
- GtkWidget *expander = gtk_expander_new ("Test Expander");
- GtkWidget *entry = gtk_entry_new ();
- gboolean expanded;
- gboolean simsuccess;
-
- gtk_container_add (GTK_CONTAINER (expander), entry);
- gtk_container_add (GTK_CONTAINER (gtk_bin_get_child (GTK_BIN (window))), expander);
- gtk_expander_set_expanded (GTK_EXPANDER (expander), TRUE);
- gtk_widget_show (expander);
- gtk_widget_show (entry);
- gtk_widget_show_now (window);
-
- /* check click on content with expander open */
- expanded = gtk_expander_get_expanded (GTK_EXPANDER (expander));
- g_assert (expanded);
- simsuccess = gtk_test_widget_click (entry, 1, 0);
- g_assert (simsuccess == TRUE);
-
- gtk_test_widget_wait_for_draw (expander);
-
- expanded = gtk_expander_get_expanded (GTK_EXPANDER (expander));
- g_assert (expanded);
-}
-
-int
-main (int argc,
- char *argv[])
-{
- gtk_test_init (&argc, &argv);
-
-#ifdef GDK_WINDOWING_X11
- if (GDK_IS_X11_DISPLAY (gdk_display_get_default ())) ;
- return 0; /* gtk_test functions don't work well elsewhere */
-#else
- return 0;
-#endif
-
- g_test_add_func ("/expander/click-expander", test_click_expander);
- g_test_add_func ("/expander/click-content-widget", test_click_content_widget);
-
- return g_test_run();
-}
diff --git a/testsuite/gtk/filechooser.c b/testsuite/gtk/filechooser.c
deleted file mode 100644
index 5846bac0ce..0000000000
--- a/testsuite/gtk/filechooser.c
+++ /dev/null
@@ -1,2487 +0,0 @@
-/* GTK - The GIMP Toolkit
- * autotestfilechooser.c: Automated unit tests for the GtkFileChooser widget
- * Copyright (C) 2005, Novell, Inc.
- *
- * Authors:
- * Federico Mena-Quintero <federico@novell.com>
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 2 of the License, or (at your option) any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/* TODO:
- *
- * - In test_reload_sequence(), test that the selection is preserved properly
- * between unmap/map.
- *
- * - More tests!
- */
-
-#define SLEEP_DURATION 100
-
-#include "config.h"
-#include <string.h>
-#include <glib/gprintf.h>
-#include <gtk/gtk.h>
-#include "gtk/gtkfilechooserdefault.h"
-#include "gtk/gtkfilechooserentry.h"
-
-#if 0
-static const char *
-get_action_name (GtkFileChooserAction action)
-{
- switch (action)
- {
- case GTK_FILE_CHOOSER_ACTION_OPEN: return "OPEN";
- case GTK_FILE_CHOOSER_ACTION_SAVE: return "SAVE";
- case GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER: return "SELECT_FOLDER";
- case GTK_FILE_CHOOSER_ACTION_CREATE_FOLDER: return "CREATE_FOLDER";
-
- default:
- g_assert_not_reached ();
- return NULL;
- }
-}
-#endif
-
-#ifdef BROKEN_TESTS
-static void
-log_test (gboolean passed, const char *test_name, ...)
-{
- va_list args;
- char *str;
-
- va_start (args, test_name);
- str = g_strdup_vprintf (test_name, args);
- va_end (args);
-
- if (g_test_verbose())
- g_printf ("%s: %s\n", passed ? "PASSED" : "FAILED", str);
- g_free (str);
-}
-
-typedef void (* SetFilenameFn) (GtkFileChooser *chooser, gpointer data);
-typedef void (* CompareFilenameFn) (GtkFileChooser *chooser, gpointer data);
-
-struct test_set_filename_closure {
- GtkWidget *chooser;
- GtkWidget *accept_button;
- gboolean focus_button;
-};
-
-static gboolean
-set_filename_timeout_cb (gpointer data)
-{
- struct test_set_filename_closure *closure;
-
- closure = data;
-
- if (closure->focus_button)
- gtk_widget_grab_focus (closure->accept_button);
-
- gtk_button_clicked (GTK_BUTTON (closure->accept_button));
-
- return FALSE;
-}
-#endif
-
-
-static guint wait_for_idle_id = 0;
-
-static gboolean
-wait_for_idle_idle (gpointer data)
-{
- wait_for_idle_id = 0;
-
- return G_SOURCE_REMOVE;
-}
-
-static void
-wait_for_idle (void)
-{
- wait_for_idle_id = g_idle_add_full (G_PRIORITY_LOW + 100,
- wait_for_idle_idle,
- NULL, NULL);
-
- while (wait_for_idle_id)
- gtk_main_iteration ();
-}
-
-#ifdef BROKEN_TESTS
-static void
-test_set_filename (GtkFileChooserAction action,
- gboolean focus_button,
- SetFilenameFn set_filename_fn,const
- CompareFilenameFn compare_filename_fn,
- gpointer data)
-{
- GtkWidget *chooser;
- struct test_set_filename_closure closure;
- guint timeout_id;
-
- chooser = gtk_file_chooser_dialog_new ("hello", NULL, action,
- _("_Cancel"), GTK_RESPONSE_CANCEL,
- NULL);
-
- closure.chooser = chooser;
- closure.accept_button = gtk_dialog_add_button (GTK_DIALOG (chooser), _("_OK"), GTK_RESPONSE_ACCEPT);
- closure.focus_button = focus_button;
-
- gtk_dialog_set_default_response (GTK_DIALOG (chooser), GTK_RESPONSE_ACCEPT);
-
- (* set_filename_fn) (GTK_FILE_CHOOSER (chooser), data);
-
- timeout_id = gdk_threads_add_timeout_full (G_MAXINT, SLEEP_DURATION, set_filename_timeout_cb, &closure, NULL);
- gtk_dialog_run (GTK_DIALOG (chooser));
- g_source_remove (timeout_id);
-
- (* compare_filename_fn) (GTK_FILE_CHOOSER (chooser), data);
-
- gtk_widget_destroy (chooser);
-}
-
-static void
-set_filename_cb (GtkFileChooser *chooser, gpointer data)
-{
- const char *filename;
-
- filename = data;
- gtk_file_chooser_set_filename (chooser, filename);
-}
-
-static void
-compare_filename_cb (GtkFileChooser *chooser, gpointer data)
-{
- const char *filename;
- char *out_filename;
-
- filename = data;
- out_filename = gtk_file_chooser_get_filename (chooser);
-
- g_assert_cmpstr (out_filename, ==, filename);
-
- g_free (out_filename);
-}
-
-typedef struct
-{
- const char *test_name;
- GtkFileChooserAction action;
- const char *filename;
- gboolean focus_button;
-} TestSetFilenameSetup;
-
-static void
-test_black_box_set_filename (gconstpointer data)
-{
- const TestSetFilenameSetup *setup = data;
-
- test_set_filename (setup->action, setup->focus_button, set_filename_cb, compare_filename_cb, (char *) setup->filename);
-}
-
-struct current_name_closure {
- const char *path;
- const char *current_name;
-};
-
-static void
-set_current_name_cb (GtkFileChooser *chooser, gpointer data)
-{
- struct current_name_closure *closure;
-
- closure = data;
-
- gtk_file_chooser_set_current_folder (chooser, closure->path);
- gtk_file_chooser_set_current_name (chooser, closure->current_name);
-}
-
-static void
-compare_current_name_cb (GtkFileChooser *chooser, gpointer data)
-{
- struct current_name_closure *closure;
- char *out_filename;
- char *filename;
-
- closure = data;
-
- out_filename = gtk_file_chooser_get_filename (chooser);
-
- g_assert (out_filename != NULL);
-
- filename = g_build_filename (closure->path, closure->current_name, NULL);
- g_assert_cmpstr (filename, ==, out_filename);
-
- g_free (filename);
- g_free (out_filename);
-}
-
-typedef struct
-{
- const char *test_name;
- GtkFileChooserAction action;
- const char *current_name;
- gboolean focus_button;
-} TestSetCurrentNameSetup;
-
-static void
-test_black_box_set_current_name (gconstpointer data)
-{
- const TestSetCurrentNameSetup *setup = data;
- struct current_name_closure closure;
- char *cwd;
-
- cwd = g_get_current_dir ();
-
- closure.path = cwd;
- closure.current_name = setup->current_name;
-
- test_set_filename (setup->action, setup->focus_button, set_current_name_cb, compare_current_name_cb, &closure);
-
- g_free (cwd);
-}
-#endif
-
-/* FIXME: fails in CREATE_FOLDER mode when FOLDER_NAME == "/" */
-
-#if 0
-#define FILE_NAME "/nonexistent"
-#define FILE_NAME_2 "/nonexistent2"
-#define FOLDER_NAME "/etc"
-#define FOLDER_NAME_2 "/usr"
-#else
-#define FILE_NAME "/etc/passwd"
-#define FILE_NAME_2 "/etc/group"
-#define FOLDER_NAME "/etc"
-#define FOLDER_NAME_2 "/usr"
-#endif
-
-#define CURRENT_NAME "parangaricutirimicuaro.txt"
-#define CURRENT_NAME_FOLDER "parangaricutirimicuaro"
-
-/* https://bugzilla.novell.com/show_bug.cgi?id=184875
- * http://bugzilla.gnome.org/show_bug.cgi?id=347066
- * http://bugzilla.gnome.org/show_bug.cgi?id=346058
- */
-
-#ifdef BROKEN_TESTS
-static void
-setup_set_filename_tests (void)
-{
- static TestSetFilenameSetup tests[] =
- {
- { "/GtkFileChooser/black_box/set_filename/open/no_focus", GTK_FILE_CHOOSER_ACTION_OPEN, FILE_NAME, FALSE },
- { "/GtkFileChooser/black_box/set_filename/open/focus", GTK_FILE_CHOOSER_ACTION_OPEN, FILE_NAME, TRUE },
- { "/GtkFileChooser/black_box/set_filename/save/no_focus", GTK_FILE_CHOOSER_ACTION_SAVE, FILE_NAME, FALSE },
- { "/GtkFileChooser/black_box/set_filename/save/focus", GTK_FILE_CHOOSER_ACTION_SAVE, FILE_NAME, TRUE },
- { "/GtkFileChooser/black_box/set_filename/select_folder/no_focus", GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER, FOLDER_NAME,FALSE },
- { "/GtkFileChooser/black_box/set_filename/select_folder/focus", GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER, FOLDER_NAME,TRUE },
- { "/GtkFileChooser/black_box/set_filename/create_folder/no_focus", GTK_FILE_CHOOSER_ACTION_CREATE_FOLDER, FOLDER_NAME,FALSE },
- { "/GtkFileChooser/black_box/set_filename/create_folder/focus", GTK_FILE_CHOOSER_ACTION_CREATE_FOLDER, FOLDER_NAME,TRUE },
- };
- int i;
-
- for (i = 0; i < G_N_ELEMENTS (tests); i++)
- g_test_add_data_func (tests[i].test_name, &tests[i], test_black_box_set_filename);
-}
-
-static void
-setup_set_current_name_tests (void)
-{
- static TestSetCurrentNameSetup tests[] =
- {
- { "/GtkFileChooser/black_box/set_current_name/save/no_focus", GTK_FILE_CHOOSER_ACTION_SAVE, CURRENT_NAME, FALSE },
- { "/GtkFileChooser/black_box/set_current_name/save/focus", GTK_FILE_CHOOSER_ACTION_SAVE, CURRENT_NAME, TRUE },
- { "/GtkFileChooser/black_box/set_current_name/create_folder/no_focus", GTK_FILE_CHOOSER_ACTION_CREATE_FOLDER, CURRENT_NAME_FOLDER, FALSE },
- { "/GtkFileChooser/black_box/set_current_name/create_folder/focus", GTK_FILE_CHOOSER_ACTION_CREATE_FOLDER, CURRENT_NAME_FOLDER, TRUE },
- };
- int i;
-
- for (i = 0; i < G_N_ELEMENTS (tests); i++)
- g_test_add_data_func (tests[i].test_name, &tests[i], test_black_box_set_current_name);
-}
-#endif
-
-typedef struct
-{
- const char *shortname;
- GtkFileChooserAction action;
- const char *initial_current_folder;
- const char *initial_filename;
- gboolean open_dialog;
- enum {
- BUTTON,
- DIALOG
- } what_to_tweak;
- const char *tweak_current_folder;
- const char *tweak_filename;
- gint dialog_response;
- gboolean unselect_all;
- const char *final_current_folder;
- const char *final_filename;
-} FileChooserButtonTest;
-
-static char *
-make_button_test_name (FileChooserButtonTest *t)
-{
- return g_strdup_printf ("/GtkFileChooserButton/%s", t->shortname);
-#if 0
- GString *s = g_string_new ("/GtkFileChooserButton");
-
- g_string_append_printf (s, "/%s/%s/%s/%s",
- get_action_name (t->action),
- t->initial_current_folder ? "set_initial_folder" : "no_default_folder",
- t->initial_filename ? "set_initial_filename" : "no_initial_filename",
- t->open_dialog ? "open_dialog" : "no_dialog");
-
- if (t->tweak_current_folder)
- g_string_append (s, "/tweak_current_folder");
-
- if (t->tweak_filename)
- g_string_append (s, "/tweak_filename");
-
- if (t->open_dialog)
- g_string_append_printf (s, "/%s",
- t->dialog_response == GTK_RESPONSE_ACCEPT ? "accept" : "cancel");
-
- if (t->final_current_folder)
- g_string_append (s, "/final_current_folder");
-
- if (t->final_filename)
- g_string_append (s, "/final_filename");
-
- return g_string_free (s, FALSE);
-#endif
-}
-
-static gboolean
-sleep_timeout_cb (gpointer data)
-{
- gtk_main_quit ();
- return FALSE;
-}
-
-static void
-sleep_in_main_loop (void)
-{
- guint timeout_id;
-
- timeout_id = gdk_threads_add_timeout_full (G_MAXINT, 250, sleep_timeout_cb, NULL, NULL);
- gtk_main ();
- g_source_remove (timeout_id);
-}
-
-static void
-build_children_list (GtkWidget *widget, gpointer data)
-{
- GList **list;
-
- list = data;
- *list = g_list_prepend (*list, widget);
-}
-
-static GtkWidget *
-find_child_widget_with_atk_role (GtkWidget *widget, AtkRole role)
-{
- AtkObject *accessible;
- AtkRole a_role;
-
- accessible = gtk_widget_get_accessible (widget);
- a_role = atk_object_get_role (accessible);
-
- if (a_role == role)
- return widget;
- else
- {
- GtkWidget *found_child;
-
- found_child = NULL;
-
- if (GTK_IS_CONTAINER (widget))
- {
- GList *children;
- GList *l;
-
- children = NULL;
- gtk_container_forall (GTK_CONTAINER (widget), build_children_list, &children);
-
- l = children;
-
- while (l && !found_child)
- {
- GtkWidget *child;
-
- child = GTK_WIDGET (l->data);
-
- found_child = find_child_widget_with_atk_role (child, role);
-
- l = l->next;
- }
-
- g_list_free (children);
- }
-
- return found_child;
- }
-}
-
-static const char *
-get_atk_name_for_filechooser_button (GtkFileChooserButton *button)
-{
- GtkFileChooserAction action;
- GtkWidget *widget;
- AtkObject *accessible;
-
- action = gtk_file_chooser_get_action (GTK_FILE_CHOOSER (button));
- g_assert (action == GTK_FILE_CHOOSER_ACTION_OPEN || action == GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER);
-
- if (action == GTK_FILE_CHOOSER_ACTION_OPEN)
- widget = find_child_widget_with_atk_role (GTK_WIDGET (button), ATK_ROLE_PUSH_BUTTON);
- else
- widget = find_child_widget_with_atk_role (GTK_WIDGET (button), ATK_ROLE_COMBO_BOX);
-
- accessible = gtk_widget_get_accessible (widget);
- return atk_object_get_name (accessible);
-}
-
-static void
-check_that_basename_is_shown (GtkFileChooserButton *button, const char *expected_filename)
-{
- GtkFileChooserAction action;
- const char *name_on_button;
- char *expected_basename;
-
- name_on_button = get_atk_name_for_filechooser_button (button);
-
- action = gtk_file_chooser_get_action (GTK_FILE_CHOOSER (button));
- g_assert (action == GTK_FILE_CHOOSER_ACTION_OPEN || action == GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER);
-
- if (expected_filename)
- expected_basename = g_path_get_basename (expected_filename);
- else
- expected_basename = NULL;
-
- if (expected_basename)
- g_assert_cmpstr (expected_basename, ==, name_on_button);
- else
- g_assert_cmpstr (name_on_button, ==, "(None)"); /* see gtkfilechooserbutton.c:FALLBACK_DISPLAY_NAME */ /* FIXME: how do we translate this? */
-
- g_free (expected_basename);
-}
-
-static const char *
-get_expected_shown_filename (GtkFileChooserAction action, const char *folder_name, const char *filename)
-{
- if (action == GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER)
- {
- if (filename)
- return filename;
- else
- return folder_name;
- }
- else
- return filename;
-}
-
-static GtkWidget *
-get_file_chooser_dialog_from_button (GtkFileChooserButton *button)
-{
- GtkWidget *fc_dialog;
-
- /* Give me the internal dialog, damnit */
- fc_dialog = g_object_get_qdata (G_OBJECT (button), g_quark_from_static_string ("gtk-file-chooser-delegate"));
- g_assert (GTK_IS_FILE_CHOOSER (fc_dialog));
- g_assert (GTK_IS_DIALOG (fc_dialog));
-
- return fc_dialog;
-}
-
-typedef struct {
- GtkWidget *window;
- GtkWidget *fc_button;
-} WindowAndButton;
-
-static WindowAndButton
-create_window_and_file_chooser_button (GtkFileChooserAction action)
-{
- WindowAndButton w;
-
- w.window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
-
- w.fc_button = gtk_file_chooser_button_new (action == GTK_FILE_CHOOSER_ACTION_OPEN ? "Select a file" : "Select a folder",
- action);
- gtk_container_add (GTK_CONTAINER (w.window), w.fc_button);
-
- return w;
-}
-
-typedef struct
-{
- GObject *object;
- GHashTable *signals;
- gboolean in_main_loop;
-} SignalWatcher;
-
-typedef struct
-{
- SignalWatcher *watcher;
- char *signal_name;
- gulong id;
- gboolean emitted;
-} SignalConnection;
-
-static SignalWatcher *
-signal_watcher_new (GObject *object)
-{
- SignalWatcher *watcher = g_new0 (SignalWatcher, 1);
-
- watcher->object = g_object_ref (object);
- watcher->signals = g_hash_table_new (g_str_hash, g_str_equal);
-
- return watcher;
-}
-
-static void
-dummy_callback (GObject *object)
-{
- /* nothing */
-}
-
-static void
-marshal_notify_cb (gpointer data, GClosure *closure)
-{
- if (data)
- {
- SignalConnection *conn;
-
- conn = data;
- conn->emitted = TRUE;
-
- if (conn->watcher->in_main_loop)
- {
- gtk_main_quit ();
- conn->watcher->in_main_loop = FALSE;
- }
- }
-}
-
-static void
-signal_watcher_watch_signal (SignalWatcher *watcher, const char *signal_name)
-{
- SignalConnection *conn;
-
- conn = g_hash_table_lookup (watcher->signals, signal_name);
- if (!conn)
- {
- GClosure *closure;
-
- conn = g_new0 (SignalConnection, 1);
- conn->watcher = watcher;
- conn->signal_name = g_strdup (signal_name);
-
- closure = g_cclosure_new (G_CALLBACK (dummy_callback), NULL, NULL);
- g_closure_add_marshal_guards (closure, conn, marshal_notify_cb, NULL, marshal_notify_cb);
- conn->id = g_signal_connect_closure (watcher->object, signal_name, closure, FALSE);
- conn->emitted = FALSE;
-
- g_hash_table_insert (watcher->signals, conn->signal_name, conn);
- }
- else
- conn->emitted = FALSE;
-}
-
-static gboolean
-signal_watcher_expect (SignalWatcher *watcher, const char *signal_name, char *unused_description)
-{
- SignalConnection *conn;
- gboolean emitted;
-
- conn = g_hash_table_lookup (watcher->signals, signal_name);
- g_assert (conn != NULL);
-
- if (!conn->emitted)
- {
- guint timeout_id;
-
- timeout_id = gdk_threads_add_timeout_full (G_MAXINT, 1000, sleep_timeout_cb, NULL, NULL);
-
- watcher->in_main_loop = TRUE;
- gtk_main ();
- watcher->in_main_loop = FALSE;
-
- g_source_remove (timeout_id);
- }
-
- emitted = conn->emitted;
- conn->emitted = FALSE;
-
- return emitted;
-}
-
-static void
-destroy_connection (gpointer key, gpointer value, gpointer user_data)
-{
- SignalConnection *conn;
-
- conn = value;
- g_signal_handler_disconnect (conn->watcher->object, conn->id);
- g_free (conn->signal_name);
- g_free (conn);
-}
-
-static void
-signal_watcher_destroy (SignalWatcher *watcher)
-{
- g_hash_table_foreach (watcher->signals, destroy_connection, NULL);
- g_hash_table_destroy (watcher->signals);
- g_object_unref (watcher->object);
- g_free (watcher);
-}
-
-static void
-test_file_chooser_button_with_response (const FileChooserButtonTest *setup, gint dialog_response)
-{
- WindowAndButton w;
- SignalWatcher *watcher;
- GtkWidget *fc_dialog = NULL;
- int iterations;
- int i;
-
- w = create_window_and_file_chooser_button (setup->action);
-
- watcher = signal_watcher_new (G_OBJECT (w.fc_button));
- signal_watcher_watch_signal (watcher, "current-folder-changed");
- signal_watcher_watch_signal (watcher, "selection-changed");
-
- if (setup->initial_current_folder)
- gtk_file_chooser_set_current_folder (GTK_FILE_CHOOSER (w.fc_button), setup->initial_current_folder);
-
- if (setup->initial_filename)
- gtk_file_chooser_select_filename (GTK_FILE_CHOOSER (w.fc_button), setup->initial_filename);
-
- gtk_widget_show_all (w.window);
- wait_for_idle ();
-
- if (setup->initial_current_folder)
- g_assert (signal_watcher_expect (watcher, "current-folder-changed", "initial current folder"));
-
- if (setup->initial_filename)
- g_assert (signal_watcher_expect (watcher, "selection-changed", "initial filename"));
-
- check_that_basename_is_shown (GTK_FILE_CHOOSER_BUTTON (w.fc_button),
- get_expected_shown_filename (setup->action, setup->initial_current_folder, setup->initial_filename));
-
- /* If there is a dialog to be opened, we actually test going through it a
- * couple of times. This ensures that any state that the button frobs for
- * each appearance of the dialog will make sense.
- */
- if (setup->open_dialog)
- iterations = 2;
- else
- iterations = 1;
-
- for (i = 0; i < iterations; i++)
- {
- GtkFileChooser *chooser_to_tweak;
-
- if (setup->open_dialog)
- {
- GList *children;
-
- /* Hack our way into the file chooser button; get its GtkButton child and click it */
- children = gtk_container_get_children (GTK_CONTAINER (w.fc_button));
- g_assert (children && GTK_IS_BUTTON (children->data));
- gtk_button_clicked (GTK_BUTTON (children->data));
- g_list_free (children);
-
- wait_for_idle ();
-
- fc_dialog = get_file_chooser_dialog_from_button (GTK_FILE_CHOOSER_BUTTON (w.fc_button));
- }
-
- if (setup->what_to_tweak == BUTTON)
- chooser_to_tweak = GTK_FILE_CHOOSER (w.fc_button);
- else if (setup->what_to_tweak == DIALOG)
- chooser_to_tweak = GTK_FILE_CHOOSER (fc_dialog);
- else
- g_assert_not_reached ();
-
- /* Okay, now frob the button or its optional dialog */
-
- if (setup->tweak_current_folder)
- {
- if (setup->what_to_tweak == BUTTON)
- signal_watcher_watch_signal (watcher, "current-folder-changed");
-
- gtk_file_chooser_set_current_folder (chooser_to_tweak, setup->tweak_current_folder);
-
- if (setup->what_to_tweak == BUTTON)
- g_assert (signal_watcher_expect (watcher, "current-folder-changed", "tweak current folder in button"));
- }
-
- if (setup->tweak_filename)
- {
- if (setup->what_to_tweak == BUTTON)
- signal_watcher_watch_signal (watcher, "selection-changed");
-
- gtk_file_chooser_select_filename (chooser_to_tweak, setup->tweak_filename);
-
- if (setup->what_to_tweak == BUTTON)
- g_assert (signal_watcher_expect (watcher, "selection-changed", "tweak filename in button"));
- }
-
- if (setup->unselect_all)
- {
- if (setup->what_to_tweak == BUTTON)
- signal_watcher_watch_signal (watcher, "selection-changed");
-
- gtk_file_chooser_unselect_all (chooser_to_tweak);
-
- if (setup->what_to_tweak == BUTTON)
- g_assert (signal_watcher_expect (watcher, "selection-changed", "tweak unselect_all in button"));
- }
-
- wait_for_idle ();
-
- if (setup->open_dialog)
- {
- gtk_dialog_response (GTK_DIALOG (fc_dialog), dialog_response);
- wait_for_idle ();
-
- gtk_window_resize (GTK_WINDOW (fc_dialog), 500, 500);
- }
-
- if (setup->final_current_folder)
- {
- char *folder = gtk_file_chooser_get_current_folder (GTK_FILE_CHOOSER (w.fc_button));
-
- g_assert_cmpstr (folder, ==, setup->final_current_folder);
- g_free (folder);
- }
-
- if (setup->final_filename)
- {
- char *filename = gtk_file_chooser_get_filename (GTK_FILE_CHOOSER (w.fc_button));
-
- g_assert_cmpstr (filename, ==, setup->final_filename);
- g_free (filename);
- }
-
- check_that_basename_is_shown (GTK_FILE_CHOOSER_BUTTON (w.fc_button),
- get_expected_shown_filename (setup->action, setup->final_current_folder, setup->final_filename));
- }
-
- signal_watcher_destroy (watcher);
- gtk_widget_destroy (w.window);
-}
-
-static void
-test_file_chooser_button (gconstpointer data)
-{
- const FileChooserButtonTest *setup = data;
-
- test_file_chooser_button_with_response (setup, setup->dialog_response);
-
- if (setup->open_dialog && setup->dialog_response == GTK_RESPONSE_CANCEL)
- {
- /* Runs the test again, with DELETE_EVENT (as if the user closed the
- * dialog instead of using the Cancel button), since the button misbehaved
- * in that case sometimes.
- */
- test_file_chooser_button_with_response (setup, GTK_RESPONSE_DELETE_EVENT);
- }
-}
-
-static int
-find_accessible_action_num (AtkObject *object, const char *action_name)
-{
- AtkAction *action_a;
- int num_actions;
- int i;
-
- action_a = ATK_ACTION (object);
-
- num_actions = atk_action_get_n_actions (action_a);
-
- for (i = 0; i < num_actions; i++)
- if (strcmp (atk_action_get_name (action_a, i), action_name) == 0)
- return i;
-
- return -1;
-}
-
-static void
-do_accessible_action (AtkObject *object, const char *action_name)
-{
- int action_num;
-
- action_num = find_accessible_action_num (object, action_name);
- g_assert (action_num != -1);
-
- atk_action_do_action (ATK_ACTION (object), action_num);
-}
-
-static void
-test_file_chooser_button_combo_box_1 (void)
-{
- WindowAndButton w;
- GtkWidget *combo_box;
- AtkObject *combo_box_a;
- AtkObject *menu_a;
- int num_items;
- int other_index;
- AtkObject *item_a;
- GtkWidget *fc_dialog;
-
- w = create_window_and_file_chooser_button (GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER);
-
- gtk_file_chooser_select_filename (GTK_FILE_CHOOSER (w.fc_button), FOLDER_NAME);
-
- gtk_widget_show_all (w.window);
-
- /* Get the accessible for the combo box */
-
- combo_box = find_child_widget_with_atk_role (GTK_WIDGET (w.fc_button), ATK_ROLE_COMBO_BOX);
- combo_box_a = gtk_widget_get_accessible (combo_box);
-
- /* Press the combo box to bring up the menu */
-
- do_accessible_action (combo_box_a, "press");
- sleep_in_main_loop (); /* have to wait because bringing up the menu is asynchronous... */
-
- /* Get the menu from the combo box; it's the first child */
-
- menu_a = atk_object_ref_accessible_child (combo_box_a, 0);
- g_assert (atk_object_get_role (menu_a) == ATK_ROLE_MENU);
-
- /* Check that the last item in the menu is the "Other…" one */
-
- num_items = atk_object_get_n_accessible_children (menu_a);
- g_assert (num_items > 0);
-
- other_index = num_items - 1;
-
- item_a = atk_object_ref_accessible_child (menu_a, other_index);
- g_assert_cmpstr (atk_object_get_name (item_a), ==, "Other…"); /* FIXME: how do we translate this? */
-
- /* Activate the item */
-
- do_accessible_action (item_a, "click");
-
- /* Cancel the dialog */
-
- sleep_in_main_loop ();
- fc_dialog = get_file_chooser_dialog_from_button (GTK_FILE_CHOOSER_BUTTON (w.fc_button));
-
- gtk_dialog_response (GTK_DIALOG (fc_dialog), GTK_RESPONSE_CANCEL);
-
- /* Now check the selection in the combo box */
- check_that_basename_is_shown (GTK_FILE_CHOOSER_BUTTON (w.fc_button), FOLDER_NAME);
-
- gtk_widget_destroy (w.window);
-}
-
-static void
-setup_file_chooser_button_combo_box_tests (void)
-{
- g_test_add_func ("/GtkFileChooserButton/combo_box-1", test_file_chooser_button_combo_box_1);
-}
-
-static FileChooserButtonTest button_tests[] =
- {
- /* OPEN tests without dialog */
-
- {
- "open-1",
- GTK_FILE_CHOOSER_ACTION_OPEN,
- NULL, /* initial_current_folder */
- NULL, /* initial_filename */
- FALSE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- NULL, /* tweak_filename */
- 0, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- NULL /* final_filename */
- },
- {
- "open-2",
- GTK_FILE_CHOOSER_ACTION_OPEN,
- NULL, /* initial_current_folder */
- FILE_NAME, /* initial_filename */
- FALSE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- NULL, /* tweak_filename */
- 0, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- FILE_NAME /* final_filename */
- },
- {
- "open-3",
- GTK_FILE_CHOOSER_ACTION_OPEN,
- NULL, /* initial_current_folder */
- NULL, /* initial_filename */
- FALSE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- FILE_NAME, /* tweak_filename */
- 0, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- FILE_NAME /* final_filename */
- },
- {
- "open-4",
- GTK_FILE_CHOOSER_ACTION_OPEN,
- NULL, /* initial_current_folder */
- FILE_NAME, /* initial_filename */
- FALSE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- FILE_NAME_2, /* tweak_filename */
- 0, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- FILE_NAME_2 /* final_filename */
- },
- {
- "open-5",
- GTK_FILE_CHOOSER_ACTION_OPEN,
- FOLDER_NAME, /* initial_current_folder */
- NULL, /* initial_filename */
- FALSE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- NULL, /* tweak_filename */
- 0, /* dialog_response */
- FALSE, /* unselect_all */
- FOLDER_NAME, /* final_current_folder */
- NULL /* final_filename */
- },
- {
- "open-6",
- GTK_FILE_CHOOSER_ACTION_OPEN,
- FOLDER_NAME, /* initial_current_folder */
- NULL, /* initial_filename */
- FALSE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- FOLDER_NAME_2, /* tweak_current_folder */
- NULL, /* tweak_filename */
- 0, /* dialog_response */
- FALSE, /* unselect_all */
- FOLDER_NAME_2, /* final_current_folder */
- NULL /* final_filename */
- },
-
- /* SELECT_FOLDER tests without dialog */
-
- {
- "select-folder-1",
- GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER,
- NULL, /* initial_current_folder */
- NULL, /* initial_filename */
- FALSE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- NULL, /* tweak_filename */
- 0, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- NULL /* final_filename */
- },
- {
- "select-folder-2",
- GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER,
- NULL, /* initial_current_folder */
- FOLDER_NAME, /* initial_filename */
- FALSE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- NULL, /* tweak_filename */
- 0, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- FOLDER_NAME /* final_filename */
- },
- {
- "select-folder-3",
- GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER,
- NULL, /* initial_current_folder */
- FOLDER_NAME, /* initial_filename */
- FALSE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- FOLDER_NAME_2, /* tweak_filename */
- 0, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- FOLDER_NAME_2 /* final_filename */
- },
- {
- "select-folder-4",
- GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER,
- FOLDER_NAME, /* initial_current_folder */
- NULL, /* initial_filename */
- FALSE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- NULL, /* tweak_filename */
- 0, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- FOLDER_NAME /* final_filename */
- },
- {
- "select-folder-5",
- GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER,
- FOLDER_NAME, /* initial_current_folder */
- NULL, /* initial_filename */
- FALSE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- NULL, /* tweak_filename */
- 0, /* dialog_response */
- FALSE, /* unselect_all */
- FOLDER_NAME, /* final_current_folder */
- NULL /* final_filename */
- },
- {
- "select-folder-6",
- GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER,
- FOLDER_NAME, /* initial_current_folder */
- NULL, /* initial_filename */
- FALSE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- FOLDER_NAME_2, /* tweak_current_folder */
- NULL, /* tweak_filename */
- 0, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- FOLDER_NAME_2 /* final_filename */
- },
- {
- "select-folder-7",
- GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER,
- FOLDER_NAME, /* initial_current_folder */
- NULL, /* initial_filename */
- FALSE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- FOLDER_NAME_2, /* tweak_current_folder */
- NULL, /* tweak_filename */
- 0, /* dialog_response */
- FALSE, /* unselect_all */
- FOLDER_NAME_2, /* final_current_folder */
- NULL /* final_filename */
- },
- {
- "select-folder-8",
- GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER,
- FOLDER_NAME, /* initial_current_folder */
- NULL, /* initial_filename */
- FALSE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- FOLDER_NAME_2, /* tweak_filename */
- 0, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- FOLDER_NAME_2 /* final_filename */
- },
-
- /* OPEN tests with dialog, cancelled
- *
- * Test names are "open-dialog-cancel-A-B", where A and B can be:
- *
- * A:
- * ni - no initial filename
- * i - initial filename
- * nf - no initial folder
- * f - initial folder
- *
- * B:
- * nt - no tweaks
- * b - tweak button
- * d - tweak dialog
- */
-
- {
- "open-dialog-cancel-ni-nt",
- GTK_FILE_CHOOSER_ACTION_OPEN,
- NULL, /* initial_current_folder */
- NULL, /* initial_filename */
- TRUE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- NULL, /* tweak_filename */
- GTK_RESPONSE_CANCEL, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- NULL /* final_filename */
- },
- {
- "open-dialog-cancel-ni-b",
- GTK_FILE_CHOOSER_ACTION_OPEN,
- NULL, /* initial_current_folder */
- NULL, /* initial_filename */
- TRUE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- FILE_NAME, /* tweak_filename */
- GTK_RESPONSE_CANCEL, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- FILE_NAME /* final_filename */
- },
- {
- "open-dialog-cancel-ni-d",
- GTK_FILE_CHOOSER_ACTION_OPEN,
- NULL, /* initial_current_folder */
- NULL, /* initial_filename */
- TRUE, /* open_dialog */
- DIALOG, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- FILE_NAME, /* tweak_filename */
- GTK_RESPONSE_CANCEL, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- NULL /* final_filename */
- },
- {
- "open-dialog-cancel-i-nt",
- GTK_FILE_CHOOSER_ACTION_OPEN,
- NULL, /* initial_current_folder */
- FILE_NAME, /* initial_filename */
- TRUE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- NULL, /* tweak_filename */
- GTK_RESPONSE_CANCEL, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- FILE_NAME /* final_filename */
- },
- {
- "open-dialog-cancel-i-b",
- GTK_FILE_CHOOSER_ACTION_OPEN,
- NULL, /* initial_current_folder */
- FILE_NAME, /* initial_filename */
- TRUE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- FILE_NAME_2, /* tweak_filename */
- GTK_RESPONSE_CANCEL, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- FILE_NAME_2 /* final_filename */
- },
- {
- "open-dialog-cancel-i-d",
- GTK_FILE_CHOOSER_ACTION_OPEN,
- NULL, /* initial_current_folder */
- FILE_NAME, /* initial_filename */
- TRUE, /* open_dialog */
- DIALOG, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- FILE_NAME_2, /* tweak_filename */
- GTK_RESPONSE_CANCEL, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- FILE_NAME /* final_filename */
- },
- {
- "open-dialog-cancel-nf-nt",
- GTK_FILE_CHOOSER_ACTION_OPEN,
- NULL, /* initial_current_folder */
- NULL, /* initial_filename */
- TRUE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- NULL, /* tweak_filename */
- GTK_RESPONSE_CANCEL, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- NULL /* final_filename */
- },
- {
- "open-dialog-cancel-nf-b",
- GTK_FILE_CHOOSER_ACTION_OPEN,
- NULL, /* initial_current_folder */
- NULL, /* initial_filename */
- TRUE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- FOLDER_NAME, /* tweak_current_folder */
- NULL, /* tweak_filename */
- GTK_RESPONSE_CANCEL, /* dialog_response */
- FALSE, /* unselect_all */
- FOLDER_NAME, /* final_current_folder */
- NULL /* final_filename */
- },
- {
- "open-dialog-cancel-nf-d",
- GTK_FILE_CHOOSER_ACTION_OPEN,
- NULL, /* initial_current_folder */
- NULL, /* initial_filename */
- TRUE, /* open_dialog */
- DIALOG, /* what_to_tweak */
- FOLDER_NAME, /* tweak_current_folder */
- NULL, /* tweak_filename */
- GTK_RESPONSE_CANCEL, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- NULL /* final_filename */
- },
- {
- "open-dialog-cancel-f-nt",
- GTK_FILE_CHOOSER_ACTION_OPEN,
- FOLDER_NAME, /* initial_current_folder */
- NULL, /* initial_filename */
- TRUE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- NULL, /* tweak_filename */
- GTK_RESPONSE_CANCEL, /* dialog_response */
- FALSE, /* unselect_all */
- FOLDER_NAME, /* final_current_folder */
- NULL /* final_filename */
- },
- {
- "open-dialog-cancel-f-b",
- GTK_FILE_CHOOSER_ACTION_OPEN,
- FOLDER_NAME, /* initial_current_folder */
- NULL, /* initial_filename */
- TRUE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- FOLDER_NAME_2, /* tweak_current_folder */
- NULL, /* tweak_filename */
- GTK_RESPONSE_CANCEL, /* dialog_response */
- FALSE, /* unselect_all */
- FOLDER_NAME_2, /* final_current_folder */
- NULL /* final_filename */
- },
- {
- "open-dialog-cancel-f-d",
- GTK_FILE_CHOOSER_ACTION_OPEN,
- FOLDER_NAME, /* initial_current_folder */
- NULL, /* initial_filename */
- TRUE, /* open_dialog */
- DIALOG, /* what_to_tweak */
- FOLDER_NAME_2, /* tweak_current_folder */
- NULL, /* tweak_filename */
- GTK_RESPONSE_CANCEL, /* dialog_response */
- FALSE, /* unselect_all */
- FOLDER_NAME, /* final_current_folder */
- NULL /* final_filename */
- },
-
- /* SELECT_FOLDER tests with dialog, cancelled */
-
- {
- "select-folder-dialog-cancel-ni-nt",
- GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER,
- NULL, /* initial_current_folder */
- NULL, /* initial_filename */
- TRUE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- NULL, /* tweak_filename */
- GTK_RESPONSE_CANCEL, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- NULL /* final_filename */
- },
- {
- "select-folder-dialog-cancel-ni-b",
- GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER,
- NULL, /* initial_current_folder */
- NULL, /* initial_filename */
- TRUE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- FOLDER_NAME, /* tweak_filename */
- GTK_RESPONSE_CANCEL, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- FOLDER_NAME /* final_filename */
- },
- {
- "select-folder-dialog-cancel-ni-d",
- GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER,
- NULL, /* initial_current_folder */
- NULL, /* initial_filename */
- TRUE, /* open_dialog */
- DIALOG, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- FOLDER_NAME, /* tweak_filename */
- GTK_RESPONSE_CANCEL, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- NULL /* final_filename */
- },
- {
- "select-folder-dialog-cancel-i-nt",
- GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER,
- NULL, /* initial_current_folder */
- FOLDER_NAME, /* initial_filename */
- TRUE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- NULL, /* tweak_filename */
- GTK_RESPONSE_CANCEL, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- FOLDER_NAME /* final_filename */
- },
- {
- "select-folder-dialog-cancel-i-b",
- GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER,
- NULL, /* initial_current_folder */
- FOLDER_NAME, /* initial_filename */
- TRUE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- FOLDER_NAME_2, /* tweak_filename */
- GTK_RESPONSE_CANCEL, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- FOLDER_NAME_2 /* final_filename */
- },
- {
- "select-folder-dialog-cancel-i-d",
- GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER,
- NULL, /* initial_current_folder */
- FOLDER_NAME, /* initial_filename */
- TRUE, /* open_dialog */
- DIALOG, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- FOLDER_NAME_2, /* tweak_filename */
- GTK_RESPONSE_CANCEL, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- FOLDER_NAME /* final_filename */
- },
- {
- "select-folder-dialog-cancel-nf-nt",
- GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER,
- NULL, /* initial_current_folder */
- NULL, /* initial_filename */
- TRUE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- NULL, /* tweak_filename */
- GTK_RESPONSE_CANCEL, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- NULL /* final_filename */
- },
- {
- "select-folder-dialog-cancel-nf-b",
- GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER,
- NULL, /* initial_current_folder */
- NULL, /* initial_filename */
- TRUE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- FOLDER_NAME, /* tweak_current_folder */
- NULL, /* tweak_filename */
- GTK_RESPONSE_CANCEL, /* dialog_response */
- FALSE, /* unselect_all */
- FOLDER_NAME, /* final_current_folder */
- NULL /* final_filename */
- },
- {
- "select-folder-dialog-cancel-nf-d",
- GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER,
- NULL, /* initial_current_folder */
- NULL, /* initial_filename */
- TRUE, /* open_dialog */
- DIALOG, /* what_to_tweak */
- FOLDER_NAME, /* tweak_current_folder */
- NULL, /* tweak_filename */
- GTK_RESPONSE_CANCEL, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- NULL /* final_filename */
- },
- {
- "select-folder-dialog-cancel-f-nt",
- GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER,
- FOLDER_NAME, /* initial_current_folder */
- NULL, /* initial_filename */
- TRUE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- NULL, /* tweak_filename */
- GTK_RESPONSE_CANCEL, /* dialog_response */
- FALSE, /* unselect_all */
- FOLDER_NAME, /* final_current_folder */
- NULL /* final_filename */
- },
- {
- "select-folder-dialog-cancel-f-nt-2",
- GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER,
- FOLDER_NAME, /* initial_current_folder */
- NULL, /* initial_filename */
- TRUE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- NULL, /* tweak_filename */
- GTK_RESPONSE_CANCEL, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- FOLDER_NAME /* final_filename */
- },
- {
- "select-folder-dialog-cancel-f-b",
- GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER,
- FOLDER_NAME, /* initial_current_folder */
- NULL, /* initial_filename */
- TRUE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- FOLDER_NAME_2, /* tweak_current_folder */
- NULL, /* tweak_filename */
- GTK_RESPONSE_CANCEL, /* dialog_response */
- FALSE, /* unselect_all */
- FOLDER_NAME_2, /* final_current_folder */
- NULL /* final_filename */
- },
- {
- "select-folder-dialog-cancel-f-b-2",
- GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER,
- FOLDER_NAME, /* initial_current_folder */
- NULL, /* initial_filename */
- TRUE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- FOLDER_NAME_2, /* tweak_filename */
- GTK_RESPONSE_CANCEL, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- FOLDER_NAME_2 /* final_filename */
- },
- {
- "select-folder-dialog-cancel-f-d",
- GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER,
- FOLDER_NAME, /* initial_current_folder */
- NULL, /* initial_filename */
- TRUE, /* open_dialog */
- DIALOG, /* what_to_tweak */
- FOLDER_NAME_2, /* tweak_current_folder */
- NULL, /* tweak_filename */
- GTK_RESPONSE_CANCEL, /* dialog_response */
- FALSE, /* unselect_all */
- FOLDER_NAME, /* final_current_folder */
- NULL /* final_filename */
- },
- {
- "select-folder-dialog-cancel-f-d-2",
- GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER,
- FOLDER_NAME, /* initial_current_folder */
- NULL, /* initial_filename */
- TRUE, /* open_dialog */
- DIALOG, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- FOLDER_NAME_2, /* tweak_filename */
- GTK_RESPONSE_CANCEL, /* dialog_response */
- FALSE, /* unselect_all */
- FOLDER_NAME, /* final_current_folder */
- NULL /* final_filename */
- },
-
- /* OPEN tests with dialog */
-
- {
- "open-dialog-1",
- GTK_FILE_CHOOSER_ACTION_OPEN,
- NULL, /* initial_current_folder */
- NULL, /* initial_filename */
- TRUE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- FILE_NAME, /* tweak_filename */
- GTK_RESPONSE_ACCEPT, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- FILE_NAME /* final_filename */
- },
- {
- "open-dialog-2",
- GTK_FILE_CHOOSER_ACTION_OPEN,
- NULL, /* initial_current_folder */
- FILE_NAME, /* initial_filename */
- TRUE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- NULL, /* tweak_filename */
- GTK_RESPONSE_ACCEPT, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- FILE_NAME /* final_filename */
- },
- {
- "open-dialog-3",
- GTK_FILE_CHOOSER_ACTION_OPEN,
- NULL, /* initial_current_folder */
- FILE_NAME, /* initial_filename */
- TRUE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- FILE_NAME_2, /* tweak_filename */
- GTK_RESPONSE_ACCEPT, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- FILE_NAME_2 /* final_filename */
- },
- {
- "open-dialog-4",
- GTK_FILE_CHOOSER_ACTION_OPEN,
- FOLDER_NAME, /* initial_current_folder */
- NULL, /* initial_filename */
- TRUE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- FILE_NAME, /* tweak_filename */
- GTK_RESPONSE_ACCEPT, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- FILE_NAME /* final_filename */
- },
-
- /* SELECT_FOLDER tests with dialog */
-
- {
- "select-folder-dialog-1",
- GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER,
- NULL, /* initial_current_folder */
- FOLDER_NAME, /* initial_filename */
- TRUE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- NULL, /* tweak_filename */
- GTK_RESPONSE_ACCEPT, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- FOLDER_NAME /* final_filename */
- },
- {
- "select-folder-dialog-2",
- GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER,
- FOLDER_NAME, /* initial_current_folder */
- NULL, /* initial_filename */
- TRUE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- NULL, /* tweak_filename */
- GTK_RESPONSE_ACCEPT, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- FOLDER_NAME /* final_filename */
- },
- {
- "select-folder-dialog-3",
- GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER,
- NULL, /* initial_current_folder */
- FOLDER_NAME, /* initial_filename */
- TRUE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- FOLDER_NAME_2, /* tweak_filename */
- GTK_RESPONSE_ACCEPT, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- FOLDER_NAME_2 /* final_filename */
- },
- {
- "select-folder-dialog-4",
- GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER,
- FOLDER_NAME, /* initial_current_folder */
- NULL, /* initial_filename */
- TRUE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- FOLDER_NAME_2, /* tweak_filename */
- GTK_RESPONSE_ACCEPT, /* dialog_response */
- FALSE, /* unselect_all */
- NULL, /* final_current_folder */
- FOLDER_NAME_2 /* final_filename */
- },
-
- /* Unselection tests */
- {
- "unselect-all-1",
- GTK_FILE_CHOOSER_ACTION_OPEN,
- NULL, /* initial_current_folder */
- NULL, /* initial_filename */
- FALSE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- NULL, /* tweak_filename */
- 0, /* dialog_response */
- TRUE, /* unselect_all */
- NULL, /* final_current_folder */
- NULL /* final_filename */
- },
- {
- "unselect-all-2",
- GTK_FILE_CHOOSER_ACTION_OPEN,
- NULL, /* initial_current_folder */
- FILE_NAME, /* initial_filename */
- FALSE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- NULL, /* tweak_filename */
- 0, /* dialog_response */
- TRUE, /* unselect_all */
- NULL, /* final_current_folder */
- NULL /* final_filename */
- },
- {
- "unselect-all-3",
- GTK_FILE_CHOOSER_ACTION_OPEN,
- NULL, /* initial_current_folder */
- FILE_NAME, /* initial_filename */
- FALSE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- FILE_NAME_2, /* tweak_filename */
- 0, /* dialog_response */
- TRUE, /* unselect_all */
- NULL, /* final_current_folder */
- NULL /* final_filename */
- },
- {
- "unselect-all-4",
- GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER,
- NULL, /* initial_current_folder */
- NULL, /* initial_filename */
- FALSE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- NULL, /* tweak_filename */
- 0, /* dialog_response */
- TRUE, /* unselect_all */
- NULL, /* final_current_folder */
- NULL /* final_filename */
- },
- {
- "unselect-all-5",
- GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER,
- NULL, /* initial_current_folder */
- FOLDER_NAME, /* initial_filename */
- FALSE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- NULL, /* tweak_filename */
- 0, /* dialog_response */
- TRUE, /* unselect_all */
- NULL, /* final_current_folder */
- NULL /* final_filename */
- },
- {
- "unselect-all-6",
- GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER,
- NULL, /* initial_current_folder */
- FOLDER_NAME, /* initial_filename */
- FALSE, /* open_dialog */
- BUTTON, /* what_to_tweak */
- NULL, /* tweak_current_folder */
- FOLDER_NAME_2, /* tweak_filename */
- 0, /* dialog_response */
- TRUE, /* unselect_all */
- NULL, /* final_current_folder */
- NULL /* final_filename */
- },
-
- };
-
-static void
-setup_file_chooser_button_tests (void)
-{
- int i;
-
- for (i = 0; i < G_N_ELEMENTS (button_tests); i++)
- {
- char *test_name;
-
- test_name = make_button_test_name (&button_tests[i]);
- g_test_add_data_func (test_name, &button_tests[i], test_file_chooser_button);
- g_free (test_name);
- }
-
- setup_file_chooser_button_combo_box_tests ();
-}
-
-#ifdef BROKEN_TESTS
-struct confirm_overwrite_closure {
- GtkWidget *chooser;
- GtkWidget *accept_button;
- gint confirm_overwrite_signal_emitted;
- gchar *extension;
-};
-
-static GtkFileChooserConfirmation
-confirm_overwrite_cb (GtkFileChooser *chooser, gpointer data)
-{
- struct confirm_overwrite_closure *closure = data;
-
- if (g_test_verbose())
- printf ("bling!\n");
- closure->confirm_overwrite_signal_emitted += 1;
-
- return GTK_FILE_CHOOSER_CONFIRMATION_ACCEPT_FILENAME;
-}
-
-static void
-overwrite_response_cb (GtkFileChooser *chooser, gint response, gpointer data)
-{
- struct confirm_overwrite_closure *closure = data;
- char *filename;
-
- if (g_test_verbose())
- printf ("plong!\n");
-
- if (response != GTK_RESPONSE_ACCEPT)
- return;
-
- filename = gtk_file_chooser_get_filename (chooser);
-
- if (!g_str_has_suffix (filename, closure->extension))
- {
- char *basename;
-
- basename = g_path_get_basename (filename);
- g_free (filename);
-
- filename = g_strconcat (basename, closure->extension, NULL);
- gtk_file_chooser_set_current_name (chooser, filename);
-
- g_signal_stop_emission_by_name (chooser, "response");
- gtk_dialog_response (GTK_DIALOG (chooser), GTK_RESPONSE_ACCEPT);
- }
-}
-
-static gboolean
-confirm_overwrite_timeout_cb (gpointer data)
-{
- struct confirm_overwrite_closure *closure;
-
- closure = data;
- gtk_button_clicked (GTK_BUTTON (closure->accept_button));
-
- return FALSE;
-}
-
-/* http://bugzilla.gnome.org/show_bug.cgi?id=347883 */
-static gboolean
-test_confirm_overwrite_for_path (const char *path, gboolean append_extension)
-{
- gboolean passed;
- struct confirm_overwrite_closure closure;
- char *filename;
- guint timeout_id;
-
- passed = TRUE;
-
- closure.extension = NULL;
- closure.confirm_overwrite_signal_emitted = 0;
- closure.chooser = gtk_file_chooser_dialog_new ("hello", NULL, GTK_FILE_CHOOSER_ACTION_SAVE,
- _("_Cancel"), GTK_RESPONSE_CANCEL,
- NULL);
- closure.accept_button = gtk_dialog_add_button (GTK_DIALOG (closure.chooser),
- _("_Save"), GTK_RESPONSE_ACCEPT);
- gtk_dialog_set_default_response (GTK_DIALOG (closure.chooser), GTK_RESPONSE_ACCEPT);
-
- gtk_file_chooser_set_do_overwrite_confirmation (GTK_FILE_CHOOSER (closure.chooser), TRUE);
-
- g_signal_connect (closure.chooser, "confirm-overwrite",
- G_CALLBACK (confirm_overwrite_cb), &closure);
-
- if (append_extension)
- {
- char *extension;
-
- filename = g_path_get_dirname (path);
- gtk_file_chooser_set_current_folder (GTK_FILE_CHOOSER (closure.chooser), filename);
- g_free (filename);
-
- filename = g_path_get_basename (path);
- extension = strchr (filename, '.');
-
- if (extension)
- {
- closure.extension = g_strdup (extension);
- *extension = '\0';
- }
-
- gtk_file_chooser_set_current_name (GTK_FILE_CHOOSER (closure.chooser), filename);
- g_free (filename);
-
- g_signal_connect (closure.chooser, "response",
- G_CALLBACK (overwrite_response_cb), &closure);
- }
- else
- {
- gtk_file_chooser_set_filename (GTK_FILE_CHOOSER (closure.chooser), path);
- }
-
- timeout_id = gdk_threads_add_timeout_full (G_MAXINT, SLEEP_DURATION, confirm_overwrite_timeout_cb, &closure, NULL);
- gtk_dialog_run (GTK_DIALOG (closure.chooser));
- g_source_remove (timeout_id);
-
- filename = gtk_file_chooser_get_filename (GTK_FILE_CHOOSER (closure.chooser));
- passed = passed && filename && (strcmp (filename, path) == 0);
- g_free (filename);
-
- gtk_widget_destroy (closure.chooser);
-
- passed = passed && (1 == closure.confirm_overwrite_signal_emitted);
-
- log_test (passed, "Confirm overwrite for %s", path);
-
- return passed;
-}
-
-static void
-test_confirm_overwrite (void)
-{
- gboolean passed = TRUE;
-
- /* first test for a file we know will always exist */
- passed = passed && test_confirm_overwrite_for_path ("/etc/passwd", FALSE);
- g_assert (passed);
- passed = passed && test_confirm_overwrite_for_path ("/etc/resolv.conf", TRUE);
- g_assert (passed);
-}
-#endif
-
-static const GtkFileChooserAction open_actions[] = {
- GTK_FILE_CHOOSER_ACTION_OPEN,
- GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER
-};
-
-static const GtkFileChooserAction save_actions[] = {
- GTK_FILE_CHOOSER_ACTION_SAVE,
- GTK_FILE_CHOOSER_ACTION_CREATE_FOLDER
-};
-
-
-#ifdef BROKEN_TESTS
-static gboolean
-has_action (const GtkFileChooserAction *actions,
- int n_actions,
- GtkFileChooserAction sought_action)
-{
- int i;
-
- for (i = 0; i < n_actions; i++)
- if (actions[i] == sought_action)
- return TRUE;
-
- return FALSE;
-}
-
-static GtkFileChooserWidgetPrivate *
-get_widget_priv_from_dialog (GtkWidget *dialog)
-{
- GtkFileChooserDialog *d;
- GtkFileChooserDialogPrivate *dialog_priv;
- GtkFileChooserWidget *chooser_widget;
- GtkFileChooserWidgetPrivate *widget_priv;
-
- d = GTK_FILE_CHOOSER_DIALOG (dialog);
- dialog_priv = d->priv;
- chooser_widget = GTK_FILE_CHOOSER_WIDGET (dialog_priv->widget);
- if (!chooser_widget)
- g_error ("BUG: dialog_priv->widget is not a GtkFileChooserWidget");
-
- widget_priv = chooser_widget->priv;
-
- return widget_priv;
-}
-
-static gboolean
-test_widgets_for_current_action (GtkFileChooserDialog *dialog,
- GtkFileChooserAction expected_action)
-{
- GtkFileChooserWidgetPrivate *priv;
- gboolean passed;
-
- if (gtk_file_chooser_get_action (GTK_FILE_CHOOSER (dialog)) != expected_action)
- return FALSE;
-
- priv = get_widget_priv_from_dialog (GTK_WIDGET (dialog));
-
- g_assert (priv->action == expected_action);
-
- passed = TRUE;
-
- /* OPEN implies that the "new folder" button is hidden; otherwise it is shown */
- if (priv->action == GTK_FILE_CHOOSER_ACTION_OPEN)
- passed = passed && !gtk_widget_get_visible (priv->browse_new_folder_button);
- else
- passed = passed && gtk_widget_get_visible (priv->browse_new_folder_button);
-
- /* Check that the widgets are present/visible or not */
- if (has_action (open_actions, G_N_ELEMENTS (open_actions), priv->action))
- {
- passed = passed && (priv->save_widgets == NULL
- && (priv->location_mode == LOCATION_MODE_PATH_BAR
- ? priv->location_entry == NULL
- : priv->location_entry != NULL)
- && priv->save_folder_label == NULL
- && priv->save_folder_combo == NULL
- && priv->save_expander == NULL
- && GTK_IS_CONTAINER (priv->browse_widgets) && gtk_widget_is_drawable (priv->browse_widgets));
- }
- else if (has_action (save_actions, G_N_ELEMENTS (save_actions), priv->action))
- {
- /* FIXME: we can't use GTK_IS_FILE_CHOOSER_ENTRY() because it uses
- * _gtk_file_chooser_entry_get_type(), which is a non-exported symbol.
- * So, we just test priv->location_entry for being non-NULL
- */
- passed = passed && (GTK_IS_CONTAINER (priv->save_widgets) && gtk_widget_is_drawable (priv->save_widgets)
- && priv->location_entry != NULL && gtk_widget_is_drawable (priv->location_entry)
- && GTK_IS_LABEL (priv->save_folder_label) && gtk_widget_is_drawable (priv->save_folder_label)
- && GTK_IS_COMBO_BOX (priv->save_folder_combo) && gtk_widget_is_drawable (priv->save_folder_combo)
- && GTK_IS_EXPANDER (priv->save_expander) && gtk_widget_is_drawable (priv->save_expander)
- && GTK_IS_CONTAINER (priv->browse_widgets));
-
- /* FIXME: we are in a SAVE mode; test the visibility and sensitivity of
- * the children that change depending on the state of the expander.
- */
- }
- else
- {
- g_error ("BAD TEST: test_widgets_for_current_action() doesn't know about %s", get_action_name (priv->action));
- passed = FALSE;
- }
-
- return passed;
-}
-
-typedef gboolean (* ForeachActionCallback) (GtkFileChooserDialog *dialog,
- GtkFileChooserAction action,
- gpointer user_data);
-
-static gboolean
-foreach_action (GtkFileChooserDialog *dialog,
- ForeachActionCallback callback,
- gpointer user_data)
-{
- GEnumClass *enum_class;
- int i;
-
- enum_class = g_type_class_peek (GTK_TYPE_FILE_CHOOSER_ACTION);
- if (!enum_class)
- g_error ("BUG: get_action_name(): no GEnumClass for GTK_TYPE_FILE_CHOOSER_ACTION");
-
- for (i = 0; i < enum_class->n_values; i++)
- {
- GEnumValue *enum_value;
- GtkFileChooserAction action;
- gboolean passed;
-
- enum_value = enum_class->values + i;
- action = enum_value->value;
-
- passed = (* callback) (dialog, action, user_data);
- if (!passed)
- return FALSE;
- }
-
- return TRUE;
-}
-
-struct action_closure {
- GtkFileChooserAction from_action;
-};
-
-static gboolean
-switch_from_to_action_cb (GtkFileChooserDialog *dialog,
- GtkFileChooserAction action,
- gpointer user_data)
-{
- struct action_closure *closure;
- gboolean passed;
-
- closure = user_data;
-
- gtk_file_chooser_set_action (GTK_FILE_CHOOSER (dialog), closure->from_action);
-
- passed = test_widgets_for_current_action (dialog, closure->from_action);
- log_test (passed, "switch_from_to_action_cb(): reset to action %s", get_action_name (closure->from_action));
- if (!passed)
- return FALSE;
-
- gtk_file_chooser_set_action (GTK_FILE_CHOOSER (dialog), action);
-
- passed = test_widgets_for_current_action (dialog, action);
- log_test (passed, "switch_from_to_action_cb(): transition from %s to %s",
- get_action_name (closure->from_action),
- get_action_name (action));
- return passed;
-}
-
-static gboolean
-switch_from_action_cb (GtkFileChooserDialog *dialog,
- GtkFileChooserAction action,
- gpointer user_data)
-{
- struct action_closure closure;
-
- closure.from_action = action;
-
- return foreach_action (dialog, switch_from_to_action_cb, &closure);
-}
-
-static void
-test_action_widgets (void)
-{
- GtkWidget *dialog;
- GtkFileChooserAction action;
- gboolean passed;
-
- dialog = gtk_file_chooser_dialog_new ("Test file chooser",
- NULL,
- GTK_FILE_CHOOSER_ACTION_OPEN,
- _("_Cancel"),
- GTK_RESPONSE_CANCEL,
- _("_OK"),
- GTK_RESPONSE_ACCEPT,
- NULL);
- gtk_widget_show_now (dialog);
-
- action = gtk_file_chooser_get_action (GTK_FILE_CHOOSER (dialog));
-
- passed = test_widgets_for_current_action (GTK_FILE_CHOOSER_DIALOG (dialog), action);
- log_test (passed, "test_action_widgets(): widgets for initial action %s", get_action_name (action));
- g_assert (passed);
-
- passed = foreach_action (GTK_FILE_CHOOSER_DIALOG (dialog), switch_from_action_cb, NULL);
- log_test (passed, "test_action_widgets(): all transitions through property change");
- g_assert (passed);
-
- gtk_widget_destroy (dialog);
-}
-#endif
-
-#ifdef BROKEN_TESTS
-static gboolean
-test_reload_sequence (gboolean set_folder_before_map)
-{
- GtkWidget *dialog;
- GtkFileChooserWidgetPrivate *priv;
- gboolean passed;
- char *folder;
- char *current_working_dir;
-
- passed = TRUE;
-
- current_working_dir = g_get_current_dir ();
-
- dialog = gtk_file_chooser_dialog_new ("Test file chooser",
- NULL,
- GTK_FILE_CHOOSER_ACTION_OPEN,
- _("_Cancel"),
- GTK_RESPONSE_CANCEL,
- _("_OK"),
- GTK_RESPONSE_ACCEPT,
- NULL);
- priv = get_widget_priv_from_dialog (dialog);
-
- if (set_folder_before_map)
- {
- gtk_file_chooser_set_current_folder (GTK_FILE_CHOOSER (dialog), g_get_home_dir ());
-
- wait_for_idle ();
-
- passed = passed && (priv->current_folder != NULL
- && priv->browse_files_model != NULL
- && (priv->load_state == LOAD_PRELOAD || priv->load_state == LOAD_LOADING || priv->load_state == LOAD_FINISHED)
- && priv->reload_state == RELOAD_HAS_FOLDER
- && (priv->load_state == LOAD_PRELOAD ? (priv->load_timeout_id != 0) : TRUE)
- && ((priv->load_state == LOAD_LOADING || priv->load_state == LOAD_FINISHED)
- ? (priv->load_timeout_id == 0 && priv->sort_model != NULL)
- : TRUE));
-
- wait_for_idle ();
-
- folder = gtk_file_chooser_get_current_folder (GTK_FILE_CHOOSER (dialog));
- passed = passed && (g_strcmp0 (folder, g_get_home_dir()) == 0);
- g_free (folder);
- }
- else
- {
- /* Initially, no folder is not loaded or pending */
- passed = passed && (priv->current_folder == NULL
- && priv->sort_model == NULL
- && priv->browse_files_model == NULL
- && priv->load_state == LOAD_EMPTY
- && priv->reload_state == RELOAD_EMPTY
- && priv->load_timeout_id == 0);
-
- wait_for_idle ();
-
- folder = gtk_file_chooser_get_current_folder (GTK_FILE_CHOOSER (dialog));
- passed = passed && (g_strcmp0 (folder, current_working_dir) == 0);
- }
-
- log_test (passed, "test_reload_sequence(): initial status");
-
- /* After mapping, it is loading some folder, either the one that was explicitly set or the default one */
-
- gtk_widget_show_now (dialog);
-
- wait_for_idle ();
-
- passed = passed && (priv->current_folder != NULL
- && priv->browse_files_model != NULL
- && (priv->load_state == LOAD_PRELOAD || priv->load_state == LOAD_LOADING || priv->load_state == LOAD_FINISHED)
- && priv->reload_state == RELOAD_HAS_FOLDER
- && (priv->load_state == LOAD_PRELOAD ? (priv->load_timeout_id != 0) : TRUE)
- && ((priv->load_state == LOAD_LOADING || priv->load_state == LOAD_FINISHED)
- ? (priv->load_timeout_id == 0 && priv->sort_model != NULL)
- : TRUE));
-
- folder = gtk_file_chooser_get_current_folder (GTK_FILE_CHOOSER (dialog));
- if (set_folder_before_map)
- passed = passed && (g_strcmp0 (folder, g_get_home_dir()) == 0);
- else
- passed = passed && (g_strcmp0 (folder, current_working_dir) == 0);
-
- g_free (folder);
-
- log_test (passed, "test_reload_sequence(): status after map");
-
- /* Unmap it; we should still have a folder */
-
- gtk_widget_hide (dialog);
-
- wait_for_idle ();
-
- passed = passed && (priv->current_folder != NULL
- && priv->browse_files_model != NULL
- && (priv->load_state == LOAD_PRELOAD || priv->load_state == LOAD_LOADING || priv->load_state == LOAD_FINISHED)
- && (priv->load_state == LOAD_PRELOAD ? (priv->load_timeout_id != 0) : TRUE)
- && ((priv->load_state == LOAD_LOADING || priv->load_state == LOAD_FINISHED)
- ? (priv->load_timeout_id == 0 && priv->sort_model != NULL)
- : TRUE));
-
- folder = gtk_file_chooser_get_current_folder (GTK_FILE_CHOOSER (dialog));
- if (set_folder_before_map)
- passed = passed && (g_strcmp0 (folder, g_get_home_dir()) == 0);
- else
- passed = passed && (g_strcmp0 (folder, current_working_dir) == 0);
-
- g_free (folder);
-
- log_test (passed, "test_reload_sequence(): status after unmap");
-
- /* Map it again! */
-
- gtk_widget_show_now (dialog);
-
- wait_for_idle ();
-
- passed = passed && (priv->current_folder != NULL
- && priv->browse_files_model != NULL
- && (priv->load_state == LOAD_PRELOAD || priv->load_state == LOAD_LOADING || priv->load_state == LOAD_FINISHED)
- && priv->reload_state == RELOAD_HAS_FOLDER
- && (priv->load_state == LOAD_PRELOAD ? (priv->load_timeout_id != 0) : TRUE)
- && ((priv->load_state == LOAD_LOADING || priv->load_state == LOAD_FINISHED)
- ? (priv->load_timeout_id == 0 && priv->sort_model != NULL)
- : TRUE));
-
- folder = gtk_file_chooser_get_current_folder (GTK_FILE_CHOOSER (dialog));
- if (set_folder_before_map)
- passed = passed && (g_strcmp0 (folder, g_get_home_dir()) == 0);
- else
- passed = passed && (g_strcmp0 (folder, current_working_dir) == 0);
-
- g_free (folder);
-
- log_test (passed, "test_reload_sequence(): status after re-map");
-
- gtk_widget_destroy (dialog);
- g_free (current_working_dir);
-
- return passed;
-}
-
-static void
-test_reload (void)
-{
- gboolean passed;
-
- passed = test_reload_sequence (FALSE);
- log_test (passed, "test_reload(): create and use the default folder");
- g_assert (passed);
-
- passed = test_reload_sequence (TRUE);
- log_test (passed, "test_reload(): set a folder explicitly before mapping");
- g_assert (passed);
-}
-
-static gboolean
-test_button_folder_states_for_action (GtkFileChooserAction action, gboolean use_dialog, gboolean set_folder_on_dialog)
-{
- gboolean passed;
- GtkWidget *window;
- GtkWidget *button;
- char *folder;
- GtkWidget *dialog;
- char *current_working_dir;
- gboolean must_have_cwd;
-
- passed = TRUE;
-
- current_working_dir = g_get_current_dir ();
- must_have_cwd = !(use_dialog && set_folder_on_dialog);
-
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
-
- if (use_dialog)
- {
- dialog = gtk_file_chooser_dialog_new ("Test", NULL, action,
- _("_Cancel"), GTK_RESPONSE_CANCEL,
- _("_OK"), GTK_RESPONSE_ACCEPT,
- NULL);
- button = gtk_file_chooser_button_new_with_dialog (dialog);
-
- if (set_folder_on_dialog)
- gtk_file_chooser_set_current_folder (GTK_FILE_CHOOSER (dialog), g_get_home_dir ());
- }
- else
- {
- button = gtk_file_chooser_button_new ("Test", action);
- dialog = NULL; /* keep gcc happy */
- }
-
- gtk_container_add (GTK_CONTAINER (window), button);
-
- /* Pre-map; no folder is set */
- wait_for_idle ();
-
- folder = gtk_file_chooser_get_current_folder (GTK_FILE_CHOOSER (button));
- if (must_have_cwd)
- passed = passed && (g_strcmp0 (folder, current_working_dir) == 0);
- else
- passed = passed && (g_strcmp0 (folder, g_get_home_dir()) == 0);
-
- log_test (passed, "test_button_folder_states_for_action(): %s, use_dialog=%d, set_folder_on_dialog=%d, pre-map, %s",
- get_action_name (action),
- use_dialog,
- set_folder_on_dialog,
- must_have_cwd ? "must have $cwd" : "must have explicit folder");
-
- /* Map; folder should be set */
-
- gtk_widget_show_all (window);
- gtk_widget_show_now (window);
-
- wait_for_idle ();
-
- folder = gtk_file_chooser_get_current_folder (GTK_FILE_CHOOSER (button));
-
- if (must_have_cwd)
- passed = passed && (g_strcmp0 (folder, current_working_dir) == 0);
- else
- passed = passed && (g_strcmp0 (folder, g_get_home_dir()) == 0);
-
- log_test (passed, "test_button_folder_states_for_action(): %s, use_dialog=%d, set_folder_on_dialog=%d, mapped, %s",
- get_action_name (action),
- use_dialog,
- set_folder_on_dialog,
- must_have_cwd ? "must have $cwd" : "must have explicit folder");
- g_free (folder);
-
- /* Unmap; folder should be set */
-
- gtk_widget_hide (window);
- wait_for_idle ();
- folder = gtk_file_chooser_get_current_folder (GTK_FILE_CHOOSER (button));
-
- if (must_have_cwd)
- passed = passed && (g_strcmp0 (folder, current_working_dir) == 0);
- else
- passed = passed && (g_strcmp0 (folder, g_get_home_dir()) == 0);
-
- log_test (passed, "test_button_folder_states_for_action(): %s, use_dialog=%d, set_folder_on_dialog=%d, unmapped, %s",
- get_action_name (action),
- use_dialog,
- set_folder_on_dialog,
- must_have_cwd ? "must have $cwd" : "must have explicit folder");
- g_free (folder);
-
- /* Re-map; folder should be set */
-
- gtk_widget_show_now (window);
- folder = gtk_file_chooser_get_current_folder (GTK_FILE_CHOOSER (button));
-
- if (must_have_cwd)
- passed = passed && (g_strcmp0 (folder, current_working_dir) == 0);
- else
- passed = passed && (g_strcmp0 (folder, g_get_home_dir()) == 0);
- wait_for_idle ();
- log_test (passed, "test_button_folder_states_for_action(): %s, use_dialog=%d, set_folder_on_dialog=%d, re-mapped, %s",
- get_action_name (action),
- use_dialog,
- set_folder_on_dialog,
- must_have_cwd ? "must have $cwd" : "must have explicit folder");
- g_free (folder);
-
- g_free (current_working_dir);
-
- gtk_widget_destroy (window);
-
- return passed;
-}
-
-static void
-test_button_folder_states (void)
-{
- /* GtkFileChooserButton only supports OPEN and SELECT_FOLDER */
- static const GtkFileChooserAction actions_to_test[] = {
- GTK_FILE_CHOOSER_ACTION_OPEN,
- GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER
- };
- gboolean passed;
- int i;
-
- passed = TRUE;
-
- for (i = 0; i < G_N_ELEMENTS (actions_to_test); i++)
- {
- passed = passed && test_button_folder_states_for_action (actions_to_test[i], FALSE, FALSE);
- g_assert (passed);
- passed = passed && test_button_folder_states_for_action (actions_to_test[i], TRUE, FALSE);
- g_assert (passed);
- passed = passed && test_button_folder_states_for_action (actions_to_test[i], TRUE, TRUE);
- g_assert (passed);
- log_test (passed, "test_button_folder_states(): action %s", get_action_name (actions_to_test[i]));
- }
-
- log_test (passed, "test_button_folder_states(): all supported actions");
-}
-
-static void
-test_folder_switch_and_filters (void)
-{
- gboolean passed;
- char *cwd;
- char *base_dir;
- GFile *cwd_file;
- GFile *base_dir_file;
- GtkWidget *dialog;
- GtkFileFilter *all_filter;
- GtkFileFilter *txt_filter;
- GtkFileChooserWidgetPrivate *priv;
-
- passed = TRUE;
-
- cwd = g_get_current_dir ();
- base_dir = g_build_filename (cwd, "file-chooser-test-dir", NULL);
-
- dialog = gtk_file_chooser_dialog_new ("Test", NULL, GTK_FILE_CHOOSER_ACTION_OPEN,
- _("_Cancel"), GTK_RESPONSE_CANCEL,
- _("_OK"), GTK_RESPONSE_ACCEPT,
- NULL);
- priv = get_widget_priv_from_dialog (dialog);
-
- cwd_file = g_file_new_for_path (cwd);
- base_dir_file = g_file_new_for_path (base_dir);
-
- passed = passed && gtk_file_chooser_set_current_folder (GTK_FILE_CHOOSER (dialog), base_dir);
- g_assert (passed);
-
- /* All files filter */
-
- all_filter = gtk_file_filter_new ();
- gtk_file_filter_set_name (all_filter, "All files");
- gtk_file_chooser_add_filter (GTK_FILE_CHOOSER (dialog), all_filter);
-
- /* *.txt filter */
-
- txt_filter = gtk_file_filter_new ();
- gtk_file_filter_set_name (all_filter, "*.txt");
- gtk_file_filter_add_pattern (txt_filter, "*.txt");
- gtk_file_chooser_add_filter (GTK_FILE_CHOOSER (dialog), txt_filter);
-
- /* Test filter set */
-
- gtk_file_chooser_set_filter (GTK_FILE_CHOOSER (dialog), all_filter);
- passed = passed && (gtk_file_chooser_get_filter (GTK_FILE_CHOOSER (dialog)) == all_filter);
- g_assert (passed);
-
- gtk_file_chooser_set_filter (GTK_FILE_CHOOSER (dialog), txt_filter);
- passed = passed && (gtk_file_chooser_get_filter (GTK_FILE_CHOOSER (dialog)) == txt_filter);
- log_test (passed, "test_folder_switch_and_filters(): set and get filter");
- g_assert (passed);
-
- gtk_widget_show (dialog);
-
- /* Test that filter is unchanged when we switch folders */
-
- gtk_file_chooser_set_current_folder (GTK_FILE_CHOOSER (dialog), cwd);
- sleep_in_main_loop ();
- passed = passed && (gtk_file_chooser_get_filter (GTK_FILE_CHOOSER (dialog)) == txt_filter);
- g_assert (passed);
-
- gtk_file_chooser_set_current_folder (GTK_FILE_CHOOSER (dialog), base_dir);
- sleep_in_main_loop ();
-
- g_signal_emit_by_name (priv->browse_path_bar, "path-clicked",
- cwd_file,
- base_dir_file,
- FALSE);
- sleep_in_main_loop ();
- passed = passed && (gtk_file_chooser_get_filter (GTK_FILE_CHOOSER (dialog)) == txt_filter);
- log_test (passed, "test_folder_switch_and_filters(): filter after changing folder");
- g_assert (passed);
-
- /* cleanups */
- g_free (cwd);
- g_free (base_dir);
- g_object_unref (cwd_file);
- g_object_unref (base_dir_file);
-
- gtk_widget_destroy (dialog);
-
- log_test (passed, "test_folder_switch_and_filters(): all filter tests");
-}
-#endif
-
-int
-main (int argc,
- char **argv)
-{
- /* initialize test program */
- gtk_test_init (&argc, &argv);
-
- /* Register tests */
-
- setup_file_chooser_button_tests ();
-#ifdef BROKEN_TESTS
- setup_set_filename_tests ();
- setup_set_current_name_tests ();
-
- g_test_add_func ("/GtkFileChooser/confirm_overwrite", test_confirm_overwrite);
- g_test_add_func ("/GtkFileChooser/action_widgets", test_action_widgets);
- g_test_add_func ("/GtkFileChooser/reload", test_reload);
- g_test_add_func ("/GtkFileChooser/button_folder_states", test_button_folder_states);
- g_test_add_func ("/GtkFileChooser/folder_switch_and_filters", test_folder_switch_and_filters);
-#endif
-
- /* run and check selected tests */
- return g_test_run();
-}
diff --git a/testsuite/gtk/testing.c b/testsuite/gtk/testing.c
deleted file mode 100644
index 7d59bd1d1d..0000000000
--- a/testsuite/gtk/testing.c
+++ /dev/null
@@ -1,304 +0,0 @@
-/* Gtk+ testing utilities
- * Copyright (C) 2007 Imendio AB
- * Authors: Tim Janik
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 2 of the License, or (at your option) any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library. If not, see <http://www.gnu.org/licenses/>.
- */
-#include <gtk/gtk.h>
-#include <gdk/gdkkeysyms.h>
-#include <string.h>
-#include <math.h>
-
-/* Use a keyval that requires Shift to be active (in typical layouts)
- * like GDK_KEY_ampersand, which is '<shift>6'
- */
-#define KEYVAL_THAT_REQUIRES_SHIFT GDK_KEY_ampersand
-
-
-/* --- test functions --- */
-static void
-test_button_clicks (void)
-{
- int a = 0, b = 0, c = 0;
- GtkWidget *window = gtk_test_display_button_window ("Test Window",
- "Test: gtk_test_widget_click",
- "IgnoreMe1", &a,
- "ClickMe", &b,
- "IgnoreMe2", &c,
- NULL);
- GtkWidget *button = gtk_test_find_widget (window, "*Click*", GTK_TYPE_BUTTON);
- gboolean simsuccess;
- g_assert (button != NULL);
- simsuccess = gtk_test_widget_click (button, 1, 0);
- g_assert (simsuccess == TRUE);
- while (gtk_events_pending ())
- gtk_main_iteration ();
- g_assert (a == 0);
- g_assert (b > 0);
- g_assert (c == 0);
-}
-
-static void
-test_button_keys (void)
-{
- int a = 0, b = 0, c = 0;
- GtkWidget *window = gtk_test_display_button_window ("Test Window",
- "Test: gtk_test_widget_send_key",
- "IgnoreMe1", &a,
- "ClickMe", &b,
- "IgnoreMe2", &c,
- NULL);
- GtkWidget *button = gtk_test_find_widget (window, "*Click*", GTK_TYPE_BUTTON);
- gboolean simsuccess;
- g_assert (button != NULL);
- gtk_widget_grab_focus (button);
- g_assert (gtk_widget_has_focus (button));
- simsuccess = gtk_test_widget_send_key (button, GDK_KEY_Return, 0);
- g_assert (simsuccess == TRUE);
- while (gtk_events_pending ())
- gtk_main_iteration ();
- g_assert (a == 0);
- g_assert (b > 0);
- g_assert (c == 0);
-}
-
-static gboolean
-store_last_key_release (GtkWidget *widget,
- GdkEventKey *event,
- gpointer user_data)
-{
- *((gint *)user_data) = event->keyval;
- return FALSE;
-}
-
-static void
-test_send_shift_key (void)
-{
- GtkWidget *window = gtk_test_display_button_window ("Test Window",
- "Test: test_send_shift_key()",
- "IgnoreMe1", NULL,
- "SendMeKeys", NULL,
- "IgnoreMe2", NULL,
- NULL);
- GtkWidget *button = gtk_test_find_widget (window, "SendMeKeys", GTK_TYPE_BUTTON);
- gint last_key_release = 0;
- gboolean simsuccess;
- g_assert (button != NULL);
- g_signal_connect (button, "key-release-event",
- G_CALLBACK (store_last_key_release),
- &last_key_release);
- gtk_widget_grab_focus (button);
- g_assert (gtk_widget_has_focus (button));
- simsuccess = gtk_test_widget_send_key (button, KEYVAL_THAT_REQUIRES_SHIFT, 0 /*modifiers*/);
- g_assert (simsuccess == TRUE);
- while (gtk_events_pending ())
- gtk_main_iteration ();
- g_assert_cmpint (KEYVAL_THAT_REQUIRES_SHIFT, ==, last_key_release);
-}
-
-static void
-test_slider_ranges (void)
-{
- GtkWidget *child;
- GtkWidget *window = gtk_test_create_simple_window ("Test Window", "Test: gtk_test_warp_slider");
- GtkWidget *hscale = gtk_scale_new_with_range (GTK_ORIENTATION_HORIZONTAL,
- -50, +50, 5);
-
- child = gtk_bin_get_child (GTK_BIN (window));
- gtk_container_add (GTK_CONTAINER (child), hscale);
- gtk_widget_show (hscale);
- gtk_widget_show_now (window);
- while (gtk_events_pending ())
- gtk_main_iteration ();
- gtk_test_slider_set_perc (hscale, 0.0);
- while (gtk_events_pending ())
- gtk_main_iteration ();
- g_assert (gtk_test_slider_get_value (hscale) == -50);
- gtk_test_slider_set_perc (hscale, 50.0);
- while (gtk_events_pending ())
- gtk_main_iteration ();
- g_assert (fabs (gtk_test_slider_get_value (hscale)) < 0.0001);
- gtk_test_slider_set_perc (hscale, 100.0);
- while (gtk_events_pending ())
- gtk_main_iteration ();
- g_assert (gtk_test_slider_get_value (hscale) == +50.0);
-}
-
-static void
-test_text_access (void)
-{
- const int N_WIDGETS = 3;
- GtkWidget *widgets[N_WIDGETS];
- int i = 0;
- widgets[i++] = gtk_test_create_widget (GTK_TYPE_LABEL, NULL);
- widgets[i++] = gtk_test_create_widget (GTK_TYPE_ENTRY, NULL);
- widgets[i++] = gtk_test_create_widget (GTK_TYPE_TEXT_VIEW, NULL);
- g_assert (i == N_WIDGETS);
- for (i = 0; i < N_WIDGETS; i++)
- gtk_test_text_set (widgets[i], "foobar");
- for (i = 0; i < N_WIDGETS; i++)
- {
- gchar *text = gtk_test_text_get (widgets[i]);
- g_assert (strcmp (text, "foobar") == 0);
- g_free (text);
- }
- for (i = 0; i < N_WIDGETS; i++)
- gtk_test_text_set (widgets[i], "");
- for (i = 0; i < N_WIDGETS; i++)
- {
- gchar *text = gtk_test_text_get (widgets[i]);
- g_assert (strcmp (text, "") == 0);
- g_free (text);
- }
-}
-
-static void
-test_xserver_sync (void)
-{
- GtkWidget *window = gtk_test_create_simple_window ("Test Window", "Test: test_xserver_sync");
- GtkWidget *darea = gtk_drawing_area_new ();
- GtkWidget *child;
- GdkWindow *gdk_window;
- GTimer *gtimer = g_timer_new();
- gint sync_is_slower = 0, repeat = 5;
-
- child = gtk_bin_get_child (GTK_BIN (window));
- //gdk_window = gtk_widget_get_window (darea);
-
- gtk_widget_set_size_request (darea, 320, 200);
- gtk_container_add (GTK_CONTAINER (child), darea);
- gtk_widget_show (darea);
- gtk_widget_show_now (window);
-
- while (repeat--)
- {
- gint i, many = 200;
- double nosync_time, sync_time;
- cairo_t *cr;
-
- while (gtk_events_pending ())
- gtk_main_iteration ();
- gdk_window = gtk_widget_get_window (darea);
- cr = gdk_cairo_create (gdk_window);
- cairo_set_source_rgba (cr, 0, 1, 0, 0.1);
- /* run a number of consecutive drawing requests, just using drawing queue */
- g_timer_start (gtimer);
- for (i = 0; i < many; i++)
- {
- cairo_paint (cr);
- }
- g_timer_stop (gtimer);
- nosync_time = g_timer_elapsed (gtimer, NULL);
- gdk_flush();
- while (gtk_events_pending ())
- gtk_main_iteration ();
- g_timer_start (gtimer);
- /* run a number of consecutive drawing requests with intermediate drawing syncs */
- for (i = 0; i < many; i++)
- {
- cairo_paint (cr);
- gdk_test_render_sync (gdk_window);
- }
- g_timer_stop (gtimer);
- sync_time = g_timer_elapsed (gtimer, NULL);
- sync_is_slower += sync_time > nosync_time * 1.5;
- }
- g_timer_destroy (gtimer);
- g_assert (sync_is_slower > 0);
-}
-
-static void
-test_spin_button_arrows (void)
-{
- GtkWidget *child;
- GtkWidget *window = gtk_test_create_simple_window ("Test Window", "Test: test_spin_button_arrows");
- GtkWidget *spinner = gtk_spin_button_new_with_range (0, 100, 5);
- gboolean simsuccess;
- double oldval, newval;
-
- child = gtk_bin_get_child (GTK_BIN (window));
- gtk_container_add (GTK_CONTAINER (child), spinner);
- gtk_widget_show (spinner);
- gtk_widget_show_now (window);
- gtk_test_slider_set_perc (spinner, 0);
- /* check initial spinner value */
- oldval = gtk_test_slider_get_value (spinner);
- g_assert (oldval == 0);
- /* check simple increment */
- simsuccess = gtk_test_spin_button_click (GTK_SPIN_BUTTON (spinner), 1, TRUE);
- g_assert (simsuccess == TRUE);
- while (gtk_events_pending ()) /* let spin button timeout/idle handlers update */
- gtk_main_iteration ();
- newval = gtk_test_slider_get_value (spinner);
- g_assert (newval > oldval);
- /* check maximum warp */
- simsuccess = gtk_test_spin_button_click (GTK_SPIN_BUTTON (spinner), 3, TRUE);
- g_assert (simsuccess == TRUE);
- while (gtk_events_pending ()) /* let spin button timeout/idle handlers update */
- gtk_main_iteration ();
- oldval = gtk_test_slider_get_value (spinner);
- g_assert (oldval == 100);
- /* check simple decrement */
- oldval = gtk_test_slider_get_value (spinner);
- simsuccess = gtk_test_spin_button_click (GTK_SPIN_BUTTON (spinner), 1, FALSE);
- g_assert (simsuccess == TRUE);
- while (gtk_events_pending ()) /* let spin button timeout/idle handlers update */
- gtk_main_iteration ();
- newval = gtk_test_slider_get_value (spinner);
- g_assert (newval < oldval);
- /* check minimum warp */
- simsuccess = gtk_test_spin_button_click (GTK_SPIN_BUTTON (spinner), 3, FALSE);
- g_assert (simsuccess == TRUE);
- while (gtk_events_pending ()) /* let spin button timeout/idle handlers update */
- gtk_main_iteration ();
- oldval = gtk_test_slider_get_value (spinner);
- g_assert (oldval == 0);
-}
-
-static void
-test_statusbar_remove_all (void)
-{
- GtkWidget *statusbar;
-
- g_test_bug ("640487");
-
- statusbar = gtk_statusbar_new ();
- g_object_ref_sink (statusbar);
-
- gtk_statusbar_push (GTK_STATUSBAR (statusbar), 1, "bla");
- gtk_statusbar_push (GTK_STATUSBAR (statusbar), 1, "bla");
- gtk_statusbar_remove_all (GTK_STATUSBAR (statusbar), 1);
-
- g_object_unref (statusbar);
-}
-
-int
-main (int argc,
- char *argv[])
-{
- gtk_test_init (&argc, &argv);
- g_test_bug_base ("http://bugzilla.gnome.org/");
- gtk_test_register_all_types();
-
- g_test_add_func ("/tests/statusbar-remove-all", test_statusbar_remove_all);
- g_test_add_func ("/ui-tests/text-access", test_text_access);
- g_test_add_func ("/ui-tests/button-clicks", test_button_clicks);
- g_test_add_func ("/ui-tests/keys-events", test_button_keys);
- g_test_add_func ("/ui-tests/send-shift-key", test_send_shift_key);
- g_test_add_func ("/ui-tests/slider-ranges", test_slider_ranges);
- g_test_add_func ("/ui-tests/xserver-sync", test_xserver_sync);
- g_test_add_func ("/ui-tests/spin-button-arrows", test_spin_button_arrows);
-
- return g_test_run();
-}
diff --git a/testsuite/gtk/treeview-scrolling.c b/testsuite/gtk/treeview-scrolling.c
deleted file mode 100644
index 5973d45a4f..0000000000
--- a/testsuite/gtk/treeview-scrolling.c
+++ /dev/null
@@ -1,1473 +0,0 @@
-/* Scrolling test suite for GtkTreeView
- * Copyright (C) 2006 Kristian Rietveld <kris@gtk.org>
- * Copyright (C) 2007 Imendio AB, Kristian Rietveld
- * Copyright (C) 2009 Kristian Rietveld <kris@gtk.org>
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 2 of the License, or (at your option) any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library. If not, see <http://www.gnu.org/licenses/>.
- */
-
-/* Original v1.0 -- December 26, 2006
- * Conversion to GLib/GTK+ test framework during December, 2007
- */
-
-
-#include <gtk/gtk.h>
-#include <unistd.h>
-#include <math.h>
-
-#define VIEW_WIDTH 320
-#define VIEW_HEIGHT 240
-
-#define N_ROWS 1000
-#define BIG_N_ROWS N_ROWS * 100
-
-/*
- * To do:
- * - Test that nothing happens if the row is fully visible.
- * - The tests are dependent on the theme/font (size measurements,
- * chosen paths).
- * - Convert to proper GTK+ coding style.
- * - Briefly test scrolling in tree stores as well.
- *
- * Important:
- * - For tests with "mixed height" models, you must ensure that
- * there are only two heights used in total and that the rows with
- * height A and B are strictly alternating. The model creation
- * functions already do this for you, but take this into account
- * when you write a unit test that adds rows to such a created
- * model, you must follow this rule otherwise things will break.
- */
-
-
-/* Constructing models for testing */
-static GtkTreeModel *
-create_model (gboolean constant)
-{
- int i;
-
- GtkTreeIter iter;
- GtkListStore *store;
-
- store = gtk_list_store_new (1, G_TYPE_STRING);
-
- for (i = 0; i < N_ROWS; i++) {
- gtk_list_store_append (store, &iter);
- if (constant || i % 2 == 0)
- gtk_list_store_set (store, &iter, 0, "Foo", -1);
- else
- gtk_list_store_set (store, &iter, 0, "Sliff\nSloff\nBleh", -1);
- }
-
- return GTK_TREE_MODEL (store);
-}
-
-static GtkTreeModel *
-create_big_model (gboolean constant)
-{
- int i;
-
- GtkTreeIter iter;
- GtkListStore *store;
-
- store = gtk_list_store_new (1, G_TYPE_STRING);
-
- for (i = 0; i < BIG_N_ROWS; i++) {
- gtk_list_store_append (store, &iter);
- if (constant || i % 2 == 0)
- gtk_list_store_set (store, &iter, 0, "Foo", -1);
- else
- gtk_list_store_set (store, &iter, 0, "Sliff\nSloff\nBleh", -1);
- }
-
- return GTK_TREE_MODEL (store);
-}
-
-/*
- * Fixtures
- */
-
-typedef struct
-{
- GtkWidget *window;
- GtkWidget *tree_view;
-}
-ScrollFixture;
-
-static void
-scroll_fixture_setup (ScrollFixture *fixture,
- GtkTreeModel *model,
- gconstpointer test_data)
-{
- GtkWidget *sw;
- GtkCellRenderer *renderer;
- GtkTreeViewColumn *column;
-
- fixture->window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
-
- sw = gtk_scrolled_window_new (NULL, NULL);
- gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (sw),
- GTK_POLICY_NEVER,
- GTK_POLICY_ALWAYS);
- gtk_container_add (GTK_CONTAINER (fixture->window), sw);
-
- fixture->tree_view = gtk_tree_view_new_with_model (model);
- g_object_unref (model);
- gtk_scrolled_window_set_min_content_width (GTK_SCROLLED_WINDOW (sw), VIEW_WIDTH);
- gtk_scrolled_window_set_min_content_height (GTK_SCROLLED_WINDOW (sw), VIEW_HEIGHT);
- gtk_widget_set_size_request (fixture->tree_view, VIEW_WIDTH, VIEW_HEIGHT);
-
- renderer = gtk_cell_renderer_text_new ();
- g_object_set (renderer, "editable", TRUE, NULL);
- column = gtk_tree_view_column_new_with_attributes ("Title",
- renderer,
- "text", 0,
- NULL);
-
- gtk_tree_view_append_column (GTK_TREE_VIEW (fixture->tree_view), column);
- gtk_container_add (GTK_CONTAINER (sw), fixture->tree_view);
-}
-
-/* sets up a fixture with a model with constant row heights */
-static void
-scroll_fixture_constant_setup (ScrollFixture *fixture,
- gconstpointer test_data)
-{
- scroll_fixture_setup (fixture, create_model (TRUE), test_data);
-}
-
-/* sets up a fixture with a model with varying row heights */
-static void
-scroll_fixture_mixed_setup (ScrollFixture *fixture,
- gconstpointer test_data)
-{
- scroll_fixture_setup (fixture, create_model (FALSE), test_data);
-}
-
-/* sets up a fixture with a large model with constant row heights */
-static void
-scroll_fixture_constant_big_setup (ScrollFixture *fixture,
- gconstpointer test_data)
-{
- scroll_fixture_setup (fixture, create_big_model (TRUE), test_data);
-}
-
-/* sets up a fixture with a large model with varying row heights */
-static void
-scroll_fixture_mixed_big_setup (ScrollFixture *fixture,
- gconstpointer test_data)
-{
- scroll_fixture_setup (fixture, create_big_model (FALSE), test_data);
-}
-
-/* sets up a fixture with only a single row for the "single row scroll" test */
-static void
-scroll_fixture_single_setup (ScrollFixture *fixture,
- gconstpointer test_data)
-{
- GtkTreeStore *store;
- GtkTreeIter iter, child;
-
- store = gtk_tree_store_new (1, G_TYPE_STRING);
-
- gtk_tree_store_append (store, &iter, NULL);
- gtk_tree_store_set (store, &iter, 0, "Foo", -1);
-
- gtk_tree_store_append (store, &child, &iter);
- gtk_tree_store_set (store, &child, 0, "Two\nLines", -1);
-
- /* The teardown will also destroy the model */
- scroll_fixture_setup (fixture, GTK_TREE_MODEL (store), test_data);
-}
-
-/* sets up a fixture with a tree store */
-static void
-scroll_fixture_tree_setup (ScrollFixture *fixture,
- gconstpointer test_data)
-{
- GtkTreeStore *store;
- GtkTreeIter iter, child;
- int i;
-
- store = gtk_tree_store_new (1, G_TYPE_STRING);
-
- gtk_tree_store_append (store, &iter, NULL);
- gtk_tree_store_set (store, &iter, 0, "Root node", -1);
-
- for (i = 0; i < 5; i++) {
- gtk_tree_store_append (store, &child, &iter);
- gtk_tree_store_set (store, &child, 0, "Child node", -1);
- }
-
- for (i = 0; i < 5; i++) {
- gtk_tree_store_append (store, &iter, NULL);
- gtk_tree_store_set (store, &iter, 0, "Other node", -1);
- }
-
- /* The teardown will also destroy the model */
- scroll_fixture_setup (fixture, GTK_TREE_MODEL (store), test_data);
-}
-
-static void
-scroll_fixture_mixed_tree_setup (ScrollFixture *fixture,
- gconstpointer test_data)
-{
- GtkTreeStore *store;
- GtkTreeIter iter, child;
- int i;
-
- store = gtk_tree_store_new (1, G_TYPE_STRING);
-
- gtk_tree_store_append (store, &iter, NULL);
- gtk_tree_store_set (store, &iter, 0, "Root\nnode", -1);
-
- for (i = 0; i < 5; i++) {
- gtk_tree_store_append (store, &child, &iter);
- if (i % 2 != 0)
- gtk_tree_store_set (store, &child, 0, "Child node", -1);
- else
- gtk_tree_store_set (store, &child,
- 0, "Child\nnode", -1);
- }
-
- for (i = 0; i < 5; i++) {
- gtk_tree_store_append (store, &iter, NULL);
- if (i % 2 == 0)
- gtk_tree_store_set (store, &iter, 0, "Other node", -1);
- else
- gtk_tree_store_set (store, &iter, 0, "Other\nnode", -1);
- }
-
- /* The teardown will also destroy the model */
- scroll_fixture_setup (fixture, GTK_TREE_MODEL (store), test_data);
-}
-
-static void
-scroll_fixture_teardown (ScrollFixture *fixture,
- gconstpointer test_data)
-{
- gtk_widget_destroy (fixture->window);
-}
-
-/*
- * Position check and helpers.
- */
-enum Pos
-{
- POS_TOP,
- POS_CENTER,
- POS_BOTTOM
-};
-
-static int
-get_row_start_for_index (GtkTreeView *tree_view, int index)
-{
- gint height1, height2;
- gint row_start;
- GtkTreePath *path;
- GdkRectangle rect;
-
- path = gtk_tree_path_new_from_indices (0, -1);
- gtk_tree_view_get_background_area (tree_view, path, NULL, &rect);
- height1 = rect.height;
-
- gtk_tree_path_next (path);
- gtk_tree_view_get_background_area (tree_view, path, NULL, &rect);
- height2 = rect.height;
- gtk_tree_path_free (path);
-
- row_start = (index / 2) * height1 + (index / 2) * height2;
- if (index % 2)
- row_start += height1;
-
- return row_start;
-}
-
-static enum Pos
-get_pos_from_path (GtkTreeView *tree_view,
- GtkTreePath *path,
- gdouble row_height,
- GtkAdjustment *vadjustment)
-{
- int row_start;
-
- row_start = get_row_start_for_index (tree_view,
- gtk_tree_path_get_indices (path)[0]);
-
- if (row_start + row_height < gtk_adjustment_get_page_size (vadjustment))
- return POS_TOP;
-
- if (row_start >= gtk_adjustment_get_upper (vadjustment) - gtk_adjustment_get_page_size (vadjustment))
- return POS_BOTTOM;
-
- return POS_CENTER;
-}
-
-static void
-assert_position_with_align (GtkTreeView *tree_view,
- enum Pos pos,
- gint row_y,
- gint row_start,
- gdouble row_height,
- gdouble row_align)
-{
- GtkAdjustment *vadjustment = gtk_scrollable_get_vadjustment (GTK_SCROLLABLE (tree_view));
-
- /* Switch on row-align: 0.0, 0.5, 1.0 */
- switch ((int)(row_align * 2.)) {
- case 0:
- if (pos == POS_TOP || pos == POS_CENTER) {
- /* The row in question is the first row
- * in the view.
- * - rect.y should be zero
- * - dy should be equal to the top
- * y coordinate of the row.
- */
- g_assert (row_y == 0);
- g_assert (gtk_adjustment_get_value (vadjustment) == row_start);
- } else {
- /* The row can be anywhere at the last
- * page of the tree view.
- * - dy is set to the start of the
- * last page.
- */
- g_assert (gtk_adjustment_get_value (vadjustment) == gtk_adjustment_get_upper (vadjustment) - gtk_adjustment_get_page_size (vadjustment));
- }
- break;
-
- case 1:
- /* 0.5 */
- if (pos == POS_TOP
- && row_start < (gtk_adjustment_get_page_size (vadjustment) - row_height) / 2) {
- /* For the first half of the top view we can't
- * center the row in the view, instead we
- * show the first page.
- * - dy should be zero
- */
- g_assert (gtk_adjustment_get_value (vadjustment) == 0);
- } else if (pos == POS_BOTTOM
- && row_start + row_height >= gtk_adjustment_get_upper (vadjustment) - (gtk_adjustment_get_page_size (vadjustment) - row_height) / 2) {
- /* For the last half of the bottom view we
- * can't center the row in the view, instead
- * we show the last page.
- * - dy should be the start of the
- * last page.
- */
- g_assert (gtk_adjustment_get_value (vadjustment) == gtk_adjustment_get_upper (vadjustment) - gtk_adjustment_get_page_size (vadjustment));
- } else {
- /* The row is located in the middle of
- * the view.
- * - top y coordinate is equal to
- * middle of the view minus
- * half the height of the row.
- * (ie. the row's center is at the
- * center of the view).
- */
- gdouble middle = (gtk_adjustment_get_page_size (vadjustment) - row_height) / 2.0;
- g_assert (row_y == ceil (middle) || row_y == floor (middle));
- }
- break;
-
- case 2:
- /* 1.0 */
- if (pos == POS_TOP) {
- /* The row can be anywhere on the
- * first page of the tree view.
- * - dy is zero.
- */
- g_assert (gtk_adjustment_get_value (vadjustment) == 0);
- } else if (pos == POS_CENTER || pos == POS_BOTTOM) {
- /* The row is the last row visible in the
- * view.
- * - rect.y is set to the top of the
- * last row.
- * - row_start is greater than page_size
- * (ie we are not on the first page).
- * - dy is greater than zero
- */
- g_assert (row_start >= gtk_adjustment_get_page_size (vadjustment)
- || row_start + row_height >= gtk_adjustment_get_page_size (vadjustment));
- g_assert (row_y == gtk_adjustment_get_page_size (vadjustment) - row_height);
- }
- break;
- }
-}
-
-static void
-assert_position_without_align (GtkTreeView *tree_view,
- gdouble row_start,
- gdouble row_height)
-{
- GtkAdjustment *vadjustment = gtk_scrollable_get_vadjustment (GTK_SCROLLABLE (tree_view));
-
- /* Without align the tree view does as less work as possible,
- * so basically we only have to check whether the row
- * is visible on the screen.
- */
- g_assert (gtk_adjustment_get_value (vadjustment) <= row_start);
- g_assert (gtk_adjustment_get_value (vadjustment) + gtk_adjustment_get_page_size (vadjustment) >= row_start + row_height);
-}
-
-static void
-test_position (GtkTreeView *tree_view,
- GtkTreePath *path,
- gboolean use_align,
- gdouble row_align)
-{
- gint pos;
- gchar *path_str;
- GdkRectangle rect;
- GtkTreeModel *model;
- gint row_start;
-
- /* Get the location of the path we scrolled to */
- gtk_tree_view_get_background_area (GTK_TREE_VIEW (tree_view),
- path, NULL, &rect);
-
- row_start = get_row_start_for_index (GTK_TREE_VIEW (tree_view),
- gtk_tree_path_get_indices (path)[0]);
-
- /* Ugh */
- pos = get_pos_from_path (GTK_TREE_VIEW (tree_view),
- path, rect.height,
- gtk_scrollable_get_vadjustment (GTK_SCROLLABLE (tree_view)));
-
- /* This is only tested for during test_single() */
- model = gtk_tree_view_get_model (GTK_TREE_VIEW (tree_view));
- if (gtk_tree_model_iter_n_children (model, NULL) == 1) {
- GtkAllocation allocation;
- GtkTreePath *tmppath;
-
- /* Test nothing is dangling at the bottom; read
- * description for test_single() for more information.
- */
-
- /* FIXME: hardcoded width */
- gtk_widget_get_allocation (GTK_WIDGET (tree_view), &allocation);
- if (gtk_tree_view_get_path_at_pos (GTK_TREE_VIEW (tree_view), 0, allocation.height - 30, &tmppath, NULL, NULL, NULL)) {
- g_assert_not_reached ();
- gtk_tree_path_free (tmppath);
- }
- }
-
- path_str = gtk_tree_path_to_string (path);
- if (use_align) {
- assert_position_with_align (tree_view, pos, rect.y,
- row_start, rect.height, row_align);
- } else {
- assert_position_without_align (tree_view, row_start, rect.height);
- }
-
- g_free (path_str);
-}
-
-/*
- * Scrolling code
- */
-
-
-/* Testing scrolling to various positions with various alignments */
-static void
-scroll (ScrollFixture *fixture,
- GtkTreePath *path,
- gboolean use_align,
- gdouble row_align)
-{
- gtk_tree_view_set_cursor (GTK_TREE_VIEW (fixture->tree_view), path,
- NULL, FALSE);
- gtk_tree_view_scroll_to_cell (GTK_TREE_VIEW (fixture->tree_view),
- path, NULL,
- use_align, row_align, 0.0);
-
- gtk_widget_show_all (fixture->window);
-
- gtk_test_widget_wait_for_draw (fixture->window);
-
- test_position (GTK_TREE_VIEW (fixture->tree_view), path,
- use_align, row_align);
-}
-
-static void
-scroll_no_align (ScrollFixture *fixture,
- gconstpointer test_data)
-{
- GtkTreePath *path;
-
- path = gtk_tree_path_new_from_string (test_data);
- scroll (fixture, path, FALSE, 0.0);
- gtk_tree_path_free (path);
-}
-
-static void
-scroll_align_0_0 (ScrollFixture *fixture,
- gconstpointer test_data)
-{
- GtkTreePath *path;
-
- path = gtk_tree_path_new_from_string (test_data);
- scroll (fixture, path, TRUE, 0.0);
- gtk_tree_path_free (path);
-}
-
-static void
-scroll_align_0_5 (ScrollFixture *fixture,
- gconstpointer test_data)
-{
- GtkTreePath *path;
-
- path = gtk_tree_path_new_from_string (test_data);
- scroll (fixture, path, TRUE, 0.5);
- gtk_tree_path_free (path);
-}
-
-static void
-scroll_align_1_0 (ScrollFixture *fixture,
- gconstpointer test_data)
-{
- GtkTreePath *path;
-
- path = gtk_tree_path_new_from_string (test_data);
- scroll (fixture, path, TRUE, 1.0);
- gtk_tree_path_free (path);
-}
-
-
-static void
-scroll_after_realize (ScrollFixture *fixture,
- GtkTreePath *path,
- gboolean use_align,
- gdouble row_align)
-{
- gtk_widget_show_all (fixture->window);
-
- gtk_test_widget_wait_for_draw (fixture->window);
-
- gtk_tree_view_set_cursor (GTK_TREE_VIEW (fixture->tree_view), path,
- NULL, FALSE);
- gtk_tree_view_scroll_to_cell (GTK_TREE_VIEW (fixture->tree_view),
- path, NULL,
- use_align, row_align, 0.0);
-
- gtk_test_widget_wait_for_draw (fixture->window);
-
- test_position (GTK_TREE_VIEW (fixture->tree_view), path,
- use_align, row_align);
-}
-
-static void
-scroll_after_no_align (ScrollFixture *fixture,
- gconstpointer test_data)
-{
- GtkTreePath *path;
-
- path = gtk_tree_path_new_from_string (test_data);
- scroll_after_realize (fixture, path, FALSE, 0.0);
- gtk_tree_path_free (path);
-}
-
-static void
-scroll_after_align_0_0 (ScrollFixture *fixture,
- gconstpointer test_data)
-{
- GtkTreePath *path;
-
- path = gtk_tree_path_new_from_string (test_data);
- scroll_after_realize (fixture, path, TRUE, 0.0);
- gtk_tree_path_free (path);
-}
-
-static void
-scroll_after_align_0_5 (ScrollFixture *fixture,
- gconstpointer test_data)
-{
- GtkTreePath *path;
-
- path = gtk_tree_path_new_from_string (test_data);
- scroll_after_realize (fixture, path, TRUE, 0.5);
- gtk_tree_path_free (path);
-}
-
-static void
-scroll_after_align_1_0 (ScrollFixture *fixture,
- gconstpointer test_data)
-{
- GtkTreePath *path;
-
- path = gtk_tree_path_new_from_string (test_data);
- scroll_after_realize (fixture, path, TRUE, 1.0);
- gtk_tree_path_free (path);
-}
-
-
-static void
-scroll_both_realize (ScrollFixture *fixture,
- GtkTreePath *path,
- gboolean use_align,
- gdouble row_align)
-{
- GtkTreePath *end;
-
- gtk_widget_show_all (fixture->window);
-
- /* Scroll to end */
- end = gtk_tree_path_new_from_indices (999, -1);
-
- gtk_tree_view_set_cursor (GTK_TREE_VIEW (fixture->tree_view), end,
- NULL, FALSE);
- gtk_tree_view_scroll_to_cell (GTK_TREE_VIEW (fixture->tree_view),
- end, NULL,
- use_align, row_align, 0.0);
- gtk_tree_path_free (end);
-
- gtk_test_widget_wait_for_draw (fixture->window);
-
- /* Scroll to final position */
- gtk_tree_view_set_cursor (GTK_TREE_VIEW (fixture->tree_view), path,
- NULL, FALSE);
- gtk_tree_view_scroll_to_cell (GTK_TREE_VIEW (fixture->tree_view),
- path, NULL,
- use_align, row_align, 0.0);
-
- gtk_test_widget_wait_for_draw (fixture->window);
-
- test_position (GTK_TREE_VIEW (fixture->tree_view), path,
- use_align, row_align);
-}
-
-static void
-scroll_both_no_align (ScrollFixture *fixture,
- gconstpointer test_data)
-{
- GtkTreePath *path;
-
- path = gtk_tree_path_new_from_string (test_data);
- scroll_both_realize (fixture, path, FALSE, 0.0);
- gtk_tree_path_free (path);
-}
-
-static void
-scroll_both_align_0_0 (ScrollFixture *fixture,
- gconstpointer test_data)
-{
- GtkTreePath *path;
-
- path = gtk_tree_path_new_from_string (test_data);
- scroll_both_realize (fixture, path, TRUE, 0.0);
- gtk_tree_path_free (path);
-}
-
-static void
-scroll_both_align_0_5 (ScrollFixture *fixture,
- gconstpointer test_data)
-{
- GtkTreePath *path;
-
- path = gtk_tree_path_new_from_string (test_data);
- scroll_both_realize (fixture, path, TRUE, 0.5);
- gtk_tree_path_free (path);
-}
-
-static void
-scroll_both_align_1_0 (ScrollFixture *fixture,
- gconstpointer test_data)
-{
- GtkTreePath *path;
-
- path = gtk_tree_path_new_from_string (test_data);
- scroll_both_realize (fixture, path, TRUE, 1.0);
- gtk_tree_path_free (path);
-}
-
-/* Testing scrolling to a newly created row */
-static void
-create_new_row (GtkListStore *store,
- int n,
- GtkTreeIter *iter)
-{
- switch (n) {
- case 0:
- /* Prepend a row */
- gtk_list_store_prepend (store, iter);
- break;
-
- case 3:
- /* Add a row in the middle of the visible area */
- gtk_list_store_insert (store, iter, 3);
- break;
-
- case 4:
- /* Add a row in the middle of the visible area */
- gtk_list_store_insert (store, iter, 4);
- break;
-
- case 5:
- /* Add a row which is not completely visible */
- gtk_list_store_insert (store, iter, 5);
- break;
-
- case 8:
- /* Add a row which is not completely visible */
- gtk_list_store_insert (store, iter, 8);
- break;
-
- case 500:
- /* Add a row in the middle */
- gtk_list_store_insert (store, iter, 500);
- break;
-
- case 999:
- /* Append a row */
- gtk_list_store_append (store, iter);
- break;
- }
-
- gtk_list_store_set (store, iter, 0, "New...", -1);
-}
-
-static void
-scroll_new_row_editing_started (GtkCellRenderer *cell,
- GtkCellEditable *editable,
- const char *path,
- gpointer user_data)
-{
- GtkWidget **widget = user_data;
-
- *widget = GTK_WIDGET (editable);
-}
-
-static void
-test_editable_position (GtkWidget *tree_view,
- GtkWidget *editable,
- GtkTreePath *cursor_path)
-{
- GtkAllocation allocation;
- GdkRectangle rect;
-
- gtk_tree_view_get_background_area (GTK_TREE_VIEW (tree_view),
- cursor_path, NULL, &rect);
-
- /* There are all in bin_window coordinates */
- gtk_widget_get_allocation (editable, &allocation);
- g_assert (allocation.y == rect.y + ((rect.height - allocation.height) / 2));
-}
-
-static void
-scroll_new_row (ScrollFixture *fixture,
- gconstpointer test_data)
-{
- GtkTreeIter scroll_iter;
- GtkTreePath *scroll_path;
- GtkTreeModel *model;
- GList *renderers;
- GtkTreeViewColumn *column;
- GtkWidget *editable;
-
- /* The aim of this test is creating a new row at several places,
- * and immediately put the cursor on it. TreeView should correctly
- * scroll to the row and show the editable widget.
- *
- * See #81627.
- */
-
- g_test_bug ("81627");
-
- gtk_widget_show_all (fixture->window);
-
- gtk_test_widget_wait_for_draw (fixture->window);
-
- /* Create the new row and scroll to it */
- model = gtk_tree_view_get_model (GTK_TREE_VIEW (fixture->tree_view));
- create_new_row (GTK_LIST_STORE (model), GPOINTER_TO_INT (test_data),
- &scroll_iter);
-
- /* Set up a signal handler to acquire the editable widget */
- column = gtk_tree_view_get_column (GTK_TREE_VIEW (fixture->tree_view), 0);
- renderers = gtk_cell_layout_get_cells (GTK_CELL_LAYOUT (column));
-
- g_signal_connect (G_OBJECT (renderers->data), "editing-started",
- G_CALLBACK (scroll_new_row_editing_started),
- &editable);
-
- /* Now set the cursor on the path and start editing */
- scroll_path = gtk_tree_model_get_path (model, &scroll_iter);
- gtk_tree_view_set_cursor (GTK_TREE_VIEW (fixture->tree_view),
- scroll_path,
- column,
- TRUE);
-
- gtk_test_widget_wait_for_draw (fixture->window);
-
- /* Test position */
- test_position (GTK_TREE_VIEW (fixture->tree_view), scroll_path,
- FALSE, 0.0);
- test_editable_position (fixture->tree_view, editable, scroll_path);
-
- gtk_tree_path_free (scroll_path);
-}
-
-static void
-scroll_new_row_tree (ScrollFixture *fixture,
- gconstpointer test_data)
-{
- GtkTreeModel *model;
- GtkAdjustment *vadjustment;
- int i;
-
- /* The goal of this test is to append new rows at the end of a tree
- * store and immediately scroll to them. If there is a parent
- * node with a couple of childs in the "area above" to explore,
- * this used to lead to unexpected results due to a bug.
- *
- * This issue has been reported by Miroslav Rajcic on
- * gtk-app-devel-list:
- * http://mail.gnome.org/archives/gtk-app-devel-list/2008-December/msg00068.html
- */
-
- gtk_widget_show_all (fixture->window);
-
- gtk_tree_view_expand_all (GTK_TREE_VIEW (fixture->tree_view));
-
- gtk_test_widget_wait_for_draw (fixture->window);
-
- model = gtk_tree_view_get_model (GTK_TREE_VIEW (fixture->tree_view));
- vadjustment = gtk_scrollable_get_vadjustment (GTK_SCROLLABLE (fixture->tree_view));
-
- for (i = 0; i < 5; i++) {
- GtkTreeIter scroll_iter;
- GtkTreePath *scroll_path;
-
- gtk_tree_store_append (GTK_TREE_STORE (model), &scroll_iter,
- NULL);
- gtk_tree_store_set (GTK_TREE_STORE (model), &scroll_iter,
- 0, "New node", -1);
-
- scroll_path = gtk_tree_model_get_path (model, &scroll_iter);
- gtk_tree_view_scroll_to_cell (GTK_TREE_VIEW (fixture->tree_view),
- scroll_path, NULL, FALSE, 0.0, 0.0);
- gtk_tree_path_free (scroll_path);
-
- gtk_test_widget_wait_for_draw (fixture->window);
-
- /* Test position, the scroll bar must be at the end */
- g_assert (gtk_adjustment_get_value (vadjustment) == gtk_adjustment_get_upper (vadjustment) - gtk_adjustment_get_page_size (vadjustment));
- }
-}
-
-/* Test for GNOME bugzilla bug 359231; tests "recovery when removing a bunch of
- * rows at the bottom.
- */
-static void
-test_bug316689 (ScrollFixture *fixture,
- gconstpointer test_data)
-{
- GtkTreeIter iter;
- GtkTreePath *path;
- GtkAdjustment *vadjustment;
- GtkTreeModel *model;
-
- /* The aim of this test is to scroll to the bottom of a TreeView,
- * remove at least one page_size of items and check if TreeView
- * correctly corrects the scroll bar (else they will look "broken").
- *
- * See #316689.
- */
-
- g_test_bug ("316689");
-
- /* Scroll to some place close to the end */
- path = gtk_tree_path_new_from_indices (N_ROWS - 4, -1);
- scroll (fixture, path, FALSE, 0.0);
- gtk_tree_path_free (path);
-
- /* No need for a while events pending loop here, scroll() does this for us.
- *
- * We now remove a bunch of rows, wait for events to process and then
- * check the adjustments to see if the TreeView gracefully recovered.
- */
- model = gtk_tree_view_get_model (GTK_TREE_VIEW (fixture->tree_view));
-
- while (gtk_tree_model_iter_nth_child (model, &iter, NULL, N_ROWS - 15))
- gtk_list_store_remove (GTK_LIST_STORE (model), &iter);
-
- gtk_test_widget_wait_for_draw (fixture->window);
-
- vadjustment = gtk_scrollable_get_vadjustment (GTK_SCROLLABLE (fixture->tree_view));
-
- g_assert (gtk_adjustment_get_value (vadjustment) + gtk_adjustment_get_page_size (vadjustment) <= gtk_adjustment_get_upper (vadjustment));
- g_assert (gtk_adjustment_get_value (vadjustment) == gtk_adjustment_get_upper (vadjustment) - gtk_adjustment_get_page_size (vadjustment));
-}
-
-
-/* Test for GNOME bugzilla bug 359231 */
-static void
-test_bug359231 (void)
-{
- int i;
- int height1, height2;
- GtkTreePath *path;
- GtkTreeIter iter, child;
- GtkTreeStore *store;
- GdkRectangle rect;
- ScrollFixture *fixture;
-
- /* See #359231. */
- g_test_bug ("359231");
-
- /* Create model (GtkTreeStore in this case) */
- store = gtk_tree_store_new (1, G_TYPE_STRING);
-
- gtk_tree_store_append (store, &iter, NULL);
- gtk_tree_store_set (store, &iter, 0, "Foo", -1);
-
- for (i = 0; i < 4; i++) {
- gtk_tree_store_append (store, &child, &iter);
- gtk_tree_store_set (store, &child, 0, "Two\nLines", -1);
- }
-
- fixture = g_new0 (ScrollFixture, 1);
- scroll_fixture_setup (fixture, GTK_TREE_MODEL (store), NULL);
- gtk_widget_show_all (fixture->window);
-
- gtk_test_widget_wait_for_draw (fixture->window);
-
- /* Prepend some rows at the top, expand */
- gtk_tree_store_prepend (store, &iter, NULL);
- gtk_tree_store_set (store, &iter, 0, "Foo", -1);
-
- gtk_tree_store_prepend (store, &child, &iter);
- gtk_tree_store_set (store, &child, 0, "Two\nLines", -1);
-
- gtk_tree_view_expand_all (GTK_TREE_VIEW (fixture->tree_view));
-
- gtk_test_widget_wait_for_draw (fixture->window);
-
- /* Test if height of row 0:0 is correct */
- path = gtk_tree_path_new_from_indices (0, -1);
- gtk_tree_view_get_background_area (GTK_TREE_VIEW (fixture->tree_view),
- path, NULL, &rect);
- height1 = rect.height;
-
- gtk_tree_path_down (path);
- gtk_tree_view_get_background_area (GTK_TREE_VIEW (fixture->tree_view),
- path, NULL, &rect);
- height2 = rect.height;
- gtk_tree_path_free (path);
-
- g_assert (height2 > height1);
-
- /* Clean up; the tear down also cleans up the model */
- scroll_fixture_teardown (fixture, NULL);
-}
-
-/* Test for GNOME bugzilla bug 93584. We add 150 rows to an existing
- * small model, and scroll to one of these with alignment.
- */
-static void
-test_bug93584 (ScrollFixture *fixture,
- gconstpointer test_data)
-{
- int row, i;
- GtkTreeStore *store;
- GtkTreePath *path;
-
- g_test_bug ("93584");
-
- /* Mimic state as in original test case */
- g_signal_connect (G_OBJECT (fixture->tree_view), "realize",
- G_CALLBACK (gtk_tree_view_expand_all), NULL);
- gtk_widget_show_all (fixture->window);
-
- store = GTK_TREE_STORE (gtk_tree_view_get_model (GTK_TREE_VIEW (fixture->tree_view)));
-
- /* Add 150 rows */
- for (i = 0; i < 150; i++) {
- GtkTreeIter iter;
-
- gtk_tree_store_append (store, &iter, NULL);
- gtk_tree_store_set (store, &iter, 0, "Row", -1);
- }
-
- row = gtk_tree_model_iter_n_children (GTK_TREE_MODEL (store), NULL);
- row -= 20;
-
- gtk_test_widget_wait_for_draw (fixture->window);
-
- path = gtk_tree_path_new_from_indices (row, -1);
- scroll (fixture, path, TRUE, 0.5);
- gtk_tree_path_free (path);
-}
-
-/* GNOME bugzilla bug 111500. Expand a row and immediately scroll
- * to its first child. Make sure that expansion happens in currently
- * invisible area.
- */
-static void
-test_bug111500 (ScrollFixture *fixture,
- gconstpointer test_data)
-{
- int i, len;
- GtkTreeStore *store;
- GtkTreeIter parent;
- GtkTreePath *path;
-
- g_test_bug ("111500");
-
- gtk_widget_show_all (fixture->window);
-
- /* Make sure all events have been processed and the window
- * is visible.
- */
- gtk_test_widget_wait_for_draw (fixture->window);
-
- /* Further prepare model */
- store = GTK_TREE_STORE (gtk_tree_view_get_model (GTK_TREE_VIEW (fixture->tree_view)));
-
- for (i = 0; i < 15; i++) {
- GtkTreeIter iter;
-
- gtk_tree_store_append (store, &iter, NULL);
- gtk_tree_store_set (store, &iter, 0, "Other node", -1);
- }
-
- len = gtk_tree_model_iter_n_children (GTK_TREE_MODEL (store), NULL);
- gtk_tree_model_iter_nth_child (GTK_TREE_MODEL (store), &parent,
- NULL, len - 1);
-
- for (i = 0; i < 5; i++) {
- GtkTreeIter iter;
-
- gtk_tree_store_append (store, &iter, &parent);
- gtk_tree_store_set (store, &iter, 0, "Row", -1);
- }
-
- path = gtk_tree_path_new_from_indices (len - 1, -1);
- gtk_tree_view_expand_row (GTK_TREE_VIEW (fixture->tree_view),
- path, FALSE);
-
- gtk_tree_path_down (path);
-
- scroll (fixture, path, FALSE, 0.5);
- gtk_tree_path_free (path);
-}
-
-static void
-test_bug111500_mixed (ScrollFixture *fixture,
- gconstpointer test_data)
-{
- int i, len;
- GtkTreeStore *store;
- GtkTreeIter parent;
- GtkTreePath *path;
-
- g_test_bug ("111500");
-
- gtk_widget_show_all (fixture->window);
-
- /* Make sure all events have been processed and the window
- * is visible.
- */
- gtk_test_widget_wait_for_draw (fixture->window);
-
- /* Further prepare model */
- store = GTK_TREE_STORE (gtk_tree_view_get_model (GTK_TREE_VIEW (fixture->tree_view)));
-
- for (i = 0; i < 15; i++) {
- GtkTreeIter iter;
-
- gtk_tree_store_append (store, &iter, NULL);
- if (i % 2 == 0)
- gtk_tree_store_set (store, &iter, 0, "Other node", -1);
- else
- gtk_tree_store_set (store, &iter, 0, "Other\nnode", -1);
- }
-
- len = gtk_tree_model_iter_n_children (GTK_TREE_MODEL (store), NULL);
- gtk_tree_model_iter_nth_child (GTK_TREE_MODEL (store), &parent,
- NULL, len - 1);
-
- for (i = 0; i < 5; i++) {
- GtkTreeIter iter;
-
- gtk_tree_store_append (store, &iter, &parent);
- if (i % 2 != 0)
- gtk_tree_store_set (store, &iter, 0, "Row", -1);
- else
- gtk_tree_store_set (store, &iter, 0, "Row\nRow", -1);
- }
-
- path = gtk_tree_path_new_from_indices (len - 1, -1);
- gtk_tree_view_expand_row (GTK_TREE_VIEW (fixture->tree_view),
- path, FALSE);
-
- gtk_tree_path_down (path);
-
- scroll (fixture, path, FALSE, 0.5);
- gtk_tree_path_free (path);
-}
-
-/* Test for GNOME bugzilla bug 163214. Invalidate a couple of rows,
- * then scroll to one of these.
- */
-static void
-test_bug163214 (ScrollFixture *fixture,
- gconstpointer test_data)
-{
- int i;
- GtkListStore *store;
- GtkTreePath *path;
-
- g_test_bug ("163214");
-
- gtk_widget_show_all (fixture->window);
-
- /* Make sure all events have been processed and the window
- * is visible.
- */
- gtk_test_widget_wait_for_draw (fixture->window);
-
- store = GTK_LIST_STORE (gtk_tree_view_get_model (GTK_TREE_VIEW (fixture->tree_view)));
-
- /* Invalidate a page of rows */
- for (i = 100; i < 110; i++) {
- GtkTreeIter iter;
-
- gtk_tree_model_iter_nth_child (GTK_TREE_MODEL (store), &iter,
- NULL, i);
- gtk_list_store_set (store, &iter, 0, "Row", -1);
- }
-
- /* Then scroll to that page. */
- path = gtk_tree_path_new_from_indices (105, -1);
- scroll (fixture, path, TRUE, 0.5);
- gtk_tree_path_free (path);
-
- /* Make sure all events have been processed and the window
- * is visible.
- */
- gtk_test_widget_wait_for_draw (fixture->window);
-
- store = GTK_LIST_STORE (gtk_tree_view_get_model (GTK_TREE_VIEW (fixture->tree_view)));
-
- /* Invalidate a page of rows */
- for (i = 300; i < 310; i++) {
- GtkTreeIter iter;
-
- gtk_tree_model_iter_nth_child (GTK_TREE_MODEL (store), &iter,
- NULL, i);
- gtk_list_store_set (store, &iter, 0, "Row", -1);
- }
-
- /* Then scroll to the first row */
- path = gtk_tree_path_new_from_indices (0, -1);
- scroll (fixture, path, TRUE, 0.5);
- gtk_tree_path_free (path);
-}
-
-/* Infrastructure for automatically adding tests */
-enum
-{
- BEFORE,
- AFTER,
- BOTH
-};
-
-static const char *
-test_type_string (int test_type)
-{
- switch (test_type) {
- case BEFORE:
- return "before-realize";
-
- case AFTER:
- return "after-realize";
-
- case BOTH:
- return "both";
- }
-
- return "???";
-}
-
-static char *
-align_string (gboolean use_align,
- gdouble row_align)
-{
- char *ret;
-
- if (!use_align)
- return g_strdup ("no-align");
-
- ret = g_strdup_printf ("align-%1.1f", row_align);
- return ret;
-}
-
-static void
-add_test (const char *path,
- gboolean mixed,
- int test_type,
- gboolean use_align,
- gdouble row_align,
- void (* setup) (ScrollFixture *, gconstpointer),
- void (* scroll_func) (ScrollFixture *, gconstpointer))
-{
- gchar *test_path;
- gchar *align;
-
- align = align_string (use_align, row_align);
-
- test_path = g_strdup_printf ("/TreeView/scrolling/%s/%s-height/path-%s-%s",
- test_type_string (test_type),
- mixed ? "mixed" : "constant",
- path, align);
- g_free (align);
-
- g_test_add (test_path, ScrollFixture, path,
- setup, scroll_func, scroll_fixture_teardown);
-
- g_free (test_path);
-}
-
-static void
-add_tests (gboolean mixed,
- int test_type,
- gboolean use_align,
- gdouble row_align,
- void (*scroll_func) (ScrollFixture *, gconstpointer))
-{
- void (* setup) (ScrollFixture *, gconstpointer);
-
- if (mixed)
- setup = scroll_fixture_mixed_setup;
- else
- setup = scroll_fixture_constant_setup;
-
- add_test ("0", mixed, test_type, use_align, row_align, setup, scroll_func);
- add_test ("2", mixed, test_type, use_align, row_align, setup, scroll_func);
- add_test ("5", mixed, test_type, use_align, row_align, setup, scroll_func);
- /* We scroll to 8 to test a partial visible row. The 8 is
- * based on my font setting of "Vera Sans 11" and
- * the separators set to 0. (This should be made dynamic; FIXME).
- */
- add_test ("8", mixed, test_type, use_align, row_align, setup, scroll_func);
- add_test ("10", mixed, test_type, use_align, row_align, setup, scroll_func);
- add_test ("250", mixed, test_type, use_align, row_align, setup, scroll_func);
- add_test ("500", mixed, test_type, use_align, row_align, setup, scroll_func);
- add_test ("750", mixed, test_type, use_align, row_align, setup, scroll_func);
- add_test ("990", mixed, test_type, use_align, row_align, setup, scroll_func);
- add_test ("991", mixed, test_type, use_align, row_align, setup, scroll_func);
- add_test ("995", mixed, test_type, use_align, row_align, setup, scroll_func);
- add_test ("997", mixed, test_type, use_align, row_align, setup, scroll_func);
- add_test ("999", mixed, test_type, use_align, row_align, setup, scroll_func);
-}
-
-int
-main (int argc, char **argv)
-{
- gtk_test_init (&argc, &argv);
-
- /* Scrolls before realization */
- add_tests (FALSE, BEFORE, FALSE, 0.0, scroll_no_align);
- if (g_test_thorough ())
- add_tests (TRUE, BEFORE, FALSE, 0.0, scroll_no_align);
-
- add_tests (FALSE, BEFORE, TRUE, 0.0, scroll_align_0_0);
- if (g_test_thorough ())
- add_tests (TRUE, BEFORE, TRUE, 0.0, scroll_align_0_0);
-
- add_tests (FALSE, BEFORE, TRUE, 0.5, scroll_align_0_5);
- if (g_test_thorough ())
- add_tests (TRUE, BEFORE, TRUE, 0.5, scroll_align_0_5);
-
- add_tests (FALSE, BEFORE, TRUE, 1.0, scroll_align_1_0);
- if (g_test_thorough ())
- add_tests (TRUE, BEFORE, TRUE, 1.0, scroll_align_1_0);
-
- /* Scrolls after realization */
- add_tests (FALSE, AFTER, FALSE, 0.0, scroll_after_no_align);
- if (g_test_thorough ())
- add_tests (TRUE, AFTER, FALSE, 0.0, scroll_after_no_align);
-
- add_tests (FALSE, AFTER, TRUE, 0.0, scroll_after_align_0_0);
- if (g_test_thorough ())
- add_tests (TRUE, AFTER, TRUE, 0.0, scroll_after_align_0_0);
-
- add_tests (FALSE, AFTER, TRUE, 0.5, scroll_after_align_0_5);
- if (g_test_thorough ())
- add_tests (TRUE, AFTER, TRUE, 0.5, scroll_after_align_0_5);
-
- add_tests (FALSE, AFTER, TRUE, 1.0, scroll_after_align_1_0);
- if (g_test_thorough ())
- add_tests (TRUE, AFTER, TRUE, 1.0, scroll_after_align_1_0);
-
- /* Scroll to end before realization, to a real position after */
- if (g_test_thorough ()) {
- add_tests (FALSE, BOTH, FALSE, 0.0, scroll_both_no_align);
- add_tests (TRUE, BOTH, FALSE, 0.0, scroll_both_no_align);
-
- add_tests (FALSE, BOTH, TRUE, 0.0, scroll_both_align_0_0);
- add_tests (TRUE, BOTH, TRUE, 0.0, scroll_both_align_0_0);
-
- add_tests (FALSE, BOTH, TRUE, 0.5, scroll_both_align_0_5);
- add_tests (TRUE, BOTH, TRUE, 0.5, scroll_both_align_0_5);
-
- add_tests (FALSE, BOTH, TRUE, 1.0, scroll_both_align_1_0);
- add_tests (TRUE, BOTH, TRUE, 1.0, scroll_both_align_1_0);
- }
-
- /* Test different alignments in view with single row */
- g_test_add ("/TreeView/scrolling/single-row/no-align",
- ScrollFixture, "0",
- scroll_fixture_single_setup,
- scroll_no_align,
- scroll_fixture_teardown);
- g_test_add ("/TreeView/scrolling/single-row/align-0.0",
- ScrollFixture, "0",
- scroll_fixture_single_setup,
- scroll_align_0_0,
- scroll_fixture_teardown);
- g_test_add ("/TreeView/scrolling/single-row/align-0.5",
- ScrollFixture, "0",
- scroll_fixture_single_setup,
- scroll_align_0_5,
- scroll_fixture_teardown);
- g_test_add ("/TreeView/scrolling/single-row/align-1.0",
- ScrollFixture, "0",
- scroll_fixture_single_setup,
- scroll_align_1_0,
- scroll_fixture_teardown);
-
- /* Test scrolling in a very large model; also very slow */
- if (g_test_slow ()) {
- g_test_add ("/TreeView/scrolling/large-model/constant-height/middle-no-align",
- ScrollFixture, "50000",
- scroll_fixture_constant_big_setup,
- scroll_no_align,
- scroll_fixture_teardown);
- g_test_add ("/TreeView/scrolling/large-model/constant-height/end-no-align",
- ScrollFixture, "99999",
- scroll_fixture_constant_big_setup,
- scroll_no_align,
- scroll_fixture_teardown);
-
- g_test_add ("/TreeView/scrolling/large-model/mixed-height/middle-no-align",
- ScrollFixture, "50000",
- scroll_fixture_mixed_big_setup,
- scroll_no_align,
- scroll_fixture_teardown);
- g_test_add ("/TreeView/scrolling/large-model/mixed-height/end-no-align",
- ScrollFixture, "99999",
- scroll_fixture_mixed_big_setup,
- scroll_no_align,
- scroll_fixture_teardown);
- }
-
- /* Test scrolling to a newly created row */
- g_test_add ("/TreeView/scrolling/new-row/path-0", ScrollFixture,
- GINT_TO_POINTER (0),
- scroll_fixture_constant_setup,
- scroll_new_row,
- scroll_fixture_teardown);
- g_test_add ("/TreeView/scrolling/new-row/path-4", ScrollFixture,
- GINT_TO_POINTER (4),
- scroll_fixture_constant_setup,
- scroll_new_row,
- scroll_fixture_teardown);
- /* We scroll to 8 to test a partial visible row. The 8 is
- * based on my font setting of "Vera Sans 11" and
- * the separators set to 0. (This should be made dynamic; FIXME).
- */
- g_test_add ("/TreeView/scrolling/new-row/path-8", ScrollFixture,
- GINT_TO_POINTER (8),
- scroll_fixture_constant_setup,
- scroll_new_row,
- scroll_fixture_teardown);
- g_test_add ("/TreeView/scrolling/new-row/path-500", ScrollFixture,
- GINT_TO_POINTER (500),
- scroll_fixture_constant_setup,
- scroll_new_row,
- scroll_fixture_teardown);
- g_test_add ("/TreeView/scrolling/new-row/path-999", ScrollFixture,
- GINT_TO_POINTER (999),
- scroll_fixture_constant_setup,
- scroll_new_row,
- scroll_fixture_teardown);
-
- g_test_add ("/TreeView/scrolling/new-row/tree", ScrollFixture,
- NULL,
- scroll_fixture_tree_setup,
- scroll_new_row_tree,
- scroll_fixture_teardown);
-
- /* Test scrolling to a newly created row, in a mixed height model */
- g_test_add ("/TreeView/scrolling/new-row-mixed/path-0", ScrollFixture,
- GINT_TO_POINTER (0),
- scroll_fixture_mixed_setup,
- scroll_new_row,
- scroll_fixture_teardown);
- g_test_add ("/TreeView/scrolling/new-row-mixed/path-3", ScrollFixture,
- GINT_TO_POINTER (3),
- scroll_fixture_mixed_setup,
- scroll_new_row,
- scroll_fixture_teardown);
- /* We scroll to 8 to test a partial visible row. The 8 is
- * based on my font setting of "Vera Sans 11" and
- * the separators set to 0. (This should be made dynamic; FIXME).
- */
- g_test_add ("/TreeView/scrolling/new-row-mixed/path-5", ScrollFixture,
- GINT_TO_POINTER (5),
- scroll_fixture_mixed_setup,
- scroll_new_row,
- scroll_fixture_teardown);
- g_test_add ("/TreeView/scrolling/new-row-mixed/path-500", ScrollFixture,
- GINT_TO_POINTER (500),
- scroll_fixture_mixed_setup,
- scroll_new_row,
- scroll_fixture_teardown);
- g_test_add ("/TreeView/scrolling/new-row-mixed/path-999", ScrollFixture,
- GINT_TO_POINTER (999),
- scroll_fixture_mixed_setup,
- scroll_new_row,
- scroll_fixture_teardown);
-
- g_test_add ("/TreeView/scrolling/new-row-mixed/tree", ScrollFixture,
- NULL,
- scroll_fixture_mixed_tree_setup,
- scroll_new_row_tree,
- scroll_fixture_teardown);
-
- /* Misc. tests */
- g_test_add ("/TreeView/scrolling/specific/bug-316689",
- ScrollFixture, NULL,
- scroll_fixture_constant_setup, test_bug316689,
- scroll_fixture_teardown);
- g_test_add_func ("/TreeView/scrolling/specific/bug-359231",
- test_bug359231);
- g_test_add ("/TreeView/scrolling/specific/bug-93584",
- ScrollFixture, NULL,
- scroll_fixture_tree_setup, test_bug93584,
- scroll_fixture_teardown);
- g_test_add ("/TreeView/scrolling/specific/bug-111500",
- ScrollFixture, NULL,
- scroll_fixture_tree_setup, test_bug111500,
- scroll_fixture_teardown);
- g_test_add ("/TreeView/scrolling/specific/bug-111500-mixed",
- ScrollFixture, NULL,
- scroll_fixture_mixed_tree_setup, test_bug111500_mixed,
- scroll_fixture_teardown);
- g_test_add ("/TreeView/scrolling/specific/bug-163214",
- ScrollFixture, NULL,
- scroll_fixture_constant_setup, test_bug163214,
- scroll_fixture_teardown);
-
- return g_test_run ();
-}