summaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
authorDavid Bremner <david@tethera.net>2020-08-01 09:25:53 -0300
committerDavid Bremner <david@tethera.net>2020-08-03 20:50:15 -0300
commitc151506773e76345508af8e46d7787d73fcffc62 (patch)
treea8e125c2da7c307a8d599fcec5060f7233123701 /test
parent2b6e73d895ccd35ede4fd9f20952de133423cf08 (diff)
test: regression test for n_m_get_filenames
Closing the database after the iterator is created is not a problem.
Diffstat (limited to 'test')
-rwxr-xr-xtest/T566-lib-message.sh23
1 files changed, 23 insertions, 0 deletions
diff --git a/test/T566-lib-message.sh b/test/T566-lib-message.sh
index 3b0e85b5..0ba601f9 100755
--- a/test/T566-lib-message.sh
+++ b/test/T566-lib-message.sh
@@ -138,6 +138,29 @@ cat <<EOF > EXPECTED
EOF
test_expect_equal_file EXPECTED OUTPUT
+test_begin_subtest "iterate over all message filenames from closed database"
+cat c_head0 - c_tail <<'EOF' | test_C ${MAIL_DIR}
+ {
+ notmuch_filenames_t *filenames;
+ filenames = notmuch_message_get_filenames (message);
+ EXPECT0(notmuch_database_close (db));
+ for (; notmuch_filenames_valid (filenames);
+ notmuch_filenames_move_to_next (filenames)) {
+ const char *filename = notmuch_filenames_get (filenames);
+ printf("%s\n", filename);
+ }
+ notmuch_filenames_destroy (filenames);
+ printf("SUCCESS\n");
+ }
+EOF
+cat <<EOF > EXPECTED
+== stdout ==
+MAIL_DIR/01:2,
+SUCCESS
+== stderr ==
+EOF
+test_expect_equal_file EXPECTED OUTPUT
+
test_begin_subtest "Handle getting ghost flag from closed database"
cat c_head - c_tail <<'EOF' | test_C ${MAIL_DIR}
{