X-Git-Url: https://git.notmuchmail.org/git?p=notmuch;a=blobdiff_plain;f=test%2FT562-lib-database.sh;h=cd202c6e8990284b9d994fcb56aeef8277d46377;hp=c869341ab383ab9d2f9ff7a4fccfc938add3e9cf;hb=f25fc8e2115fc0fa6fa2a6d1cf3ed2747e163886;hpb=f3a56b5f6d02d72c53ae22be9a4c65c86c2faffc diff --git a/test/T562-lib-database.sh b/test/T562-lib-database.sh index c869341a..cd202c6e 100755 --- a/test/T562-lib-database.sh +++ b/test/T562-lib-database.sh @@ -1,5 +1,5 @@ #!/usr/bin/env bash -test_description="error reporting for library" +test_description="notmuch_database_* API" . $(dirname "$0")/test-lib.sh || exit 1 @@ -15,7 +15,7 @@ cat < c_head int main (int argc, char** argv) { notmuch_database_t *db; - notmuch_status_t stat; + notmuch_status_t stat = NOTMUCH_STATUS_SUCCESS; char *msg = NULL; stat = notmuch_database_open_verbose (argv[1], NOTMUCH_DATABASE_MODE_READ_WRITE, &db, &msg); @@ -67,4 +67,87 @@ MAIL_DIR EOF test_expect_equal_file EXPECTED OUTPUT +test_begin_subtest "get version with closed db" +cat c_head - c_tail <<'EOF' | test_C ${MAIL_DIR} + { + unsigned int version; + EXPECT0(notmuch_database_close (db)); + version = notmuch_database_get_version (db); + printf ("%u\n", version); + stat = NOTMUCH_STATUS_XAPIAN_EXCEPTION; + } +EOF +cat < EXPECTED +== stdout == +0 +== stderr == +A Xapian exception occurred at lib/database.cc:XXX: Database has been closed +EOF +test_expect_equal_file EXPECTED OUTPUT + +test_begin_subtest "re-close a closed db" +cat c_head - c_tail <<'EOF' | test_C ${MAIL_DIR} + { + EXPECT0(notmuch_database_close (db)); + stat = notmuch_database_close (db); + printf ("%d\n", stat); + } +EOF +cat < EXPECTED +== stdout == +0 +== stderr == +EOF +test_expect_equal_file EXPECTED OUTPUT + +test_begin_subtest "destroy a closed db" +cat c_head - c_tail <<'EOF' | test_C ${MAIL_DIR} + { + unsigned int version; + EXPECT0(notmuch_database_close (db)); + stat = notmuch_database_destroy (db); + printf ("%d\n", stat); + } +EOF +cat < EXPECTED +== stdout == +0 +== stderr == +EOF +test_expect_equal_file EXPECTED OUTPUT + +test_begin_subtest "destroy an open db" +cat c_head - c_tail <<'EOF' | test_C ${MAIL_DIR} + { + unsigned int version; + stat = notmuch_database_destroy (db); + printf ("%d\n", stat); + } +EOF +cat < EXPECTED +== stdout == +0 +== stderr == +EOF +test_expect_equal_file EXPECTED OUTPUT + +test_begin_subtest "check a closed db for upgrade" +cat c_head - c_tail <<'EOF' | test_C ${MAIL_DIR} + { + notmuch_bool_t ret; + + EXPECT0(notmuch_database_close (db)); + ret = notmuch_database_needs_upgrade (db); + printf ("%d\n", ret == FALSE); + stat = NOTMUCH_STATUS_XAPIAN_EXCEPTION; + } +EOF +cat < EXPECTED +== stdout == +1 +== stderr == +A Xapian exception occurred at lib/database.cc:XXX: Database has been closed +EOF +test_expect_equal_file EXPECTED OUTPUT + test_done