/* * 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. * * 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, see . * */ #include "evolution-data-server-config.h" #include #include #include #include #include #include "camel-test.h" /* TODO: should put utf8 stuff here too */ static struct { const gchar *word; gint count; struct { const gchar *word; gint type; } splits[5]; } split_tests[] = { { "simple", 1, { { "simple", CAMEL_SEARCH_WORD_SIMPLE } } }, { "two words", 2, { { "two", CAMEL_SEARCH_WORD_SIMPLE }, {"words" , CAMEL_SEARCH_WORD_SIMPLE } } }, { "compl;ex", 1, { { "compl;ex", CAMEL_SEARCH_WORD_COMPLEX } } }, { "compl;ex simple", 2, { { "compl;ex", CAMEL_SEARCH_WORD_COMPLEX} , {"simple", CAMEL_SEARCH_WORD_SIMPLE} } }, { "\"quoted\"", 1, { { "quoted", CAMEL_SEARCH_WORD_SIMPLE } } }, { "\"quoted double\"", 1, { { "quoted double", CAMEL_SEARCH_WORD_COMPLEX } } }, { "\"quoted double\" compl;ex", 2, { { "quoted double", CAMEL_SEARCH_WORD_COMPLEX }, { "compl;ex", CAMEL_SEARCH_WORD_COMPLEX } } }, { "\"quoted gdouble \\\" escaped\"", 1, { { "quoted gdouble \" escaped", CAMEL_SEARCH_WORD_COMPLEX } } }, { "\"quoted\\\"double\" \\\" escaped\\\"", 3, { { "quoted\"double", CAMEL_SEARCH_WORD_COMPLEX }, {"\"", CAMEL_SEARCH_WORD_COMPLEX}, { "escaped\"", CAMEL_SEARCH_WORD_COMPLEX } } }, { "\\\"escaped", 1, { { "\"escaped", CAMEL_SEARCH_WORD_COMPLEX } } }, }; static struct { const gchar *word; gint count; struct { const gchar *word; gint type; } splits[5]; } simple_tests[] = { { "simple", 1, { {"simple", CAMEL_SEARCH_WORD_SIMPLE } } }, { "simpleCaSe", 1, { { "simplecase", CAMEL_SEARCH_WORD_SIMPLE } } }, { "two words", 2, { { "two", CAMEL_SEARCH_WORD_SIMPLE }, { "words", CAMEL_SEARCH_WORD_SIMPLE } } }, { "two wordscAsE", 2, { { "two", CAMEL_SEARCH_WORD_SIMPLE} , { "wordscase", CAMEL_SEARCH_WORD_SIMPLE } } }, { "compl;ex", 2, { { "compl", CAMEL_SEARCH_WORD_SIMPLE }, { "ex", CAMEL_SEARCH_WORD_SIMPLE } } }, { "compl;ex simple", 3, { { "compl", CAMEL_SEARCH_WORD_SIMPLE }, { "ex", CAMEL_SEARCH_WORD_SIMPLE }, { "simple", CAMEL_SEARCH_WORD_SIMPLE } } }, { "\"quoted compl;ex\" simple", 4, { { "quoted", CAMEL_SEARCH_WORD_SIMPLE}, { "compl", CAMEL_SEARCH_WORD_SIMPLE }, { "ex", CAMEL_SEARCH_WORD_SIMPLE }, { "simple", CAMEL_SEARCH_WORD_SIMPLE } } }, { "\\\" \"quoted\"compl;ex\" simple", 4, { { "quoted", CAMEL_SEARCH_WORD_SIMPLE}, { "compl", CAMEL_SEARCH_WORD_SIMPLE }, { "ex", CAMEL_SEARCH_WORD_SIMPLE }, { "simple", CAMEL_SEARCH_WORD_SIMPLE } } }, }; gint main (gint argc, gchar **argv) { gint i, j; struct _camel_search_words *words, *tmp; camel_test_init (argc, argv); camel_test_start ("Search splitting"); for (i = 0; i < G_N_ELEMENTS (split_tests); i++) { camel_test_push ("split %d '%s'", i, split_tests[i].word); words = camel_search_words_split ((const guchar *) split_tests[i].word); check (words != NULL); check_msg (words->len == split_tests[i].count, "words->len = %d, count = %d", words->len, split_tests[i].count); for (j = 0; j < words->len; j++) { check_msg ( strcmp (split_tests[i].splits[j].word, words->words[j]->word) == 0, "'%s' != '%s'", split_tests[i].splits[j].word, words->words[j]->word); check (split_tests[i].splits[j].type == words->words[j]->type); } camel_search_words_free (words); camel_test_pull (); } camel_test_end (); camel_test_start ("Search splitting - simple"); for (i = 0; i < G_N_ELEMENTS (simple_tests); i++) { camel_test_push ("simple split %d '%s'", i, simple_tests[i].word); tmp = camel_search_words_split ((const guchar *) simple_tests[i].word); check (tmp != NULL); words = camel_search_words_simple (tmp); check (words != NULL); check_msg (words->len == simple_tests[i].count, "words->len = %d, count = %d", words->len, simple_tests[i].count); for (j = 0; j < words->len; j++) { check_msg ( strcmp (simple_tests[i].splits[j].word, words->words[j]->word) == 0, "'%s' != '%s'", simple_tests[i].splits[j].word, words->words[j]->word); check (simple_tests[i].splits[j].type == words->words[j]->type); } camel_search_words_free (words); camel_search_words_free (tmp); camel_test_pull (); } camel_test_end (); return 0; }