[PATCH 1/2] New test: Emacs' forgetfulness.
Thomas Schwinge
thomas at schwinge.name
Wed Feb 2 15:56:38 PST 2011
Signed-off-by: Thomas Schwinge <thomas at schwinge.name>
---
test/emacs-forgetfulness | 38 ++++++++++++++++++++++++++++++++++++++
test/notmuch-test | 1 +
2 files changed, 39 insertions(+), 0 deletions(-)
create mode 100755 test/emacs-forgetfulness
diff --git a/test/emacs-forgetfulness b/test/emacs-forgetfulness
new file mode 100755
index 0000000..e17b26f
--- /dev/null
+++ b/test/emacs-forgetfulness
@@ -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 at 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
diff --git a/test/notmuch-test b/test/notmuch-test
index 9d77c0f..2f11eac 100755
--- a/test/notmuch-test
+++ b/test/notmuch-test
@@ -36,6 +36,7 @@ TESTS="
encoding
emacs
maildir-sync
+ emacs-forgetfulness
"
# Clean up any results from a previous run
--
1.7.1
More information about the notmuch
mailing list