From 4f5effdf884b53299fb85bf344ccd5441f01d7fe Mon Sep 17 00:00:00 2001 From: Michael Zucci Date: Wed, 17 Jan 2001 01:07:02 +0000 Subject: Index: ChangeLog Index: ChangeLog =================================================================== RCS file: /cvs/gnome/evolution/camel/ChangeLog,v retrieving revision 1.684 diff -r1.684 ChangeLog 0a1,34 > 2001-01-17 Not Zed > > * camel-folder.c (free_summary): Call > camel_folder_summary_array_free() to do the work. > (get_summary): Use camel_folder_summary_array() to get the array > atomically. These fixes allow folder/test8 to work again, and fix > a sort of race where the summary size can change while we were > making a copy of it. > > * camel-folder-summary.c (camel_folder_summary_array): Get the > summary array atomically, so it can't contain empty records. > (camel_folder_summary_array_free): And free it. > > * tests/lib/camel-test.c (die): If we are verbose & in threads, > then goto sleep so we can debug. > > * tests/folder/test8.c (worker): Add a missing pull() for > comnparing content. > > * camel-filter-search.c: Fix the symbol table, so match-all is an > immediate function, as it should be. > > * tests/folder/test9.c (main): New test, tests some filtering > things. > > * tests/message/test3.c (main): Dont use a boundary string with > spaces in it. Folding can corrupt it. Maybe the folding isn't > working entirely right, but anyway. > > * camel-session.c: Debug out the debug. > > * camel-filter-driver.c (camel_filter_driver_filter_folder): Plug > a messageinfo leak. > 1a36,94 > > * camel-filter-search.c (header_exists): Changed to support > multiple args (or'd together). > (header_contains): Cleaned up to match the search code. Why did > fejj change it? I'll never know. > (header_matches): > (header_starts_with): > (header_ends_with): Big cleanup of fejj's "i'm the cut & paste > king" code. Also properly handle or'ing of additional args to > match what the folder-search code should do. > (check_match): New function which does the annoying matching > stuff (for header matches). > (check_header): Similarly, handles or'ing of the matches together. > (header_contains): > (header_matches): > (header_starts_with): > (header_ends_with): Call check_header to do the actual work. > (header_soundex): And here too. > (match_all): Yeah like match-all isn't passed expression results, > its passed expression terms. Fix this so match-all works like it > should, by executing the contained expression. > (message_body_contains): Copied directly from > camel-folder-search.c, a more robust/faster/simpler body search > code. > (mime_part_matches): Removed entirely. > (handle_multipart): Removed entirely. > (build_match_regex): Copied from camel-folder-search. Builds a > set of simple strings into a regex pattern that matches any of > them (for faster & simpler matching). Expanded to accept regex > patterns itself, so it can merge them together. > (body_contains): Use build match/match message to match using a > built regex. > (body_regex): Likewise, this time we tell it we're building a > regex though. > (header_full_regex): Use build_match_regex to take the drudgery > out of it, and expand it to handle multiple regex's at once. > (get_full_header): slightly cleaner (well i dunno, the sprintf > stuff just got to me). > (header_regex): Cleaned up to use build_match_Regex too, and to > properly check types. > (filter_message_search): Just allocate 'fms' on the stack. > > * camel-filter-driver.c (camel_filter_driver_finalise): > (camel_filter_driver_init): > (camel_filter_driver_class_init): > (camel_filter_driver_get_type): Changed from gtk object to camel > object. > (camel_filter_driver_add_rule): New function to add a rule to be > processed in sexp form. > (camel_filter_driver_init): Init the rules list. > (camel_filter_driver_finalise): Clear the rules/rules list. > (camel_filter_driver_filter_message): Scan rules list directly > rather than creating on the fly. > > * Makefile.am (libcamelinclude_HEADERS): Added camel-filter-driver.h > (libcamel_la_SOURCES): Added camel-filter-driver.c, code taken > from filter-driver, which can drive, uh, filters based on sexp's. > (libcamelinclude_HEADERS): > (libcamel_la_SOURCES): Added camel-filter-search.[ch] svn path=/trunk/; revision=7560 --- camel/tests/folder/Makefile.am | 6 +- camel/tests/folder/README | 2 +- camel/tests/folder/test8.c | 1 + camel/tests/folder/test9.c | 176 +++++++++++++++++++++++++++++++++++++++++ camel/tests/lib/camel-test.c | 8 ++ camel/tests/message/test3.c | 10 +-- 6 files changed, 195 insertions(+), 8 deletions(-) create mode 100644 camel/tests/folder/test9.c (limited to 'camel/tests') diff --git a/camel/tests/folder/Makefile.am b/camel/tests/folder/Makefile.am index 4401d310f6..f6dd852dd8 100644 --- a/camel/tests/folder/Makefile.am +++ b/camel/tests/folder/Makefile.am @@ -16,12 +16,14 @@ check_PROGRAMS = \ test1 test4 test5 \ test2 test6 test7 \ test3 \ - test8 + test8 \ + test9 TESTS = test1 test4 test5 \ test2 test6 test7 \ test3 \ - test8 + test8 \ + test9 diff --git a/camel/tests/folder/README b/camel/tests/folder/README index e02308d2d7..4fed421413 100644 --- a/camel/tests/folder/README +++ b/camel/tests/folder/README @@ -8,4 +8,4 @@ test6 basic folder operations, IMAP test7 basic folder operations, NNTP test8 multithreaded folder torture test, local - +test9 filtering diff --git a/camel/tests/folder/test8.c b/camel/tests/folder/test8.c index 30552cf782..5665f96f2a 100644 --- a/camel/tests/folder/test8.c +++ b/camel/tests/folder/test8.c @@ -107,6 +107,7 @@ worker(void *d) content = g_strdup_printf("Test message %d contents\n\n", id+i); test_message_compare_content(camel_medium_get_content_object((CamelMedium *)msg), content, strlen(content)); test_free(content); + pull(); push("deleting message, cleanup"); j=(100.0*rand()/(RAND_MAX+1.0)); diff --git a/camel/tests/folder/test9.c b/camel/tests/folder/test9.c new file mode 100644 index 0000000000..68c761c40d --- /dev/null +++ b/camel/tests/folder/test9.c @@ -0,0 +1,176 @@ +/* folder/index testing */ + +#include "camel-test.h" +#include "messages.h" +#include "folders.h" + +#include "camel/camel-exception.h" +#include "camel/camel-service.h" +#include "camel/camel-session.h" +#include "camel/camel-store.h" + +#include "camel/camel-folder.h" +#include "camel/camel-folder-summary.h" +#include "camel/camel-mime-message.h" +#include "camel/camel-filter-driver.h" +#include "camel/camel-stream-fs.h" + +#define ARRAY_LEN(x) (sizeof(x)/sizeof(x[0])) + + +/* god, who designed this horrid interface */ +static char *auth_callback(CamelAuthCallbackMode mode, + char *data, gboolean secret, + CamelService *service, char *item, + CamelException *ex) +{ + return NULL; +} + +struct { + char *name; + CamelFolder *folder; +} mailboxes[] = { + { "INBOX", NULL }, + { "folder1", NULL }, + { "folder2", NULL }, + { "folder3", NULL }, + { "folder4", NULL }, +}; + +struct { + char *name, *match, *action; +} rules[] = { + { "empty1", "(match-all (header-contains \"Frobnitz\"))", "(copy-to \"folder1\")" }, + { "empty2", "(header-contains \"Frobnitz\")", "(copy-to \"folder2\")" }, + { "count11", "(and (header-contains \"subject\" \"Test1\") (header-contains \"subject\" \"subject\"))", "(move-to \"folder3\")" }, + { "empty3", "(and (header-contains \"subject\" \"Test1\") (header-contains \"subject\" \"subject\"))", "(move-to \"folder4\")" }, + { "count1", "(body-contains \"data50\")", "(copy-to \"folder1\")" }, + { "stop", "(body-contains \"data2\")", "(stop)" }, + { "notreached1", "(body-contains \"data2\")", "(move-to \"folder2\")" }, + { "count1", "(body-contains \"data3\")", "(move-to \"folder2\")" }, +}; + + +static CamelFolder *get_folder(CamelFilterDriver *d, const char *uri, void *data) +{ + int i; + + for (i=0;i +#include #endif #ifdef ENABLE_THREADS @@ -74,6 +75,13 @@ static void die(int sig) indie = 1; printf("\n\nReceived fatal signal %d\n", sig); g_hash_table_foreach(info_table, (GHFunc)dump_action, 0); + +#ifdef ENABLE_THREADS + if (camel_test_verbose > 2) { + printf("Attach debugger to pid %d to debug\n", getpid()); + sleep(1000); + } +#endif } _exit(1); diff --git a/camel/tests/message/test3.c b/camel/tests/message/test3.c index 78ac7b3042..0a9683d146 100644 --- a/camel/tests/message/test3.c +++ b/camel/tests/message/test3.c @@ -30,8 +30,8 @@ int main(int argc, char **argv) mp = camel_multipart_new(); /* Hrm, this should be able to set its own boundary, no? */ - camel_multipart_set_boundary(mp, "_=,.XYZ Kangaroo Meat is ! ABADF00D"); - check(strcmp(camel_multipart_get_boundary(mp), "_=,.XYZ Kangaroo Meat is ! ABADF00D") == 0); + camel_multipart_set_boundary(mp, "_=,.XYZ_Kangaroo_Meat_is_!_ABADF00D"); + check(strcmp(camel_multipart_get_boundary(mp), "_=,.XYZ_Kangaroo_Meat_is_!_ABADF00D") == 0); camel_medium_set_content_object((CamelMedium *)msg, (CamelDataWrapper *)mp); check(camel_multipart_get_number(mp) == 0); @@ -110,7 +110,7 @@ int main(int argc, char **argv) check(CAMEL_IS_MULTIPART(mp2)); check(camel_multipart_get_number(mp2) == 3); - check(strcmp(camel_multipart_get_boundary(mp2), "_=,.XYZ Kangaroo Meat is ! ABADF00D") == 0); + check(strcmp(camel_multipart_get_boundary(mp2), "_=,.XYZ_Kangaroo_Meat_is_!_ABADF00D") == 0); check(mp2->preface == NULL || strlen(mp2->preface) == 0); /* FIXME */ @@ -137,7 +137,7 @@ int main(int argc, char **argv) check(CAMEL_IS_MULTIPART(mp2)); check(camel_multipart_get_number(mp2) == 3); - check(strcmp(camel_multipart_get_boundary(mp2), "_=,.XYZ Kangaroo Meat is ! ABADF00D") == 0); + check(strcmp(camel_multipart_get_boundary(mp2), "_=,.XYZ_Kangaroo_Meat_is_!_ABADF00D") == 0); check(mp2->preface == NULL || strlen(mp2->preface) == 0); /* FIXME */ @@ -174,7 +174,7 @@ int main(int argc, char **argv) check(CAMEL_IS_MULTIPART(mp2)); check(camel_multipart_get_number(mp2) == 3); - check(strcmp(camel_multipart_get_boundary(mp2), "_=,.XYZ Kangaroo Meat is ! ABADF00D") == 0); + check(strcmp(camel_multipart_get_boundary(mp2), "_=,.XYZ_Kangaroo_Meat_is_!_ABADF00D") == 0); check(strcmp(mp2->preface, "pre-text\nLines.") == 0); check(strcmp(mp2->postface, "post-text, no lines.\nOne line.\n") == 0); test_message_compare_content(camel_medium_get_content_object(CAMEL_MEDIUM(camel_multipart_get_part(mp2, 0))), -- cgit v1.2.3