mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-02 08:50:28 +00:00
Add a scrolling test case involving creating new rows in tree stores
Based on a bug report from Miroslav Rajcic, details are in the tree view scrolling suite source code.
This commit is contained in:
parent
105e0be70e
commit
7b4f09a589
@ -38,6 +38,8 @@
|
|||||||
* - Test that nothing happens if the row is fully visible.
|
* - Test that nothing happens if the row is fully visible.
|
||||||
* - The tests are dependent on the theme/font (size measurements,
|
* - The tests are dependent on the theme/font (size measurements,
|
||||||
* chosen paths).
|
* chosen paths).
|
||||||
|
* - Convert to proper GTK+ coding style.
|
||||||
|
* - Briefly test scrolling in tree stores as well.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
@ -176,6 +178,34 @@ scroll_fixture_single_setup (ScrollFixture *fixture,
|
|||||||
scroll_fixture_setup (fixture, GTK_TREE_MODEL (store), test_data);
|
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
|
static void
|
||||||
scroll_fixture_teardown (ScrollFixture *fixture,
|
scroll_fixture_teardown (ScrollFixture *fixture,
|
||||||
gconstpointer test_data)
|
gconstpointer test_data)
|
||||||
@ -753,6 +783,56 @@ scroll_new_row (ScrollFixture *fixture,
|
|||||||
gtk_tree_path_free (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));
|
||||||
|
|
||||||
|
while (gtk_events_pending ())
|
||||||
|
gtk_main_iteration ();
|
||||||
|
|
||||||
|
model = gtk_tree_view_get_model (GTK_TREE_VIEW (fixture->tree_view));
|
||||||
|
vadjustment = gtk_tree_view_get_vadjustment (GTK_TREE_VIEW (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);
|
||||||
|
|
||||||
|
while (gtk_events_pending ())
|
||||||
|
gtk_main_iteration ();
|
||||||
|
|
||||||
|
/* Test position, the scroll bar must be at the end */
|
||||||
|
g_assert (vadjustment->value == vadjustment->upper - vadjustment->page_size);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* Test for GNOME bugzilla bug 359231; tests "recovery when removing a bunch of
|
/* Test for GNOME bugzilla bug 359231; tests "recovery when removing a bunch of
|
||||||
* rows at the bottom.
|
* rows at the bottom.
|
||||||
*/
|
*/
|
||||||
@ -1091,6 +1171,12 @@ main (int argc, char **argv)
|
|||||||
scroll_new_row,
|
scroll_new_row,
|
||||||
scroll_fixture_teardown);
|
scroll_fixture_teardown);
|
||||||
|
|
||||||
|
g_test_add ("/TreeView/scrolling/new-row/tree", ScrollFixture,
|
||||||
|
NULL,
|
||||||
|
scroll_fixture_tree_setup,
|
||||||
|
scroll_new_row_tree,
|
||||||
|
scroll_fixture_teardown);
|
||||||
|
|
||||||
/* Misc. tests */
|
/* Misc. tests */
|
||||||
g_test_add ("/TreeView/scrolling/specific/bug-316689",
|
g_test_add ("/TreeView/scrolling/specific/bug-316689",
|
||||||
ScrollFixture, NULL,
|
ScrollFixture, NULL,
|
||||||
|
Loading…
Reference in New Issue
Block a user