[gtk+] Add tests for GtkTreePath
- From: Matthias Clasen <matthiasc src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+] Add tests for GtkTreePath
- Date: Wed, 1 Jun 2011 02:12:16 +0000 (UTC)
commit 906292541a985d783221b6b73fd8d45d320f567a
Author: Matthias Clasen <mclasen redhat com>
Date: Tue May 31 22:10:40 2011 -0400
Add tests for GtkTreePath
gtk/tests/Makefile.am | 4 +
gtk/tests/treepath.c | 183 +++++++++++++++++++++++++++++++++++++++++++++++++
2 files changed, 187 insertions(+), 0 deletions(-)
---
diff --git a/gtk/tests/Makefile.am b/gtk/tests/Makefile.am
index 17bbc38..32d741a 100644
--- a/gtk/tests/Makefile.am
+++ b/gtk/tests/Makefile.am
@@ -109,6 +109,10 @@ TEST_PROGS += cellarea
cellarea_SOURCES = cellarea.c
cellarea_LDADD = $(progs_ldadd)
+TEST_PROGS += treepath
+treepath_SOURCES = treepath.c
+treepath_LDADD = $(progs_ldadd)
+
EXTRA_DIST += \
file-chooser-test-dir/empty \
file-chooser-test-dir/text.txt
diff --git a/gtk/tests/treepath.c b/gtk/tests/treepath.c
new file mode 100644
index 0000000..03b96a0
--- /dev/null
+++ b/gtk/tests/treepath.c
@@ -0,0 +1,183 @@
+/* GtkTrePath tests.
+ *
+ * Copyright (C) 2011, Red Hat, Inc.
+ * Authors: Matthias Clasen <mclasen redhat 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, write to the
+ * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+ * Boston, MA 02111-1307, USA.
+ */
+
+#include <gtk/gtk.h>
+
+static void
+test_append (void)
+{
+ GtkTreePath *p;
+ gint i;
+ gint *indices;
+
+ p = gtk_tree_path_new ();
+ for (i = 0; i < 100; i++)
+ {
+ g_assert_cmpint (gtk_tree_path_get_depth (p), ==, i);
+ gtk_tree_path_append_index (p, i);
+ }
+
+ indices = gtk_tree_path_get_indices (p);
+ for (i = 0; i < 100; i++)
+ g_assert_cmpint (indices[i], ==, i);
+
+ gtk_tree_path_free (p);
+}
+
+static void
+test_prepend (void)
+{
+ GtkTreePath *p;
+ gint i;
+ gint *indices;
+
+ p = gtk_tree_path_new ();
+ for (i = 0; i < 100; i++)
+ {
+ g_assert_cmpint (gtk_tree_path_get_depth (p), ==, i);
+ gtk_tree_path_prepend_index (p, i);
+ }
+
+ indices = gtk_tree_path_get_indices (p);
+ for (i = 0; i < 100; i++)
+ g_assert_cmpint (indices[i], ==, 99 - i);
+
+ gtk_tree_path_free (p);
+}
+
+static void
+test_to_string (void)
+{
+ const gchar *str = "0:1:2:3:4:5:6:7:8:9:10";
+ GtkTreePath *p;
+ gint *indices;
+ gchar *s;
+ gint i;
+
+ p = gtk_tree_path_new_from_string (str);
+ indices = gtk_tree_path_get_indices (p);
+ for (i = 0; i < 10; i++)
+ g_assert_cmpint (indices[i], ==, i);
+ s = gtk_tree_path_to_string (p);
+ g_assert_cmpstr (s, ==, str);
+
+ gtk_tree_path_free (p);
+ g_free (s);
+}
+
+static void
+test_from_indices (void)
+{
+ GtkTreePath *p;
+ gint *indices;
+ gint i;
+
+ p = gtk_tree_path_new_from_indices (0, 1, 2, 3, 4, 5, 6, 7, 8, 9, -1);
+ g_assert_cmpint (gtk_tree_path_get_depth (p), ==, 10);
+ indices = gtk_tree_path_get_indices (p);
+ for (i = 0; i < 10; i++)
+ g_assert_cmpint (indices[i], ==, i);
+ gtk_tree_path_free (p);
+}
+
+static void
+test_first (void)
+{
+ GtkTreePath *p;
+ p = gtk_tree_path_new_first ();
+ g_assert_cmpint (gtk_tree_path_get_depth (p), ==, 1);
+ g_assert_cmpint (gtk_tree_path_get_indices (p)[0], ==, 0);
+ gtk_tree_path_free (p);
+}
+
+static void
+test_navigation (void)
+{
+ GtkTreePath *p;
+ GtkTreePath *q;
+ gint *pi;
+ gint *qi;
+ gint i;
+ gboolean res;
+
+ p = gtk_tree_path_new_from_indices (0, 1, 2, 3, 4, 5, 6, 7, 8, 9, -1);
+ q = gtk_tree_path_copy (p);
+ g_assert (gtk_tree_path_compare (p, q) == 0);
+ gtk_tree_path_next (q);
+ pi = gtk_tree_path_get_indices (p);
+ qi = gtk_tree_path_get_indices (q);
+ for (i = 0; i < 9; i++)
+ g_assert_cmpint (pi[i], ==, qi[i]);
+ g_assert_cmpint (qi[9], ==, pi[9] + 1);
+
+ g_assert (!gtk_tree_path_is_ancestor (p, q));
+ g_assert (!gtk_tree_path_is_ancestor (q, p));
+ g_assert (!gtk_tree_path_is_descendant (p, q));
+ g_assert (!gtk_tree_path_is_descendant (q, p));
+
+ res = gtk_tree_path_prev (q);
+ g_assert (res);
+ g_assert (gtk_tree_path_compare (p, q) == 0);
+
+ g_assert (!gtk_tree_path_is_ancestor (p, q));
+ g_assert (!gtk_tree_path_is_ancestor (q, p));
+ g_assert (!gtk_tree_path_is_descendant (p, q));
+ g_assert (!gtk_tree_path_is_descendant (q, p));
+
+ gtk_tree_path_down (q);
+
+ g_assert (gtk_tree_path_compare (p, q) < 0);
+
+ g_assert (gtk_tree_path_is_ancestor (p, q));
+ g_assert (!gtk_tree_path_is_ancestor (q, p));
+ g_assert (!gtk_tree_path_is_descendant (p, q));
+ g_assert (gtk_tree_path_is_descendant (q, p));
+
+ res = gtk_tree_path_prev (q);
+ g_assert (!res);
+
+ res = gtk_tree_path_up (q);
+ g_assert (res);
+ g_assert (gtk_tree_path_compare (p, q) == 0);
+
+ g_assert_cmpint (gtk_tree_path_get_depth (q), ==, 10);
+ res = gtk_tree_path_up (q);
+ g_assert (res);
+ g_assert_cmpint (gtk_tree_path_get_depth (q), ==, 9);
+
+ gtk_tree_path_free (p);
+ gtk_tree_path_free (q);
+}
+
+int
+main (int argc, char *argv[])
+{
+ gtk_test_init (&argc, &argv, NULL);
+
+ g_test_add_func ("/tree-path/append", test_append);
+ g_test_add_func ("/tree-path/prepend", test_prepend);
+ g_test_add_func ("/tree-path/to-string", test_to_string);
+ g_test_add_func ("/tree-path/from-indices", test_from_indices);
+ g_test_add_func ("/tree-path/first", test_first);
+ g_test_add_func ("/tree-path/navigation", test_navigation);
+
+ return g_test_run ();
+}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]