notmuch/test/T620-lock.sh
Daniel Kahn Gillmor 8e1c3fa5bb test: retrying lock tests are broken when built against older Xapian
If we're building against a version of Xapian that doesn't offer
retrying the lock, we should be honest and describe the tests as
broken, rather than marking them as missing a test prerequisite.

missing test prerequisites should be for specific components of the
test harness that are missing, not for the backend library notmuch
uses.
2017-12-19 07:14:13 -04:00

77 lines
1.6 KiB
Bash
Executable file

#!/usr/bin/env bash
test_description="locking"
. $(dirname "$0")/test-lib.sh || exit 1
add_email_corpus
test_begin_subtest "blocking open"
if [ $NOTMUCH_HAVE_XAPIAN_DB_RETRY_LOCK -ne 1 ]; then
test_subtest_known_broken
fi
test_C ${MAIL_DIR} <<'EOF'
#include <unistd.h>
#include <stdlib.h>
#include <sys/wait.h>
#include <notmuch-test.h>
void
taggit (notmuch_database_t *db, const char *tag)
{
notmuch_message_t *message;
EXPECT0 (notmuch_database_find_message (db, "4EFC743A.3060609@april.org", &message));
if (message == NULL) {
fprintf (stderr, "unable to find message");
exit (1);
}
EXPECT0 (notmuch_message_add_tag (message, tag));
notmuch_message_destroy (message);
}
int
main (int argc, char **argv)
{
pid_t child;
const char *path = argv[1];
child = fork ();
if (child == -1) {
fprintf (stderr, "fork failed\n");
exit (1);
}
if (child == 0) {
notmuch_database_t *db2;
sleep (1);
EXPECT0 (notmuch_database_open (path, NOTMUCH_DATABASE_MODE_READ_WRITE, &db2));
taggit (db2, "child");
EXPECT0 (notmuch_database_close (db2));
} else {
notmuch_database_t *db;
EXPECT0 (notmuch_database_open (path, NOTMUCH_DATABASE_MODE_READ_WRITE, &db));
taggit (db, "parent");
sleep (2);
EXPECT0 (notmuch_database_close (db));
wait (NULL);
}
}
EOF
notmuch search --output=tags id:4EFC743A.3060609@april.org >> OUTPUT
cat <<'EOF' >EXPECTED
== stdout ==
== stderr ==
child
inbox
parent
unread
EOF
if [ $NOTMUCH_HAVE_XAPIAN_DB_RETRY_LOCK -ne 1 ]; then
test_subtest_known_broken
fi
test_expect_equal_file EXPECTED OUTPUT
test_done