]> git.notmuchmail.org Git - notmuch/commitdiff
New test: Emacs' forgetfulness.
authorThomas Schwinge <thomas@schwinge.name>
Wed, 2 Feb 2011 23:56:38 +0000 (00:56 +0100)
committerCarl Worth <cworth@cworth.org>
Thu, 10 Mar 2011 20:07:53 +0000 (12:07 -0800)
Signed-off-by: Thomas Schwinge <thomas@schwinge.name>
test/emacs-forgetfulness [new file with mode: 0755]
test/notmuch-test

diff --git a/test/emacs-forgetfulness b/test/emacs-forgetfulness
new file mode 100755 (executable)
index 0000000..e17b26f
--- /dev/null
@@ -0,0 +1,38 @@
+#!/bin/bash
+
+test_description=Emacs\'\ forgetfulness
+
+. test-lib.sh
+
+# RFC822 imposes a 998 character limit per line.
+x=0123456789 # 10
+x=$x$x$x$x$x$x$x$x$x$x # 100
+x=$x$x$x$x$x$x$x$x$x # 900
+
+# If setting this ``too high'' (TODO: yet to be determined), Emacs will crash
+# with a segmentation fault.
+n=20
+for i in $(seq 1 $n); do
+  # Roughly 2 KiB per message.  That is, we need two messages in order to
+  # exceed the typical size of the pipe buffer (4 KiB on commodity systems).
+  generate_message [subject]=$i-$x [from]=$i-$x@x.x
+done
+# With 20 messages à 2 KiB, we have about 10 full pipe buffers, which should be
+# enough to trigger the erroneous behavior.
+
+notmuch new > /dev/null
+
+test_begin_subtest 'Search for all messages'
+output=$(exec 2>&1; \
+         diff -wu \
+           <(notmuch search \* \
+               | sed \
+                   -e 's%^thread:[0-9a-f]*\ %%' \
+                   -e 's%;%%'; \
+             echo 'End of search results.'; \
+             echo) \
+           <(test_emacs 2>&1 \
+               '(notmuch-search "*") (notmuch-test-wait) (message (buffer-string))'))
+test_expect_equal "$output" ''
+
+test_done
index e3e04476f7bc11f2ffe7809fc784a5949456d8f5..c0aed3145b0d805ce59d0567a3322229a12f4064 100755 (executable)
@@ -37,6 +37,7 @@ TESTS="
   encoding
   emacs
   maildir-sync
+  emacs-forgetfulness
 "
 
 # Clean up any results from a previous run