[sysprof] filter: backport fixes from dazzle
- From: Christian Hergert <chergert src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [sysprof] filter: backport fixes from dazzle
- Date: Wed, 12 Sep 2018 11:56:10 +0000 (UTC)
commit c8d97eb198af52c521f410386d9688f3c9dfd5fd
Author: Christian Hergert <chergert redhat com>
Date: Mon Sep 10 17:07:29 2018 -0700
filter: backport fixes from dazzle
lib/util/sp-model-filter.c | 2 +-
tests/test-model-filter.c | 67 ++++++++++++++++++++++++++++++++++++++++++++++
2 files changed, 68 insertions(+), 1 deletion(-)
---
diff --git a/lib/util/sp-model-filter.c b/lib/util/sp-model-filter.c
index 182be2a..ae0ad86 100644
--- a/lib/util/sp-model-filter.c
+++ b/lib/util/sp-model-filter.c
@@ -191,7 +191,7 @@ add_new_items:
if (n_added > 0)
{
- GSequenceIter *iter = g_sequence_get_iter_at_pos (priv->child_seq, position + 1);
+ GSequenceIter *iter = g_sequence_get_iter_at_pos (priv->child_seq, position);
GSequenceIter *filter_iter = find_next_visible_filter_iter (self, iter);
guint filter_position = g_sequence_iter_get_position (filter_iter);
guint count = 0;
diff --git a/tests/test-model-filter.c b/tests/test-model-filter.c
index fa17841..82111e3 100644
--- a/tests/test-model-filter.c
+++ b/tests/test-model-filter.c
@@ -171,6 +171,72 @@ test_process (void)
g_object_unref (model);
}
+static guint last_n_added = 0;
+static guint last_n_removed = 0;
+static guint last_changed_position = 0;
+
+static void
+model_items_changed_cb (SpModelFilter *filter,
+ guint position,
+ guint n_removed,
+ guint n_added,
+ GListModel *model)
+{
+ last_n_added = n_added;
+ last_n_removed = n_removed;
+ last_changed_position = position;
+}
+
+
+static void
+filter_items_changed_cb (SpModelFilter *filter,
+ guint position,
+ guint n_removed,
+ guint n_added,
+ GListModel *model)
+{
+ g_assert_cmpint (n_added, ==, last_n_added);
+ g_assert_cmpint (n_removed, ==, last_n_removed);
+ g_assert_cmpint (position, ==, last_changed_position);
+}
+
+static void
+test_items_changed (void)
+{
+ SpModelFilter *filter;
+ GListStore *model;
+ guint i;
+
+ model = g_list_store_new (TEST_TYPE_ITEM);
+ g_assert (model);
+
+ g_signal_connect (model, "items-changed", G_CALLBACK (model_items_changed_cb), NULL);
+
+ filter = sp_model_filter_new (G_LIST_MODEL (model));
+ g_assert (filter);
+
+ g_signal_connect_after (filter, "items-changed", G_CALLBACK (filter_items_changed_cb), model);
+
+ /* The filter model is not filtered, so it must mirror whatever
+ * the child model does. In this case, test if the position of
+ * items-changed match.
+ */
+ for (i = 0; i < 100; i++)
+ {
+ g_autoptr (TestItem) val = test_item_new (i);
+ g_list_store_append (model, val);
+ }
+
+ g_assert_cmpint (100, ==, g_list_model_get_n_items (G_LIST_MODEL (model)));
+ g_assert_cmpint (100, ==, g_list_model_get_n_items (G_LIST_MODEL (filter)));
+
+ for (i = 0; i < 100; i++)
+ g_list_store_remove (model, 0);
+
+ g_clear_object (&model);
+ g_clear_object (&filter);
+}
+
gint
main (gint argc,
gchar *argv[])
@@ -178,5 +244,6 @@ main (gint argc,
g_test_init (&argc, &argv, NULL);
g_test_add_func ("/SpModelFilter/basic", test_basic);
g_test_add_func ("/SpModelFilter/process", test_process);
+ g_test_add_func ("/SpModelFilter/items-changed", test_items_changed);
return g_test_run ();
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]