[gtk+] Add caseless unit tests for textiter.
- From: Paolo Borelli <pborelli src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+] Add caseless unit tests for textiter.
- Date: Mon, 1 Nov 2010 14:39:54 +0000 (UTC)
commit 1fad7eaf85d7749f8def4cbedca2ff6e68006290
Author: Ignacio Casal Quinteiro <icq gnome org>
Date: Sat Oct 30 18:19:59 2010 +0200
Add caseless unit tests for textiter.
gtk/tests/textiter.c | 94 +++++++++++++++++++++++++++++++++++++++++++++++++-
1 files changed, 93 insertions(+), 1 deletions(-)
---
diff --git a/gtk/tests/textiter.c b/gtk/tests/textiter.c
index 9418fbd..4fc5fc7 100644
--- a/gtk/tests/textiter.c
+++ b/gtk/tests/textiter.c
@@ -138,6 +138,17 @@ check_not_found (const gchar *haystack,
}
static void
+test_full_buffer (void)
+{
+ check_found_forward ("foo", "foo", 0, 0, 3, "foo");
+ check_found_backward ("foo", "foo", 0, 0, 3, "foo");
+ check_found_forward ("foo", "foo", GTK_TEXT_SEARCH_CASE_INSENSITIVE, 0, 3, "foo");
+ check_found_backward ("foo", "foo", GTK_TEXT_SEARCH_CASE_INSENSITIVE, 0, 3, "foo");
+ check_found_forward ("foo", "Foo", GTK_TEXT_SEARCH_CASE_INSENSITIVE, 0, 3, "foo");
+ check_found_backward ("foo", "Foo", GTK_TEXT_SEARCH_CASE_INSENSITIVE, 0, 3, "foo");
+}
+
+static void
test_search (void)
{
/* simple match */
@@ -153,7 +164,7 @@ test_search (void)
check_found_forward ("This is some\nfoo text", "foo", 0, 13, 16, "foo");
check_found_backward ("This is some\nfoo text", "foo", 0, 13, 16, "foo");
check_found_forward ("This is some foo\nfoo text", "foo", 0, 13, 16, "foo");
- check_found_backward ("This is some foo\nfoo text", "foo", 0, 17, 20, "foo")
+ check_found_backward ("This is some foo\nfoo text", "foo", 0, 17, 20, "foo");
check_not_found ("This is some\nfoo text", "Foo", 0);
/* end of buffer */
@@ -167,13 +178,94 @@ test_search (void)
check_not_found ("This is some foo\nfoo text", "Foo\nfoo", 0);
}
+static void
+test_search_caseless (void)
+{
+ GtkTextSearchFlags flags;
+
+ flags = GTK_TEXT_SEARCH_CASE_INSENSITIVE;
+
+ /* simple match */
+ check_found_forward ("This is some foo text", "foo", flags, 13, 16, "foo");
+ check_found_forward ("This is some foo text", "Foo", flags, 13, 16, "foo");
+ check_found_forward ("This is some Foo text", "foo", flags, 13, 16, "Foo");
+ check_found_backward ("This is some foo text", "foo", flags, 13, 16, "foo");
+ check_found_backward ("This is some foo text", "Foo", flags, 13, 16, "foo");
+ check_found_backward ("This is some Foo text", "foo", flags, 13, 16, "Foo");
+
+ /* check also that different composition of utf8 characters
+ (e.g. accented letters) match */
+
+ /* different matches for forward and backward */
+ check_found_forward ("This is some foo foo text", "foo", flags, 13, 16, "foo");
+ check_found_forward ("This is some foo foo text", "Foo", flags, 13, 16, "foo");
+ check_found_forward ("This is some Foo foo text", "foo", flags, 13, 16, "Foo");
+ check_found_forward ("This is some \303\200 \303\240 text", "\303\240", flags, 13, 14, "\303\200");
+ check_found_forward ("This is some \303\200 \303\240 text", "\303\200", flags, 13, 14, "\303\200");
+ check_found_forward ("This is some \303\200 \303\240 text", "a\u0300", flags, 13, 14, "\303\200");
+ check_found_backward ("This is some foo foo text", "foo", flags, 17, 20, "foo");
+ check_found_backward ("This is some foo foo text", "Foo", flags, 17, 20, "foo");
+ check_found_backward ("This is some foo Foo text", "foo", flags, 17, 20, "Foo");
+ check_found_backward ("This is some \303\200 \303\240 text", "\303\240", flags, 15, 16, "\303\240");
+ check_found_backward ("This is some \303\200 \303\240 text", "\303\200", flags, 15, 16, "\303\240");
+ check_found_backward ("This is some \303\200 \303\240 text", "a\u0300", flags, 15, 16, "\303\240");
+
+ /* new lines in the haystack */
+ check_found_forward ("This is some\nfoo text", "foo", flags, 13, 16, "foo");
+ check_found_forward ("This is some\nfoo text", "Foo", flags, 13, 16, "foo");
+ check_found_forward ("This is some\nFoo text", "foo", flags, 13, 16, "Foo");
+ check_found_forward ("This is some\n\303\200 text", "\303\240", flags, 13, 14, "\303\200");
+ check_found_forward ("This is some\n\303\200 text", "a\u0300", flags, 13, 14, "\303\200");
+ check_found_backward ("This is some\nfoo text", "foo", flags, 13, 16, "foo");
+ check_found_backward ("This is some\nfoo text", "Foo", flags, 13, 16, "foo");
+ check_found_backward ("This is some\nFoo text", "foo", flags, 13, 16, "Foo");
+ check_found_backward ("This is some\n\303\200 text", "\303\240", flags, 13, 14, "\303\200");
+ check_found_backward ("This is some\n\303\200 text", "a\u0300", flags, 13, 14, "\303\200");
+ check_found_forward ("This is some foo\nfoo text", "foo", flags, 13, 16, "foo");
+ check_found_forward ("This is some foo\nfoo text", "Foo", flags, 13, 16, "foo");
+ check_found_forward ("This is some Foo\nfoo text", "foo", flags, 13, 16, "Foo");
+ check_found_forward ("This is some \303\200\n\303\200 text", "\303\240", flags, 13, 14, "\303\200");
+ check_found_forward ("This is some \303\200\n\303\200 text", "a\u0300", flags, 13, 14, "\303\200");
+ check_found_backward ("This is some foo\nfoo text", "foo", flags, 17, 20, "foo");
+ check_found_backward ("This is some foo\nfoo text", "Foo", flags, 17, 20, "foo");
+ check_found_backward ("This is some foo\nFoo text", "foo", flags, 17, 20, "Foo");
+ check_found_backward ("This is some \303\200\n\303\200 text", "\303\240", flags, 15, 16, "\303\200");
+ check_found_backward ("This is some \303\200\n\303\200 text", "a\u0300", flags, 15, 16, "\303\200");
+
+ /* end of buffer */
+ check_found_forward ("This is some\ntext foo", "foo", flags, 18, 21, "foo");
+ check_found_forward ("This is some\ntext foo", "Foo", flags, 18, 21, "foo");
+ check_found_forward ("This is some\ntext Foo", "foo", flags, 18, 21, "Foo");
+ check_found_forward ("This is some\ntext \303\200", "\303\240", flags, 18, 19, "\303\200");
+ check_found_forward ("This is some\ntext \303\200", "a\u0300", flags, 18, 19, "\303\200");
+ check_found_backward ("This is some\ntext foo", "foo", flags, 18, 21, "foo");
+ check_found_backward ("This is some\ntext foo", "Foo", flags, 18, 21, "foo");
+ check_found_backward ("This is some\ntext Foo", "foo", flags, 18, 21, "Foo");
+ check_found_backward ("This is some\ntext \303\200", "\303\240", flags, 18, 19, "\303\200");
+ check_found_backward ("This is some\ntext \303\200", "a\u0300", flags, 18, 19, "\303\200");
+
+ /* multiple lines in the needle */
+ check_found_forward ("This is some foo\nfoo text", "foo\nfoo", flags, 13, 20, "foo\nfoo");
+ check_found_forward ("This is some foo\nfoo text", "Foo\nFoo", flags, 13, 20, "foo\nfoo");
+ check_found_forward ("This is some Foo\nFoo text", "foo\nfoo", flags, 13, 20, "Foo\nFoo");
+ check_found_forward ("This is some \303\200\n\303\200 text", "\303\240\n\303\240", flags, 13, 16, "\303\200\n\303\200");
+ check_found_forward ("This is some \303\200\n\303\200 text", "a\u0300\na\u0300", flags, 13, 16, "\303\200\n\303\200");
+ check_found_backward ("This is some foo\nfoo text", "foo\nfoo", flags, 13, 20, "foo\nfoo");
+ check_found_backward ("This is some foo\nfoo text", "Foo\nFoo", flags, 13, 20, "foo\nfoo");
+ check_found_backward ("This is some Foo\nFoo text", "foo\nfoo", flags, 13, 20, "Foo\nFoo");
+ check_found_backward ("This is some \303\200\n\303\200 text", "\303\240\n\303\240", flags, 13, 16, "\303\200\n\303\200");
+ check_found_backward ("This is some \303\200\n\303\200 text", "a\u0300\na\u0300", flags, 13, 16, "\303\200\n\303\200");
+}
+
int
main (int argc, char** argv)
{
gtk_test_init (&argc, &argv);
g_test_add_func ("/TextIter/Search Empty", test_empty_search);
+ g_test_add_func ("/TextIter/Search Full Buffer", test_full_buffer);
g_test_add_func ("/TextIter/Search", test_search);
+ g_test_add_func ("/TextIter/Search Caseless", test_search_caseless);
return g_test_run();
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]