]> code.citadel.org Git - citadel.git/blobdiff - libcitadel/tests/stringbuf_conversion.c
* add StrBufSanitizeEmailRecipientVector(); it will qp encode plain names with utf...
[citadel.git] / libcitadel / tests / stringbuf_conversion.c
index a6c08a98408637ac36591e16692cfc3d05ee1cc8..e2841624219376af3479fca21e4a607ff2beb6fc 100644 (file)
 #include <stdio.h>
 #include <stdlib.h>
 #include <string.h>
+#include <stdio.h>
+#include <unistd.h>
 
 #include "stringbuf_test.h"
 #include "../lib/libcitadel.h"
 
 
+int fromstdin = 0;
+int parse_email = 0;
 static void TestRevalidateStrBuf(StrBuf *Buf)
 {
        CU_ASSERT(strlen(ChrPtr(Buf)) == StrLength(Buf));
@@ -84,6 +88,117 @@ static void TestRFC822Decode(void)
        FreeStrBuf(&Target);
        FreeStrBuf(&FoundCharset);
        FreeStrBuf(&DefaultCharset);
+
+
+       DefaultCharset = NewStrBufPlain(HKEY("iso-8859-1"));
+       FoundCharset = NewStrBuf();
+       Source = NewStrBufPlain(HKEY("\"w.goesgens\" <w.goesgens@aoeuaoeuaoeu.org>, =?ISO-8859-15?Q?Walter_?= =?ISO-8859-15?Q?G=F6aoeus?= <aoeuaoeu@aoe.de>, =?ISO-8859-15?Q?aoeuaoeuh?= =?ISO-8859-15?Q?_G=F6aoeus?= <aoeuoeuaoeu@oeu.de>, aoeuao aoeuaoeu <aoeuaoeuaoeaoe@aoe.de"));
+       Target = NewStrBufPlain(NULL, 256);
+
+       StrBuf_RFC822_to_Utf8(Target, Source, DefaultCharset, FoundCharset);
+       TestRevalidateStrBuf(Target);
+       printf("the ugly multi:>%s<\n", ChrPtr(Target));
+       FreeStrBuf(&Source);
+       FreeStrBuf(&Target);
+       FreeStrBuf(&FoundCharset);
+       FreeStrBuf(&DefaultCharset);
+
+}
+
+
+static void TestRFC822DecodeStdin(void)
+{
+       int fdin = 0;// STDIN
+       const char *Err;
+       StrBuf *Target;
+       StrBuf *Source;
+       StrBuf *DefaultCharset;
+       StrBuf *FoundCharset;
+       
+       DefaultCharset = NewStrBufPlain(HKEY("iso-8859-1"));
+       FoundCharset = NewStrBuf();
+       Source = NewStrBuf();
+
+       while (fdin == 0) {
+
+               StrBufTCP_read_line(Source, &fdin, 0, &Err);
+               Target = NewStrBuf();
+               
+               StrBuf_RFC822_to_Utf8(Target, Source, DefaultCharset, FoundCharset);
+               
+               TestRevalidateStrBuf(Target);
+               printf("the ugly multi:>%s<\n", ChrPtr(Target));
+               FreeStrBuf(&Target);
+       }
+       FreeStrBuf(&Source);
+       FreeStrBuf(&FoundCharset);
+       FreeStrBuf(&DefaultCharset);
+}
+
+
+static void TestEncodeEmail(void)
+{
+       StrBuf *Target;
+       StrBuf *Source;
+       StrBuf *UserName = NewStrBuf();
+       StrBuf *EmailAddress = NewStrBuf();
+       StrBuf *EncBuf = NewStrBuf();
+       
+       Source = NewStrBuf();
+//     Source = NewStrBufPlain(HKEY("Art Cancro <ajc@uncensored.citadel.org>, Art Cancro <ajc@uncensored.citadel.org>"));
+
+       Source = NewStrBufPlain(HKEY("\"Alexandra Weiz, Restless GmbH\" <alexandra.weiz@boblbee.de>, \"NetIN\" <editor@netin.co.il>, \" יריב ברקאי, מולטימדי\" <info@immembed.com>")); 
+       Target = StrBufSanitizeEmailRecipientVector(
+               Source,
+               UserName, 
+               EmailAddress,
+               EncBuf
+               );              
+       
+       TestRevalidateStrBuf(Target);
+       printf("the source:>%s<\n", ChrPtr(Source));
+       printf("the target:>%s<\n", ChrPtr(Target));
+       FreeStrBuf(&Target);
+       FreeStrBuf(&UserName);
+       FreeStrBuf(&EmailAddress);
+       FreeStrBuf(&EncBuf);
+
+       FreeStrBuf(&Source);
+}
+
+static void TestEncodeEmailSTDIN(void)
+{
+       int fdin = 0;// STDIN
+       const char *Err;
+       StrBuf *Target;
+       StrBuf *Source;
+       StrBuf *UserName = NewStrBuf();
+       StrBuf *EmailAddress = NewStrBuf();
+       StrBuf *EncBuf = NewStrBuf();
+       
+       Source = NewStrBuf();
+
+       while (fdin == 0) {
+
+               StrBufTCP_read_line(Source, &fdin, 0, &Err);
+               printf("the source:>%s<\n", ChrPtr(Source));
+               Target = StrBufSanitizeEmailRecipientVector(
+                       Source,
+                       UserName, 
+                       EmailAddress,
+                       EncBuf
+                       );
+               
+               TestRevalidateStrBuf(Target);
+               printf("the target:>%s<\n", ChrPtr(Target));
+               FreeStrBuf(&Target);
+       }
+       FreeStrBuf(&UserName);
+       FreeStrBuf(&EmailAddress);
+       FreeStrBuf(&EncBuf);
+
+       FreeStrBuf(&Source);
 }
 
 
@@ -94,14 +209,43 @@ static void AddStrBufSimlpeTests(void)
        CU_pTest pTest = NULL;
 
        pGroup = CU_add_suite("TestStringBufConversions", NULL, NULL);
-       pTest = CU_add_test(pGroup, "testRFC822Decode", TestRFC822Decode);
-
+       if (!parse_email) {
+               if (!fromstdin) {
+                       pTest = CU_add_test(pGroup, "testRFC822Decode", TestRFC822Decode);
+                       pTest = CU_add_test(pGroup, "testRFC822Decode1", TestRFC822Decode);
+                       pTest = CU_add_test(pGroup, "testRFC822Decode2", TestRFC822Decode);
+                       pTest = CU_add_test(pGroup, "testRFC822Decode3", TestRFC822Decode);
+               }
+               else
+                       pTest = CU_add_test(pGroup, "testRFC822DecodeSTDIN", TestRFC822DecodeStdin);
+       }
+       else {
+               if (!fromstdin) {
+                       pTest = CU_add_test(pGroup, "TestParseEmailSTDIN", TestEncodeEmail);
+               }
+               else
+                       pTest = CU_add_test(pGroup, "TestParseEmailSTDIN", TestEncodeEmailSTDIN);
+       }
 
 }
 
 
 int main(int argc, char* argv[])
 {
+       int a;
+
+       while ((a = getopt(argc, argv, "@i")) != EOF)
+               switch (a) {
+               case '@':
+                       parse_email = 1;
+                       break;
+               case 'i':
+                       fromstdin = 1;
+                       
+                       break;
+               }
+
+
        setvbuf(stdout, NULL, _IONBF, 0);
 
        StartLibCitadel(8);
@@ -117,9 +261,9 @@ int main(int argc, char* argv[])
        
        if (CU_TRUE == Run) {
                //CU_console_run_tests();
-    printf("\nTests completed with return value %d.\n", CU_basic_run_tests());
+               printf("\nTests completed with return value %d.\n", CU_basic_run_tests());
     
-    ///CU_automated_run_tests();
+               ///CU_automated_run_tests();
        }
        
        CU_cleanup_registry();