X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~mdw/git/disorder/blobdiff_plain/121f51ac44276ce2744e91bc589e9dc78d3ffd3b..0e2b222fc14b8f890fab644118cf0f43abbe450a:/lib/t-mime.c diff --git a/lib/t-mime.c b/lib/t-mime.c index 05ae8b5..7f56c5d 100644 --- a/lib/t-mime.c +++ b/lib/t-mime.c @@ -34,15 +34,13 @@ static int header_callback(const char *name, const char *value, return 0; } -void test_mime(void) { +static void test_mime(void) { char *t, *n, *v; struct vector parts[1]; struct kvp *k; - const char *s; + const char *s, *cs, *enc; hash *h; - fprintf(stderr, "test_mime\n"); - t = 0; k = 0; insist(!mime_content_type("text/plain", &t, &k)); @@ -191,7 +189,37 @@ void test_mime(void) { "Content-Description: jpeg-1\r\n" "\r\n" ""); - + + /* Bogus inputs to mime_multipart() */ + fprintf(stderr, "expect two mime_multipart errors:\n"); + insist(mime_multipart("--inner\r\n" + "Content-Type: text/plain\r\n" + "Content-Disposition: inline\r\n" + "Content-Description: text-part-2\r\n" + "\r\n" + "Some more text here.\r\n" + "\r\n" + "--inner\r\n" + "Content-Type: image/jpeg\r\n" + "Content-Disposition: attachment\r\n" + "Content-Description: jpeg-1\r\n" + "\r\n" + "\r\n", + test_multipart_callback, + "inner", + parts) == -1); + insist(mime_multipart("--wrong\r\n" + "Content-Type: text/plain\r\n" + "Content-Disposition: inline\r\n" + "Content-Description: text-part-2\r\n" + "\r\n" + "Some more text here.\r\n" + "\r\n" + "--inner--\r\n", + test_multipart_callback, + "inner", + parts) == -1); + /* XXX mime_parse */ check_string(mime_qp(""), ""); @@ -220,7 +248,9 @@ void test_mime(void) { "Now's the time for all folk to come to the aid of their country."); #define check_base64(encoded, decoded) do { \ - check_string(mime_base64(encoded, 0), decoded); \ + size_t ns; \ + check_string(mime_base64(encoded, &ns), decoded); \ + insist(ns == (sizeof decoded) - 1); \ check_string(mime_to_base64((const uint8_t *)decoded, \ (sizeof decoded) - 1), \ encoded); \ @@ -308,8 +338,35 @@ void test_mime(void) { check_string(*(char **)hash_find(h, "content-type"), "text/plain"); check_string(*(char **)hash_find(h, "content-transfer-encoding"), "BASE64"); check_string(s, "wibble\r\n"); + +#define CHECK_QUOTE(INPUT, EXPECT) do { \ + s = quote822(INPUT, 0); \ + insist(s != 0); \ + check_string(s, EXPECT); \ + s = mime_parse_word(s, &t, mime_http_separator); \ + check_string(t, INPUT); \ +} while(0) + CHECK_QUOTE("wibble", "wibble"); + CHECK_QUOTE("wibble spong", "\"wibble spong\""); + CHECK_QUOTE("wibble\\spong", "\"wibble\\\\spong\""); + CHECK_QUOTE("wibble\"spong", "\"wibble\\\"spong\""); + CHECK_QUOTE("(wibble)", "\"(wibble)\""); + + s = mime_encode_text("wibble\n", &cs, &enc); + insist(s != 0); + check_string(s, "wibble\n"); + check_string(cs, "us-ascii"); + check_string(enc, "7bit"); + + s = mime_encode_text("wibble\xC3\xB7\n", &cs, &enc); + insist(s != 0); + check_string(s, "wibble=C3=B7\n"); + check_string(cs, "utf-8"); + check_string(enc, "quoted-printable"); } +TEST(mime); + /* Local Variables: c-basic-offset:2