2015-03-14 09:50:55 +01:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
test_description="error reporting for library"
|
|
|
|
|
2017-09-25 22:38:19 +02:00
|
|
|
. $(dirname "$0")/test-lib.sh || exit 1
|
2015-03-14 09:50:55 +01:00
|
|
|
|
|
|
|
add_email_corpus
|
|
|
|
|
2017-02-26 14:43:00 +01:00
|
|
|
test_begin_subtest "building database"
|
|
|
|
test_expect_success "NOTMUCH_NEW"
|
2015-03-14 09:50:55 +01:00
|
|
|
|
|
|
|
test_begin_subtest "Open null pointer"
|
|
|
|
test_C <<'EOF'
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <notmuch.h>
|
|
|
|
int main (int argc, char** argv)
|
|
|
|
{
|
|
|
|
notmuch_database_t *db;
|
|
|
|
notmuch_status_t stat;
|
|
|
|
stat = notmuch_database_open (NULL, 0, 0);
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
cat <<'EOF' >EXPECTED
|
|
|
|
== stdout ==
|
|
|
|
== stderr ==
|
|
|
|
Error: Cannot open a database for a NULL path.
|
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
2015-06-10 07:58:44 +02:00
|
|
|
test_begin_subtest "Open relative path"
|
2015-03-14 09:50:55 +01:00
|
|
|
test_C <<'EOF'
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <notmuch.h>
|
|
|
|
int main (int argc, char** argv)
|
|
|
|
{
|
|
|
|
notmuch_database_t *db;
|
|
|
|
notmuch_status_t stat;
|
2015-04-07 14:10:15 +02:00
|
|
|
stat = notmuch_database_open ("./nonexistent/foo", 0, 0);
|
2015-03-14 09:50:55 +01:00
|
|
|
}
|
|
|
|
EOF
|
|
|
|
cat <<'EOF' >EXPECTED
|
|
|
|
== stdout ==
|
|
|
|
== stderr ==
|
2015-06-10 07:58:44 +02:00
|
|
|
Error: Database path must be absolute.
|
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
|
|
|
test_begin_subtest "Create database in relative path"
|
|
|
|
test_C <<'EOF'
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <notmuch.h>
|
|
|
|
int main (int argc, char** argv)
|
|
|
|
{
|
|
|
|
notmuch_database_t *db;
|
|
|
|
notmuch_status_t stat;
|
|
|
|
stat = notmuch_database_create ("./nonexistent/foo", &db);
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
cat <<'EOF' >EXPECTED
|
|
|
|
== stdout ==
|
|
|
|
== stderr ==
|
|
|
|
Error: Database path must be absolute.
|
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
|
|
|
test_begin_subtest "Open nonexistent database"
|
|
|
|
test_C ${PWD}/nonexistent/foo <<'EOF'
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <notmuch.h>
|
|
|
|
int main (int argc, char** argv)
|
|
|
|
{
|
|
|
|
notmuch_database_t *db;
|
|
|
|
notmuch_status_t stat;
|
|
|
|
stat = notmuch_database_open (argv[1], 0, 0);
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
cat <<'EOF' >EXPECTED
|
|
|
|
== stdout ==
|
|
|
|
== stderr ==
|
|
|
|
Error opening database at CWD/nonexistent/foo/.notmuch: No such file or directory
|
2015-03-14 09:50:55 +01:00
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
|
|
|
test_begin_subtest "create NULL path"
|
|
|
|
test_C <<'EOF'
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <notmuch.h>
|
|
|
|
int main (int argc, char** argv)
|
|
|
|
{
|
|
|
|
notmuch_status_t stat;
|
|
|
|
stat = notmuch_database_create (NULL, NULL);
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
cat <<'EOF' >EXPECTED
|
|
|
|
== stdout ==
|
|
|
|
== stderr ==
|
|
|
|
Error: Cannot create a database for a NULL path.
|
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
2015-06-08 08:02:22 +02:00
|
|
|
test_begin_subtest "Create database in nonexistent directory"
|
|
|
|
test_C ${PWD}/nonexistent/foo<<'EOF'
|
2015-03-14 09:50:55 +01:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <notmuch.h>
|
|
|
|
int main (int argc, char** argv)
|
|
|
|
{
|
|
|
|
notmuch_database_t *db;
|
|
|
|
notmuch_status_t stat;
|
2015-06-08 08:02:22 +02:00
|
|
|
stat = notmuch_database_create (argv[1], &db);
|
2015-03-14 09:50:55 +01:00
|
|
|
}
|
|
|
|
EOF
|
|
|
|
cat <<'EOF' >EXPECTED
|
|
|
|
== stdout ==
|
|
|
|
== stderr ==
|
2015-06-08 08:02:22 +02:00
|
|
|
Error: Cannot create database at CWD/nonexistent/foo: No such file or directory.
|
2015-03-14 09:50:55 +01:00
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
|
|
|
test_begin_subtest "Write to read-only database"
|
|
|
|
test_C ${MAIL_DIR} <<'EOF'
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <notmuch.h>
|
|
|
|
int main (int argc, char** argv)
|
|
|
|
{
|
|
|
|
notmuch_database_t *db;
|
|
|
|
notmuch_status_t stat;
|
|
|
|
stat = notmuch_database_open (argv[1], NOTMUCH_DATABASE_MODE_READ_ONLY, &db);
|
|
|
|
if (stat != NOTMUCH_STATUS_SUCCESS) {
|
|
|
|
fprintf (stderr, "error opening database: %d\n", stat);
|
|
|
|
}
|
database: add n_d_index_file (deprecates n_d_add_message)
We need a way to pass parameters to the indexing functionality on the
first index, not just on reindexing. The obvious place is in
notmuch_database_add_message. But since modifying the argument list
would break both API and ABI, we needed a new name.
I considered notmuch_database_add_message_with_params(), but the
functionality we're talking about doesn't always add a message. It
tries to index a specific file, possibly adding a message, but
possibly doing other things, like adding terms to an existing message,
or failing to deal with message objects entirely (e.g. because the
file didn't contain a message).
So i chose the function name notmuch_database_index_file.
I confess i'm a little concerned about confusing future notmuch
developers with the new name, since we already have a private
_notmuch_message_index_file function, and the two do rather different
things. But i think the added clarity for people linking against the
future libnotmuch and the capacity for using index parameters makes
this a worthwhile tradeoff. (that said, if anyone has another name
that they strongly prefer, i'd be happy to go with it)
This changeset also adjusts the tests so that we test whether the new,
preferred function returns bad values (since the deprecated function
just calls the new one).
We can keep the deprecated n_d_add_message function around as long as
we like, but at the next place where we're forced to break API or ABI
we can probably choose to drop the name relatively safely.
NOTE: there is probably more cleanup to do in the ruby and go bindings
to complete the deprecation directly. I don't know those languages
well enough to attempt a fix; i don't know how to test them; and i
don't know the culture around those languages about API additions or
deprecations.
2017-08-18 01:14:25 +02:00
|
|
|
stat = notmuch_database_index_file (db, "/dev/null", NULL, NULL);
|
2014-12-26 17:25:35 +01:00
|
|
|
if (stat)
|
|
|
|
fputs (notmuch_database_status_string (db), stderr);
|
|
|
|
|
2015-03-14 09:50:55 +01:00
|
|
|
}
|
|
|
|
EOF
|
|
|
|
cat <<'EOF' >EXPECTED
|
|
|
|
== stdout ==
|
|
|
|
== stderr ==
|
|
|
|
Cannot write to a read-only database.
|
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
2015-03-29 00:24:38 +01:00
|
|
|
test_begin_subtest "Add non-existent file"
|
|
|
|
test_C ${MAIL_DIR} <<'EOF'
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <notmuch.h>
|
|
|
|
int main (int argc, char** argv)
|
|
|
|
{
|
|
|
|
notmuch_database_t *db;
|
|
|
|
notmuch_status_t stat;
|
|
|
|
stat = notmuch_database_open (argv[1], NOTMUCH_DATABASE_MODE_READ_WRITE, &db);
|
|
|
|
if (stat != NOTMUCH_STATUS_SUCCESS) {
|
|
|
|
fprintf (stderr, "error opening database: %d\n", stat);
|
|
|
|
}
|
database: add n_d_index_file (deprecates n_d_add_message)
We need a way to pass parameters to the indexing functionality on the
first index, not just on reindexing. The obvious place is in
notmuch_database_add_message. But since modifying the argument list
would break both API and ABI, we needed a new name.
I considered notmuch_database_add_message_with_params(), but the
functionality we're talking about doesn't always add a message. It
tries to index a specific file, possibly adding a message, but
possibly doing other things, like adding terms to an existing message,
or failing to deal with message objects entirely (e.g. because the
file didn't contain a message).
So i chose the function name notmuch_database_index_file.
I confess i'm a little concerned about confusing future notmuch
developers with the new name, since we already have a private
_notmuch_message_index_file function, and the two do rather different
things. But i think the added clarity for people linking against the
future libnotmuch and the capacity for using index parameters makes
this a worthwhile tradeoff. (that said, if anyone has another name
that they strongly prefer, i'd be happy to go with it)
This changeset also adjusts the tests so that we test whether the new,
preferred function returns bad values (since the deprecated function
just calls the new one).
We can keep the deprecated n_d_add_message function around as long as
we like, but at the next place where we're forced to break API or ABI
we can probably choose to drop the name relatively safely.
NOTE: there is probably more cleanup to do in the ruby and go bindings
to complete the deprecation directly. I don't know those languages
well enough to attempt a fix; i don't know how to test them; and i
don't know the culture around those languages about API additions or
deprecations.
2017-08-18 01:14:25 +02:00
|
|
|
stat = notmuch_database_index_file (db, "./nonexistent", NULL, NULL);
|
2015-03-29 09:39:46 +02:00
|
|
|
if (stat) {
|
|
|
|
char *status_string = notmuch_database_status_string (db);
|
|
|
|
if (status_string) fputs (status_string, stderr);
|
|
|
|
}
|
2015-03-29 00:24:38 +01:00
|
|
|
}
|
|
|
|
EOF
|
|
|
|
cat <<'EOF' >EXPECTED
|
|
|
|
== stdout ==
|
|
|
|
== stderr ==
|
2015-04-07 14:10:15 +02:00
|
|
|
Error opening ./nonexistent: No such file or directory
|
2015-03-29 00:24:38 +01:00
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
2015-03-14 09:50:55 +01:00
|
|
|
test_begin_subtest "compact, overwriting existing backup"
|
|
|
|
test_C ${MAIL_DIR} <<'EOF'
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <notmuch.h>
|
|
|
|
static void
|
|
|
|
status_cb (const char *msg, void *closure)
|
|
|
|
{
|
|
|
|
printf ("%s\n", msg);
|
|
|
|
}
|
|
|
|
int main (int argc, char** argv)
|
|
|
|
{
|
|
|
|
notmuch_database_t *db;
|
|
|
|
notmuch_status_t stat;
|
|
|
|
stat = notmuch_database_compact (argv[1], argv[1], status_cb, NULL);
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
cat <<'EOF' >EXPECTED
|
|
|
|
== stdout ==
|
2016-01-23 13:49:26 +01:00
|
|
|
Path already exists: MAIL_DIR
|
2014-12-26 17:25:35 +01:00
|
|
|
|
|
|
|
== stderr ==
|
2015-03-14 09:50:55 +01:00
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
2016-04-09 03:49:50 +02:00
|
|
|
cat <<EOF > c_head
|
2015-03-29 00:24:38 +01:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <sys/stat.h>
|
|
|
|
#include <fcntl.h>
|
|
|
|
#include <talloc.h>
|
|
|
|
#include <notmuch.h>
|
|
|
|
|
|
|
|
int main (int argc, char** argv)
|
|
|
|
{
|
|
|
|
notmuch_database_t *db;
|
|
|
|
notmuch_status_t stat;
|
|
|
|
char *path;
|
2016-04-09 03:49:47 +02:00
|
|
|
char *msg = NULL;
|
2015-03-29 00:24:38 +01:00
|
|
|
int fd;
|
|
|
|
|
2016-04-09 03:49:47 +02:00
|
|
|
stat = notmuch_database_open_verbose (argv[1], NOTMUCH_DATABASE_MODE_READ_WRITE, &db, &msg);
|
2015-03-29 00:24:38 +01:00
|
|
|
if (stat != NOTMUCH_STATUS_SUCCESS) {
|
2016-04-09 03:49:47 +02:00
|
|
|
fprintf (stderr, "error opening database: %d %s\n", stat, msg ? msg : "");
|
|
|
|
exit (1);
|
2015-03-29 00:24:38 +01:00
|
|
|
}
|
2016-04-09 03:49:50 +02:00
|
|
|
path = talloc_asprintf (db, "%s/.notmuch/xapian/postlist.${db_ending}", argv[1]);
|
2015-03-29 00:24:38 +01:00
|
|
|
fd = open(path,O_WRONLY|O_TRUNC);
|
2016-04-09 03:49:47 +02:00
|
|
|
if (fd < 0) {
|
|
|
|
fprintf (stderr, "error opening %s\n", argv[1]);
|
|
|
|
exit (1);
|
|
|
|
}
|
2015-03-29 00:24:38 +01:00
|
|
|
EOF
|
|
|
|
cat <<'EOF' > c_tail
|
|
|
|
if (stat) {
|
|
|
|
const char *stat_str = notmuch_database_status_string (db);
|
|
|
|
if (stat_str)
|
|
|
|
fputs (stat_str, stderr);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
|
|
|
|
backup_database
|
|
|
|
test_begin_subtest "Xapian exception finding message"
|
|
|
|
cat c_head - c_tail <<'EOF' | test_C ${MAIL_DIR}
|
|
|
|
{
|
|
|
|
notmuch_message_t *message = NULL;
|
2015-04-08 16:31:43 +02:00
|
|
|
stat = notmuch_database_find_message (db, "id:nonexistent", &message);
|
2015-03-29 00:24:38 +01:00
|
|
|
}
|
|
|
|
EOF
|
|
|
|
sed 's/^\(A Xapian exception [^:]*\):.*$/\1/' < OUTPUT > OUTPUT.clean
|
|
|
|
cat <<'EOF' >EXPECTED
|
|
|
|
== stdout ==
|
|
|
|
== stderr ==
|
|
|
|
A Xapian exception occurred finding message
|
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT.clean
|
|
|
|
restore_database
|
|
|
|
|
|
|
|
backup_database
|
|
|
|
test_begin_subtest "Xapian exception getting tags"
|
|
|
|
cat c_head - c_tail <<'EOF' | test_C ${MAIL_DIR}
|
|
|
|
{
|
|
|
|
notmuch_tags_t *tags = NULL;
|
|
|
|
tags = notmuch_database_get_all_tags (db);
|
|
|
|
stat = (tags == NULL);
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
sed 's/^\(A Xapian exception [^:]*\):.*$/\1/' < OUTPUT > OUTPUT.clean
|
|
|
|
cat <<'EOF' >EXPECTED
|
|
|
|
== stdout ==
|
|
|
|
== stderr ==
|
|
|
|
A Xapian exception occurred getting tags
|
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT.clean
|
|
|
|
restore_database
|
|
|
|
|
|
|
|
backup_database
|
|
|
|
test_begin_subtest "Xapian exception creating directory"
|
|
|
|
cat c_head - c_tail <<'EOF' | test_C ${MAIL_DIR}
|
|
|
|
{
|
|
|
|
notmuch_directory_t *directory = NULL;
|
|
|
|
stat = notmuch_database_get_directory (db, "none/existing", &directory);
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
sed 's/^\(A Xapian exception [^:]*\):.*$/\1/' < OUTPUT > OUTPUT.clean
|
|
|
|
cat <<'EOF' >EXPECTED
|
|
|
|
== stdout ==
|
|
|
|
== stderr ==
|
|
|
|
A Xapian exception occurred creating a directory
|
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT.clean
|
|
|
|
restore_database
|
|
|
|
|
|
|
|
backup_database
|
|
|
|
test_begin_subtest "Xapian exception searching messages"
|
|
|
|
cat c_head - c_tail <<'EOF' | test_C ${MAIL_DIR}
|
|
|
|
{
|
|
|
|
notmuch_messages_t *messages = NULL;
|
|
|
|
notmuch_query_t *query=notmuch_query_create (db, "*");
|
2017-02-26 22:21:32 +01:00
|
|
|
stat = notmuch_query_search_messages (query, &messages);
|
2015-03-29 00:24:38 +01:00
|
|
|
}
|
|
|
|
EOF
|
|
|
|
sed 's/^\(A Xapian exception [^:]*\):.*$/\1/' < OUTPUT > OUTPUT.clean
|
|
|
|
cat <<'EOF' >EXPECTED
|
|
|
|
== stdout ==
|
|
|
|
== stderr ==
|
|
|
|
A Xapian exception occurred performing query
|
|
|
|
Query string was: *
|
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT.clean
|
|
|
|
restore_database
|
|
|
|
|
|
|
|
backup_database
|
|
|
|
test_begin_subtest "Xapian exception counting messages"
|
|
|
|
cat c_head - c_tail <<'EOF' | test_C ${MAIL_DIR}
|
|
|
|
{
|
2017-02-26 22:21:34 +01:00
|
|
|
int count;
|
2015-03-29 00:24:38 +01:00
|
|
|
notmuch_query_t *query=notmuch_query_create (db, "id:87ocn0qh6d.fsf@yoom.home.cworth.org");
|
2017-02-26 22:21:34 +01:00
|
|
|
stat = notmuch_query_count_messages (query, &count);
|
2015-03-29 00:24:38 +01:00
|
|
|
}
|
|
|
|
EOF
|
|
|
|
sed 's/^\(A Xapian exception [^:]*\):.*$/\1/' < OUTPUT > OUTPUT.clean
|
|
|
|
cat <<'EOF' >EXPECTED
|
|
|
|
== stdout ==
|
|
|
|
== stderr ==
|
|
|
|
A Xapian exception occurred performing query
|
|
|
|
Query string was: id:87ocn0qh6d.fsf@yoom.home.cworth.org
|
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT.clean
|
|
|
|
restore_database
|
|
|
|
|
2020-06-30 03:14:08 +02:00
|
|
|
cat <<EOF > c_head2
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <notmuch.h>
|
|
|
|
#include <notmuch-test.h>
|
|
|
|
int main (int argc, char** argv)
|
|
|
|
{
|
|
|
|
notmuch_database_t *db;
|
|
|
|
notmuch_status_t stat;
|
|
|
|
char *msg = NULL;
|
|
|
|
notmuch_message_t *message = NULL;
|
|
|
|
const char *id = "1258471718-6781-1-git-send-email-dottedmag@dottedmag.net";
|
|
|
|
|
|
|
|
stat = notmuch_database_open_verbose (argv[1], NOTMUCH_DATABASE_MODE_READ_WRITE, &db, &msg);
|
|
|
|
if (stat != NOTMUCH_STATUS_SUCCESS) {
|
|
|
|
fprintf (stderr, "error opening database: %d %s\n", stat, msg ? msg : "");
|
|
|
|
exit (1);
|
|
|
|
}
|
|
|
|
EXPECT0(notmuch_database_find_message (db, id, &message));
|
|
|
|
EXPECT0(notmuch_database_close (db));
|
|
|
|
EOF
|
|
|
|
|
|
|
|
test_begin_subtest "Handle getting message-id from closed database"
|
|
|
|
cat c_head2 - c_tail <<'EOF' | test_C ${MAIL_DIR}
|
|
|
|
{
|
|
|
|
const char *id2;
|
|
|
|
id2=notmuch_message_get_message_id (message);
|
2020-07-04 14:29:41 +02:00
|
|
|
printf("%d\n%d\n", message != NULL, id2==NULL);
|
2020-07-22 13:19:28 +02:00
|
|
|
stat = NOTMUCH_STATUS_XAPIAN_EXCEPTION;
|
2020-06-30 03:14:08 +02:00
|
|
|
}
|
|
|
|
EOF
|
|
|
|
cat <<EOF > EXPECTED
|
|
|
|
== stdout ==
|
2020-07-04 14:29:41 +02:00
|
|
|
1
|
2020-06-30 03:14:08 +02:00
|
|
|
1
|
|
|
|
== stderr ==
|
2020-07-22 13:19:28 +02:00
|
|
|
A Xapian exception occurred at lib/message.cc:XXX: Database has been closed
|
2020-06-30 03:14:08 +02:00
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
2020-06-30 03:14:10 +02:00
|
|
|
test_begin_subtest "Handle getting thread-id from closed database"
|
|
|
|
cat c_head2 - c_tail <<'EOF' | test_C ${MAIL_DIR}
|
|
|
|
{
|
|
|
|
const char *id2;
|
|
|
|
id2=notmuch_message_get_thread_id (message);
|
2020-07-04 14:29:41 +02:00
|
|
|
printf("%d\n%d\n", message != NULL, id2==NULL);
|
2020-07-22 13:19:28 +02:00
|
|
|
stat = NOTMUCH_STATUS_XAPIAN_EXCEPTION;
|
2020-06-30 03:14:10 +02:00
|
|
|
}
|
|
|
|
EOF
|
|
|
|
cat <<EOF > EXPECTED
|
|
|
|
== stdout ==
|
2020-07-04 14:29:41 +02:00
|
|
|
1
|
2020-06-30 03:14:10 +02:00
|
|
|
1
|
|
|
|
== stderr ==
|
2020-07-22 13:19:28 +02:00
|
|
|
A Xapian exception occurred at lib/message.cc:XXX: Database has been closed
|
2020-06-30 03:14:10 +02:00
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
2020-07-04 13:35:08 +02:00
|
|
|
test_begin_subtest "Handle getting header from closed database"
|
|
|
|
cat c_head2 - c_tail <<'EOF' | test_C ${MAIL_DIR}
|
|
|
|
{
|
|
|
|
const char *from;
|
|
|
|
from=notmuch_message_get_header (message, "from");
|
|
|
|
printf("%s\n%d\n", id, from == NULL);
|
2020-07-22 13:19:28 +02:00
|
|
|
stat = NOTMUCH_STATUS_XAPIAN_EXCEPTION;
|
2020-07-04 13:35:08 +02:00
|
|
|
}
|
|
|
|
EOF
|
|
|
|
cat <<EOF > EXPECTED
|
|
|
|
== stdout ==
|
|
|
|
1258471718-6781-1-git-send-email-dottedmag@dottedmag.net
|
|
|
|
1
|
|
|
|
== stderr ==
|
2020-07-22 13:19:28 +02:00
|
|
|
A Xapian exception occurred at lib/message.cc:XXX: Database has been closed
|
2020-07-04 13:35:08 +02:00
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
2020-07-04 14:09:09 +02:00
|
|
|
# XXX TODO: test on a message from notmuch_thread_get_toplevel_messages
|
|
|
|
# XXX this test only tests the trivial code path
|
|
|
|
test_begin_subtest "Handle getting replies from closed database"
|
|
|
|
cat c_head2 - c_tail <<'EOF' | test_C ${MAIL_DIR}
|
|
|
|
{
|
|
|
|
notmuch_messages_t *replies;
|
|
|
|
replies = notmuch_message_get_replies (message);
|
|
|
|
printf("%d\n%d\n", message != NULL, replies==NULL);
|
2020-07-22 13:19:28 +02:00
|
|
|
stat = NOTMUCH_STATUS_XAPIAN_EXCEPTION;
|
2020-07-04 14:09:09 +02:00
|
|
|
}
|
|
|
|
EOF
|
|
|
|
cat <<EOF > EXPECTED
|
|
|
|
== stdout ==
|
|
|
|
1
|
|
|
|
1
|
|
|
|
== stderr ==
|
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
2020-07-04 14:16:30 +02:00
|
|
|
test_begin_subtest "Handle getting message filename from closed database"
|
|
|
|
cat c_head2 - c_tail <<'EOF' | test_C ${MAIL_DIR}
|
|
|
|
{
|
|
|
|
const char *filename;
|
|
|
|
filename = notmuch_message_get_filename (message);
|
|
|
|
printf("%d\n%d\n", message != NULL, filename == NULL);
|
2020-07-22 13:19:28 +02:00
|
|
|
stat = NOTMUCH_STATUS_XAPIAN_EXCEPTION;
|
2020-07-04 14:16:30 +02:00
|
|
|
}
|
|
|
|
EOF
|
|
|
|
cat <<EOF > EXPECTED
|
|
|
|
== stdout ==
|
|
|
|
1
|
|
|
|
1
|
|
|
|
== stderr ==
|
2020-07-22 13:19:28 +02:00
|
|
|
A Xapian exception occurred at lib/message.cc:XXX: Database has been closed
|
2020-07-04 14:16:30 +02:00
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
2020-07-04 16:06:37 +02:00
|
|
|
test_begin_subtest "Handle getting all message filenames from closed database"
|
|
|
|
cat c_head2 - c_tail <<'EOF' | test_C ${MAIL_DIR}
|
|
|
|
{
|
|
|
|
notmuch_filenames_t *filenames;
|
|
|
|
filenames = notmuch_message_get_filenames (message);
|
|
|
|
printf("%d\n%d\n", message != NULL, filenames == NULL);
|
2020-07-22 13:19:28 +02:00
|
|
|
stat = NOTMUCH_STATUS_XAPIAN_EXCEPTION;
|
2020-07-04 16:06:37 +02:00
|
|
|
}
|
|
|
|
EOF
|
|
|
|
cat <<EOF > EXPECTED
|
|
|
|
== stdout ==
|
|
|
|
1
|
|
|
|
1
|
|
|
|
== stderr ==
|
2020-07-22 13:19:28 +02:00
|
|
|
A Xapian exception occurred at lib/message.cc:XXX: Database has been closed
|
2020-07-04 16:06:37 +02:00
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
2020-07-04 16:22:25 +02:00
|
|
|
test_begin_subtest "Handle getting ghost flag from closed database"
|
|
|
|
cat c_head2 - c_tail <<'EOF' | test_C ${MAIL_DIR}
|
|
|
|
{
|
|
|
|
notmuch_bool_t result;
|
|
|
|
result = notmuch_message_get_flag (message, NOTMUCH_MESSAGE_FLAG_GHOST);
|
|
|
|
printf("%d\n%d\n", message != NULL, result == FALSE);
|
2020-07-22 13:19:28 +02:00
|
|
|
stat = NOTMUCH_STATUS_XAPIAN_EXCEPTION;
|
2020-07-04 16:22:25 +02:00
|
|
|
}
|
|
|
|
EOF
|
|
|
|
cat <<EOF > EXPECTED
|
|
|
|
== stdout ==
|
|
|
|
1
|
|
|
|
1
|
|
|
|
== stderr ==
|
2020-07-22 13:19:28 +02:00
|
|
|
A Xapian exception occurred at lib/message.cc:XXX: Database has been closed
|
2020-07-04 16:22:25 +02:00
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
2020-07-05 15:00:16 +02:00
|
|
|
test_begin_subtest "Handle getting date from closed database"
|
|
|
|
cat c_head2 - c_tail <<'EOF' | test_C ${MAIL_DIR}
|
|
|
|
{
|
|
|
|
time_t result;
|
|
|
|
result = notmuch_message_get_date (message);
|
|
|
|
printf("%d\n%d\n", message != NULL, result == 0);
|
2020-07-22 13:19:28 +02:00
|
|
|
stat = NOTMUCH_STATUS_XAPIAN_EXCEPTION;
|
2020-07-05 15:00:16 +02:00
|
|
|
}
|
|
|
|
EOF
|
|
|
|
cat <<EOF > EXPECTED
|
|
|
|
== stdout ==
|
|
|
|
1
|
|
|
|
1
|
|
|
|
== stderr ==
|
2020-07-22 13:19:28 +02:00
|
|
|
A Xapian exception occurred at lib/message.cc:XXX: Database has been closed
|
2020-07-05 15:00:16 +02:00
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
2020-07-05 15:00:18 +02:00
|
|
|
test_begin_subtest "Handle getting tags from closed database"
|
|
|
|
cat c_head2 - c_tail <<'EOF' | test_C ${MAIL_DIR}
|
|
|
|
{
|
|
|
|
notmuch_tags_t *result;
|
|
|
|
result = notmuch_message_get_tags (message);
|
|
|
|
printf("%d\n%d\n", message != NULL, result == NULL);
|
2020-07-22 13:19:28 +02:00
|
|
|
stat = NOTMUCH_STATUS_XAPIAN_EXCEPTION;
|
2020-07-05 15:00:18 +02:00
|
|
|
}
|
|
|
|
EOF
|
|
|
|
cat <<EOF > EXPECTED
|
|
|
|
== stdout ==
|
|
|
|
1
|
|
|
|
1
|
|
|
|
== stderr ==
|
2020-07-22 13:19:28 +02:00
|
|
|
A Xapian exception occurred at lib/message.cc:XXX: Database has been closed
|
2020-07-05 15:00:18 +02:00
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
2020-07-05 15:00:20 +02:00
|
|
|
test_begin_subtest "Handle counting files from closed database"
|
|
|
|
cat c_head2 - c_tail <<'EOF' | test_C ${MAIL_DIR}
|
|
|
|
{
|
|
|
|
int result;
|
|
|
|
result = notmuch_message_count_files (message);
|
|
|
|
printf("%d\n%d\n", message != NULL, result < 0);
|
2020-07-22 13:19:28 +02:00
|
|
|
stat = NOTMUCH_STATUS_XAPIAN_EXCEPTION;
|
2020-07-05 15:00:20 +02:00
|
|
|
}
|
|
|
|
EOF
|
|
|
|
cat <<EOF > EXPECTED
|
|
|
|
== stdout ==
|
|
|
|
1
|
|
|
|
1
|
|
|
|
== stderr ==
|
2020-07-22 13:19:28 +02:00
|
|
|
A Xapian exception occurred at lib/message.cc:XXX: Database has been closed
|
2020-07-05 15:00:20 +02:00
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
2020-07-05 15:00:22 +02:00
|
|
|
test_begin_subtest "Handle adding tag with closed database"
|
|
|
|
cat c_head2 - c_tail <<'EOF' | test_C ${MAIL_DIR}
|
|
|
|
{
|
2020-07-22 13:19:28 +02:00
|
|
|
stat = notmuch_message_add_tag (message, "boom");
|
|
|
|
printf("%d\n%d\n", message != NULL, stat == NOTMUCH_STATUS_XAPIAN_EXCEPTION);
|
2020-07-05 15:00:22 +02:00
|
|
|
}
|
|
|
|
EOF
|
|
|
|
cat <<EOF > EXPECTED
|
|
|
|
== stdout ==
|
|
|
|
1
|
|
|
|
1
|
|
|
|
== stderr ==
|
2020-07-22 13:19:28 +02:00
|
|
|
A Xapian exception occurred at lib/message.cc:XXX: Database has been closed
|
2020-07-05 15:00:22 +02:00
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
2020-07-04 16:22:25 +02:00
|
|
|
|
2020-07-05 15:00:24 +02:00
|
|
|
test_begin_subtest "Handle removing tag with closed database"
|
|
|
|
cat c_head2 - c_tail <<'EOF' | test_C ${MAIL_DIR}
|
|
|
|
{
|
2020-07-22 13:19:28 +02:00
|
|
|
stat = notmuch_message_remove_tag (message, "boom");
|
|
|
|
printf("%d\n%d\n", message != NULL, stat == NOTMUCH_STATUS_XAPIAN_EXCEPTION);
|
2020-07-05 15:00:24 +02:00
|
|
|
}
|
|
|
|
EOF
|
|
|
|
cat <<EOF > EXPECTED
|
|
|
|
== stdout ==
|
|
|
|
1
|
|
|
|
1
|
|
|
|
== stderr ==
|
2020-07-22 13:19:28 +02:00
|
|
|
A Xapian exception occurred at lib/message.cc:XXX: Database has been closed
|
2020-07-05 15:00:24 +02:00
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
2020-07-09 02:17:00 +02:00
|
|
|
test_begin_subtest "Handle read maildir flag with closed database"
|
|
|
|
cat c_head2 - c_tail <<'EOF' | test_C ${MAIL_DIR}
|
|
|
|
{
|
|
|
|
notmuch_bool_t is_set = -1;
|
|
|
|
is_set = notmuch_message_has_maildir_flag (message, 'S');
|
|
|
|
printf("%d\n%d\n", message != NULL, is_set == FALSE || is_set == TRUE);
|
2020-07-22 13:19:28 +02:00
|
|
|
stat = NOTMUCH_STATUS_XAPIAN_EXCEPTION;
|
2020-07-09 02:17:00 +02:00
|
|
|
}
|
|
|
|
EOF
|
|
|
|
cat <<EOF > EXPECTED
|
|
|
|
== stdout ==
|
|
|
|
1
|
|
|
|
1
|
|
|
|
== stderr ==
|
2020-07-22 13:19:28 +02:00
|
|
|
A Xapian exception occurred at lib/message.cc:XXX: Database has been closed
|
2020-07-09 02:17:00 +02:00
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
2020-07-09 02:17:01 +02:00
|
|
|
test_begin_subtest "Handle checking maildir flag with closed db (new API)"
|
|
|
|
cat c_head2 - c_tail <<'EOF' | test_C ${MAIL_DIR}
|
|
|
|
{
|
|
|
|
notmuch_bool_t out;
|
2020-07-22 13:19:28 +02:00
|
|
|
stat = notmuch_message_has_maildir_flag_st (message, 'S', &out);
|
|
|
|
printf("%d\n%d\n", message != NULL, stat == NOTMUCH_STATUS_XAPIAN_EXCEPTION);
|
2020-07-09 02:17:01 +02:00
|
|
|
}
|
|
|
|
EOF
|
|
|
|
cat <<EOF > EXPECTED
|
|
|
|
== stdout ==
|
|
|
|
1
|
|
|
|
1
|
|
|
|
== stderr ==
|
2020-07-22 13:19:28 +02:00
|
|
|
A Xapian exception occurred at lib/message.cc:XXX: Database has been closed
|
2020-07-09 02:17:01 +02:00
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
2020-07-09 02:17:02 +02:00
|
|
|
test_begin_subtest "Handle converting maildir flags to tags with closed db"
|
|
|
|
cat c_head2 - c_tail <<'EOF' | test_C ${MAIL_DIR}
|
|
|
|
{
|
2020-07-22 13:19:28 +02:00
|
|
|
stat = notmuch_message_maildir_flags_to_tags (message);
|
|
|
|
printf("%d\n%d\n", message != NULL, stat == NOTMUCH_STATUS_XAPIAN_EXCEPTION);
|
2020-07-09 02:17:02 +02:00
|
|
|
}
|
|
|
|
EOF
|
|
|
|
cat <<EOF > EXPECTED
|
|
|
|
== stdout ==
|
|
|
|
1
|
|
|
|
1
|
|
|
|
== stderr ==
|
2020-07-22 13:19:28 +02:00
|
|
|
A Xapian exception occurred at lib/message.cc:XXX: Database has been closed
|
2020-07-09 02:17:02 +02:00
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
2020-07-09 02:17:03 +02:00
|
|
|
test_begin_subtest "Handle removing all tags with closed db"
|
|
|
|
cat c_head2 - c_tail <<'EOF' | test_C ${MAIL_DIR}
|
|
|
|
{
|
2020-07-22 13:19:28 +02:00
|
|
|
stat = notmuch_message_remove_all_tags (message);
|
|
|
|
printf("%d\n%d\n", message != NULL, stat == NOTMUCH_STATUS_XAPIAN_EXCEPTION);
|
2020-07-09 02:17:03 +02:00
|
|
|
}
|
|
|
|
EOF
|
|
|
|
cat <<EOF > EXPECTED
|
|
|
|
== stdout ==
|
|
|
|
1
|
|
|
|
1
|
|
|
|
== stderr ==
|
2020-07-22 13:19:28 +02:00
|
|
|
A Xapian exception occurred at lib/message.cc:XXX: Database has been closed
|
2020-07-09 02:17:03 +02:00
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
2020-07-09 02:17:05 +02:00
|
|
|
test_begin_subtest "Handle freezing message with closed db"
|
|
|
|
cat c_head2 - c_tail <<'EOF' | test_C ${MAIL_DIR}
|
|
|
|
{
|
2020-07-22 13:19:28 +02:00
|
|
|
stat = notmuch_message_freeze (message);
|
|
|
|
printf("%d\n%d\n", message != NULL, stat == NOTMUCH_STATUS_SUCCESS);
|
2020-07-09 02:17:05 +02:00
|
|
|
}
|
|
|
|
EOF
|
|
|
|
cat <<EOF > EXPECTED
|
|
|
|
== stdout ==
|
|
|
|
1
|
|
|
|
1
|
|
|
|
== stderr ==
|
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
|
|
|
test_begin_subtest "Handle thawing message with closed db"
|
|
|
|
cat c_head2 - c_tail <<'EOF' | test_C ${MAIL_DIR}
|
|
|
|
{
|
2020-07-22 13:19:28 +02:00
|
|
|
stat = notmuch_message_thaw (message);
|
|
|
|
printf("%d\n%d\n", message != NULL, stat == NOTMUCH_STATUS_UNBALANCED_FREEZE_THAW);
|
2020-07-09 02:17:05 +02:00
|
|
|
}
|
|
|
|
EOF
|
|
|
|
cat <<EOF > EXPECTED
|
|
|
|
== stdout ==
|
|
|
|
1
|
|
|
|
1
|
|
|
|
== stderr ==
|
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
2020-07-09 02:17:06 +02:00
|
|
|
test_begin_subtest "Handle destroying message with closed db"
|
|
|
|
cat c_head2 - c_tail <<'EOF' | test_C ${MAIL_DIR}
|
|
|
|
{
|
|
|
|
notmuch_message_destroy (message);
|
|
|
|
printf("%d\n%d\n", message != NULL, 1);
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
cat <<EOF > EXPECTED
|
|
|
|
== stdout ==
|
|
|
|
1
|
|
|
|
1
|
|
|
|
== stderr ==
|
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
2020-07-09 02:17:07 +02:00
|
|
|
test_begin_subtest "Handle retrieving closed db from message"
|
|
|
|
cat c_head2 - c_tail <<'EOF' | test_C ${MAIL_DIR}
|
|
|
|
{
|
|
|
|
notmuch_database_t *db2;
|
|
|
|
db2 = notmuch_message_get_database (message);
|
|
|
|
printf("%d\n%d\n", message != NULL, db == db2);
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
cat <<EOF > EXPECTED
|
|
|
|
== stdout ==
|
|
|
|
1
|
|
|
|
1
|
|
|
|
== stderr ==
|
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
2020-07-09 02:17:08 +02:00
|
|
|
test_begin_subtest "Handle reindexing message with closed db"
|
|
|
|
cat c_head2 - c_tail <<'EOF' | test_C ${MAIL_DIR}
|
|
|
|
{
|
2020-07-22 13:19:28 +02:00
|
|
|
stat = notmuch_message_reindex (message, NULL);
|
|
|
|
printf("%d\n%d\n", message != NULL, stat == NOTMUCH_STATUS_XAPIAN_EXCEPTION);
|
2020-07-09 02:17:08 +02:00
|
|
|
}
|
|
|
|
EOF
|
|
|
|
cat <<EOF > EXPECTED
|
|
|
|
== stdout ==
|
|
|
|
1
|
|
|
|
1
|
|
|
|
== stderr ==
|
2020-07-22 13:19:28 +02:00
|
|
|
A Xapian exception occurred at lib/message.cc:XXX: Database has been closed
|
2020-07-09 02:17:08 +02:00
|
|
|
EOF
|
|
|
|
test_expect_equal_file EXPECTED OUTPUT
|
|
|
|
|
2015-03-14 09:50:55 +01:00
|
|
|
test_done
|