summaryrefslogtreecommitdiff
path: root/tests/testtreechanging.c
diff options
context:
space:
mode:
authorBenjamin Otte <otte@redhat.com>2011-12-10 05:45:02 +0100
committerBenjamin Otte <otte@redhat.com>2011-12-10 08:00:26 +0100
commitbf47d8d4996e8fc8254ae7c7dc87ae40efa79b5e (patch)
treeb4df60a68b00f9bb956dbbb45201091a4eed1a95 /tests/testtreechanging.c
parent4dbedb748130370e77352dba26a4cb9a18751ba7 (diff)
downloadgtk+-bf47d8d4996e8fc8254ae7c7dc87ae40efa79b5e.tar.gz
tests: Add sanity checks for selection
We want to know that the selection emits "changed" when it changes.
Diffstat (limited to 'tests/testtreechanging.c')
-rw-r--r--tests/testtreechanging.c92
1 files changed, 78 insertions, 14 deletions
diff --git a/tests/testtreechanging.c b/tests/testtreechanging.c
index 943b641d8d..bd688ff01f 100644
--- a/tests/testtreechanging.c
+++ b/tests/testtreechanging.c
@@ -249,37 +249,70 @@ collapse (GtkTreeView *treeview)
}
}
+/* sanity checks */
+
static void
-check_cursor (GtkTreeView *treeview)
+assert_row_reference_is_path (GtkTreeRowReference *ref,
+ GtkTreePath *path)
{
- GtkTreeRowReference *ref = g_object_get_data (G_OBJECT (treeview), "cursor");
- GtkTreePath *expected, *cursor;
+ GtkTreePath *expected;
- gtk_tree_view_get_cursor (treeview, &cursor, NULL);
if (ref == NULL)
{
- g_assert (cursor == NULL);
+ g_assert (path == NULL);
+ return;
}
- else
- {
- g_assert (cursor != NULL);
- g_assert (gtk_tree_row_reference_valid (ref));
- expected = gtk_tree_row_reference_get_path (ref);
- g_assert (expected != NULL);
- g_assert (gtk_tree_path_compare (expected, cursor) == 0);
+ g_assert (path != NULL);
+ g_assert (gtk_tree_row_reference_valid (ref));
- gtk_tree_path_free (expected);
- }
+ expected = gtk_tree_row_reference_get_path (ref);
+ g_assert (expected != NULL);
+ g_assert (gtk_tree_path_compare (expected, path) == 0);
+ gtk_tree_path_free (expected);
+}
+
+static void
+check_cursor (GtkTreeView *treeview)
+{
+ GtkTreeRowReference *ref = g_object_get_data (G_OBJECT (treeview), "cursor");
+ GtkTreePath *cursor;
+
+ gtk_tree_view_get_cursor (treeview, &cursor, NULL);
+ assert_row_reference_is_path (ref, cursor);
if (cursor)
gtk_tree_path_free (cursor);
}
static void
+check_selection_item (GtkTreeModel *model,
+ GtkTreePath *path,
+ GtkTreeIter *iter,
+ gpointer listp)
+{
+ GList **list = listp;
+
+ g_assert (*list);
+ assert_row_reference_is_path ((*list)->data, path);
+ *list = (*list)->next;
+}
+
+static void
+check_selection (GtkTreeView *treeview)
+{
+ GList *selection = g_object_get_data (G_OBJECT (treeview), "selection");
+
+ gtk_tree_selection_selected_foreach (gtk_tree_view_get_selection (treeview),
+ check_selection_item,
+ &selection);
+}
+
+static void
check_sanity (GtkTreeView *treeview)
{
check_cursor (treeview);
+ check_selection (treeview);
}
static gboolean
@@ -322,10 +355,41 @@ cursor_changed_cb (GtkTreeView *treeview,
}
static void
+selection_list_free (gpointer list)
+{
+ g_list_free_full (list, (GDestroyNotify) gtk_tree_row_reference_free);
+}
+
+static void
+selection_changed_cb (GtkTreeSelection *tree_selection,
+ gpointer unused)
+{
+ GList *selected, *list;
+ GtkTreeModel *model;
+
+ selected = gtk_tree_selection_get_selected_rows (tree_selection, &model);
+
+ for (list = selected; list; list = list->next)
+ {
+ GtkTreePath *path = list->data;
+
+ list->data = gtk_tree_row_reference_new (model, path);
+ gtk_tree_path_free (path);
+ }
+
+ g_object_set_data_full (G_OBJECT (gtk_tree_selection_get_tree_view (tree_selection)),
+ "selection",
+ selected,
+ selection_list_free);
+}
+
+static void
setup_sanity_checks (GtkTreeView *treeview)
{
g_signal_connect (treeview, "cursor-changed", G_CALLBACK (cursor_changed_cb), NULL);
cursor_changed_cb (treeview, NULL);
+ g_signal_connect (gtk_tree_view_get_selection (treeview), "changed", G_CALLBACK (selection_changed_cb), NULL);
+ selection_changed_cb (gtk_tree_view_get_selection (treeview), NULL);
}
int