From 4e414e2a5a72e8345df6371b3524030d07c2ce96 Mon Sep 17 00:00:00 2001 From: Carl Worth Date: Thu, 10 Mar 2011 13:22:04 -0800 Subject: Rename/rewrite the new emacs-forgetfulness test (to emacs-large-search-buffer) The new name is more descriptive of the bug being tested. Also, the test is rewritten slightly so that it's much more plain to see how the bug manifests itself, (that messages are droped from the emacs result at regular intervals). Primarily, this is by collapsing the large blobs used to inflate the message subjects. --- test/emacs-large-search-buffer | 27 +++++++++++++++++++++++++++ 1 file changed, 27 insertions(+) create mode 100755 test/emacs-large-search-buffer (limited to 'test/emacs-large-search-buffer') diff --git a/test/emacs-large-search-buffer b/test/emacs-large-search-buffer new file mode 100755 index 00000000..f827bb14 --- /dev/null +++ b/test/emacs-large-search-buffer @@ -0,0 +1,27 @@ +#!/bin/bash +test_description="Emacs with large search results buffer" +. test-lib.sh + +x=xxxxxxxxxx # 10 +x=$x$x$x$x$x$x$x$x$x$x # 100 +x=$x$x$x$x$x$x$x$x$x # 900 + +# We generate a long subject here (over 900 bytes) so that the emacs +# search results get large quickly. With 30 such messages we should +# cross several 4kB page boundaries and see the bug. +n=30 +for i in $(seq 1 $n); do + # Roughly 100B2 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]="$x $i of $n"' +done + +notmuch new > /dev/null + +test_begin_subtest 'Comparing emacs result to "notmuch search"' +expected="$(notmuch search '*' | sed -e 's/^thread:[0-9a-f]* //' -e 's/;//' -e 's/xx*/[BLOB]/') +End of search results." +output=$(test_emacs '(notmuch-search "*") (notmuch-test-wait) (message (buffer-string))' 2>&1 | sed -e s', *, ,g' -e 's/xx*/[BLOB]/') +test_expect_equal "$output" "$expected" + +test_done -- cgit v1.2.3