diff options
author | Not Zed <NotZed@HelixCode.com> | 2000-11-24 11:18:20 +0800 |
---|---|---|
committer | Michael Zucci <zucchi@src.gnome.org> | 2000-11-24 11:18:20 +0800 |
commit | 99e80d6ecf06cc60f2734f87bc974bd9479ba139 (patch) | |
tree | 84b8922548128a99dd89e2ecb96fba5f21d94f78 /camel/tests/lib/messages.c | |
parent | a7e18523ff09dd48a0aae229e1416c6d021dbb29 (diff) | |
download | gsoc2013-evolution-99e80d6ecf06cc60f2734f87bc974bd9479ba139.tar gsoc2013-evolution-99e80d6ecf06cc60f2734f87bc974bd9479ba139.tar.gz gsoc2013-evolution-99e80d6ecf06cc60f2734f87bc974bd9479ba139.tar.bz2 gsoc2013-evolution-99e80d6ecf06cc60f2734f87bc974bd9479ba139.tar.lz gsoc2013-evolution-99e80d6ecf06cc60f2734f87bc974bd9479ba139.tar.xz gsoc2013-evolution-99e80d6ecf06cc60f2734f87bc974bd9479ba139.tar.zst gsoc2013-evolution-99e80d6ecf06cc60f2734f87bc974bd9479ba139.zip |
Add tests.
2000-11-24 Not Zed <NotZed@HelixCode.com>
* Makefile.am (SUBDIRS): Add tests.
* camel-mime-filter-basic.c (filter): Well, I'll add the extra
bytes here too, lathough not strictly needed, might save a
re-malloc when we get to complete().
* camel-mime-filter-charset.c (filter): Make sure we have room if
we only convert very short data.
(complete): and here too.
* tests/Makefile.am: Initial test harness & tests. Requires gcc
for this.
* camel-internet-address.c (d): Turn off debug.
* camel-charset-map.c (camel_charset_step): Oops, & masks for set
intersection, not | them. Dunno how this got even close to
working.
2000-11-23 Not Zed <NotZed@HelixCode.com>
* camel-mime-filter-basic.c (filter): For base64 encoding, the
output size for 0, 1, or 2 bytes of input can exceed input*2, so
make sure we account for that as well.
(complete): And here.
(complete): Similarly for qp encoding, if we have a trailing
space, we need some extra bytes (not needed for 'filter()', as any
such bytes are stored in state/save).
* camel-mime-utils.c (quoted_decode_step): Removed fixme not required.
(quoted_encode_close): Dont append a trailing afterall. Otherwise
a pass through the encode/decode will grow the message each time.
svn path=/trunk/; revision=6656
Diffstat (limited to 'camel/tests/lib/messages.c')
-rw-r--r-- | camel/tests/lib/messages.c | 145 |
1 files changed, 145 insertions, 0 deletions
diff --git a/camel/tests/lib/messages.c b/camel/tests/lib/messages.c new file mode 100644 index 0000000000..e2e447d97c --- /dev/null +++ b/camel/tests/lib/messages.c @@ -0,0 +1,145 @@ + + +#include "messages.h" +#include "camel-test.h" + +#include <camel/camel-mime-message.h> +#include <camel/camel-stream-fs.h> +#include <camel/camel-stream-mem.h> + +CamelMimeMessage * +test_message_create_simple(void) +{ + CamelMimeMessage *msg; + CamelInternetAddress *addr; + + msg = camel_mime_message_new(); + + addr = camel_internet_address_new(); + camel_internet_address_add(addr, "Michael Zucchi", "zed@nowhere.com"); + camel_mime_message_set_from(msg, addr); + camel_address_remove((CamelAddress *)addr, -1); + camel_internet_address_add(addr, "POSTMASTER", "POSTMASTER@somewhere.net"); + camel_mime_message_set_recipients(msg, CAMEL_RECIPIENT_TYPE_TO, addr); + camel_address_remove((CamelAddress *)addr, -1); + camel_internet_address_add(addr, "Michael Zucchi", "zed@nowhere.com"); + camel_mime_message_set_recipients(msg, CAMEL_RECIPIENT_TYPE_CC, addr); + + check_unref(addr, 1); + + camel_mime_message_set_subject(msg, "Simple message subject"); + camel_mime_message_set_date(msg, time(0), 930); + + return msg; +} + +void +test_message_set_content_simple(CamelMimePart *part, int how, const char *type, const char *text, int len) +{ + CamelStreamMem *content = NULL; + CamelDataWrapper *dw; + static GByteArray *ba; + + switch (how) { + case 0: + camel_mime_part_set_content(part, text, len, type); + break; + case 1: + content = (CamelStreamMem *)camel_stream_mem_new_with_buffer(text, len); + break; + case 2: + content = (CamelStreamMem *)camel_stream_mem_new(); + camel_stream_mem_set_buffer(content, text, len); + break; + case 3: + ba = g_byte_array_new(); + g_byte_array_append(ba, text, len); + + content = (CamelStreamMem *)camel_stream_mem_new_with_byte_array(ba); + ba = NULL; + break; + case 4: + ba = g_byte_array_new(); + g_byte_array_append(ba, text, len); + + content = (CamelStreamMem *)camel_stream_mem_new(); + camel_stream_mem_set_byte_array(content, ba); + + /* ba gets leaked here */ + break; + } + + if (content != 0) { + dw = camel_data_wrapper_new(); + camel_data_wrapper_set_mime_type (dw, type); + + camel_data_wrapper_construct_from_stream(dw, (CamelStream *)content); + camel_medium_set_content_object((CamelMedium *)part, dw); + + check_unref(content, 2); + check_unref(dw, 2); + } +} + +int +test_message_write_file(CamelMimeMessage *msg, const char *name) +{ + CamelStreamFs *file; + int ret; + + file = (CamelStreamFs *)camel_stream_fs_new_with_name(name, O_CREAT|O_WRONLY, 0600); + camel_data_wrapper_write_to_stream((CamelDataWrapper *)msg, (CamelStream *)file); + ret = camel_stream_close((CamelStream *)file); + + check(((CamelObject *)file)->ref_count == 1); + camel_object_unref((CamelObject *)file); + + return ret; +} + +CamelMimeMessage * +test_message_read_file(const char *name) +{ + CamelStreamFs *file; + CamelMimeMessage *msg2; + + file = (CamelStreamFs *)camel_stream_fs_new_with_name(name, O_RDONLY, 0); + msg2 = camel_mime_message_new(); + + camel_data_wrapper_construct_from_stream((CamelDataWrapper *)msg2, (CamelStream *)file); + /* file's refcount may be > 1 if the message is real big */ + check(CAMEL_OBJECT(file)->ref_count >=1); + + return msg2; +} + +int +test_message_compare_content(CamelDataWrapper *dw, const char *text, int len) +{ + CamelStreamMem *content; + + /* sigh, ok, so i len == 0, dw will probably be 0 too + camel_mime_part_set_content is weird like that */ + if (dw == 0 && len == 0) + return 0; + + content = (CamelStreamMem *)camel_stream_mem_new(); + camel_data_wrapper_write_to_stream(dw, (CamelStream *)content); + + check_msg(content->buffer->len == len, "buffer->len = %d, len = %d", content->buffer->len, len); + check_msg(memcmp(content->buffer->data, text, content->buffer->len) == 0, "len = %d", len); + + check_unref(content, 1); + + return 0; +} + +int +test_message_compare_header(CamelMimeMessage *m1, CamelMimeMessage *m2) +{ +} + +int +test_message_compare_messages(CamelMimeMessage *m1, CamelMimeMessage *m2) +{ +} |