From 581ea7c8d39c9de73282b21de16dd9b0192ec5ac Mon Sep 17 00:00:00 2001 From: Carl Worth Date: Sat, 6 Nov 2010 11:25:56 -0700 Subject: [PATCH] test: Add test for saving an attachment from emacs This tests the use of "notmuch cat" recently added to the emacs interface. --- test/emacs | 6 +++++ test/emacs.expected-output/attachment | 32 +++++++++++++++++++++++++++ 2 files changed, 38 insertions(+) create mode 100644 test/emacs.expected-output/attachment diff --git a/test/emacs b/test/emacs index 620de548..096fa017 100755 --- a/test/emacs +++ b/test/emacs @@ -112,4 +112,10 @@ Fcc: $(pwd)/mail/sent On Fri, 29 Mar 1974 10:00:00 -0000, Notmuch Test Suite wrote: > This is a test that messages are sent via SMTP" +test_begin_subtest "Save attachment from within emacs" +echo "./attachment" | test_emacs '(notmuch-show "id:cf0c4d610911171136h1713aa59w9cf9aa31f052ad0a@mail.gmail.com") (notmuch-show-save-attachments)' > /dev/null 2>&1 +output=$(cat attachment) +expected=$(cat $EXPECTED/attachment) +test_expect_equal "$output" "$expected" + test_done diff --git a/test/emacs.expected-output/attachment b/test/emacs.expected-output/attachment new file mode 100644 index 00000000..1e22d3a9 --- /dev/null +++ b/test/emacs.expected-output/attachment @@ -0,0 +1,32 @@ +From e3bc4bbd7b9d0d086816ab5f8f2d6ffea1dd3ea4 Mon Sep 17 00:00:00 2001 +From: Alexander Botero-Lowry +Date: Tue, 17 Nov 2009 11:30:39 -0800 +Subject: [PATCH] Deal with situation where sysconf(_SC_GETPW_R_SIZE_MAX) returns -1 + +--- + notmuch-config.c | 2 ++ + 1 files changed, 2 insertions(+), 0 deletions(-) + +diff --git a/notmuch-config.c b/notmuch-config.c +index 248149c..e7220d8 100644 +--- a/notmuch-config.c ++++ b/notmuch-config.c +@@ -77,6 +77,7 @@ static char * + get_name_from_passwd_file (void *ctx) + { + long pw_buf_size = sysconf(_SC_GETPW_R_SIZE_MAX); ++ if (pw_buf_size == -1) pw_buf_size = 64; + char *pw_buf = talloc_zero_size (ctx, pw_buf_size); + struct passwd passwd, *ignored; + char *name; +@@ -101,6 +102,7 @@ static char * + get_username_from_passwd_file (void *ctx) + { + long pw_buf_size = sysconf(_SC_GETPW_R_SIZE_MAX); ++ if (pw_buf_size == -1) pw_buf_size = 64; + char *pw_buf = talloc_zero_size (ctx, pw_buf_size); + struct passwd passwd, *ignored; + char *name; +-- +1.6.5.2 + -- 2.26.2