]> code.citadel.org Git - citadel.git/blobdiff - libcitadel/tests/stringbuf_conversion.c
fixing html2ascii
[citadel.git] / libcitadel / tests / stringbuf_conversion.c
index e2841624219376af3479fca21e4a607ff2beb6fc..a554c82618f5858fe2285e819c66d4c8fe4911d3 100644 (file)
@@ -30,6 +30,7 @@
 
 int fromstdin = 0;
 int parse_email = 0;
+int parse_html = 0;
 static void TestRevalidateStrBuf(StrBuf *Buf)
 {
        CU_ASSERT(strlen(ChrPtr(Buf)) == StrLength(Buf));
@@ -202,6 +203,29 @@ static void TestEncodeEmailSTDIN(void)
 }
 
 
+static void TestHTML2ASCII_line(void)
+{
+       int fdin = 0;// STDIN
+       const char *Err;
+       StrBuf *Source;
+       char *Target;
+
+       Source = NewStrBuf();
+
+       while (fdin == 0) {
+               
+               StrBufTCP_read_line(Source, &fdin, 0, &Err);
+               printf("the source:>%s<\n", ChrPtr(Source));
+               Target = html_to_ascii(ChrPtr(Source), StrLength(Source), 80, 0);
+               
+               printf("the target:>%s<\n", Target);
+               FlushStrBuf(Source);
+               free(Target);
+       }
+
+       FreeStrBuf(&Source);
+}
+
 
 static void AddStrBufSimlpeTests(void)
 {
@@ -209,22 +233,25 @@ static void AddStrBufSimlpeTests(void)
        CU_pTest pTest = NULL;
 
        pGroup = CU_add_suite("TestStringBufConversions", NULL, NULL);
-       if (!parse_email) {
+       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);
+                       pTest = CU_add_test(pGroup, "TestParseEmailSTDIN", TestEncodeEmail);
                }
                else
-                       pTest = CU_add_test(pGroup, "testRFC822DecodeSTDIN", TestRFC822DecodeStdin);
+                       pTest = CU_add_test(pGroup, "TestParseEmailSTDIN", TestEncodeEmailSTDIN);
+       }
+       else if (parse_html) {
+                       pTest = CU_add_test(pGroup, "TestParseHTMLSTDIN", TestHTML2ASCII_line);
        }
        else {
                if (!fromstdin) {
-                       pTest = CU_add_test(pGroup, "TestParseEmailSTDIN", TestEncodeEmail);
+                       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, "TestParseEmailSTDIN", TestEncodeEmailSTDIN);
+                       pTest = CU_add_test(pGroup, "testRFC822DecodeSTDIN", TestRFC822DecodeStdin);
        }
 
 }
@@ -234,8 +261,11 @@ int main(int argc, char* argv[])
 {
        int a;
 
-       while ((a = getopt(argc, argv, "@i")) != EOF)
+       while ((a = getopt(argc, argv, "@ih")) != EOF)
                switch (a) {
+               case 'h':
+                       parse_html = 1;
+                       break;
                case '@':
                        parse_email = 1;
                        break;