From: David Bremner Date: Tue, 11 Mar 2014 23:01:35 +0000 (+2100) Subject: [Patch v6 09/14] test: add database upgrade test from format version 1 to 2 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=12e89d196b11f1889c26fa0b0e45fddd58c43662;p=notmuch-archives.git [Patch v6 09/14] test: add database upgrade test from format version 1 to 2 --- diff --git a/c0/e1ad393798e4fa52f11a759cd4caf335042035 b/c0/e1ad393798e4fa52f11a759cd4caf335042035 new file mode 100644 index 000000000..ed42086c6 --- /dev/null +++ b/c0/e1ad393798e4fa52f11a759cd4caf335042035 @@ -0,0 +1,190 @@ +Return-Path: +X-Original-To: notmuch@notmuchmail.org +Delivered-To: notmuch@notmuchmail.org +Received: from localhost (localhost [127.0.0.1]) + by olra.theworths.org (Postfix) with ESMTP id 0EF11429E34 + for ; Tue, 11 Mar 2014 16:02:19 -0700 (PDT) +X-Virus-Scanned: Debian amavisd-new at olra.theworths.org +X-Spam-Flag: NO +X-Spam-Score: 0 +X-Spam-Level: +X-Spam-Status: No, score=0 tagged_above=-999 required=5 tests=[none] + autolearn=disabled +Received: from olra.theworths.org ([127.0.0.1]) + by localhost (olra.theworths.org [127.0.0.1]) (amavisd-new, port 10024) + with ESMTP id lVlqvLzWw8ZM for ; + Tue, 11 Mar 2014 16:02:18 -0700 (PDT) +Received: from yantan.tethera.net (yantan.tethera.net [199.188.72.155]) + (using TLSv1 with cipher DHE-RSA-AES128-SHA (128/128 bits)) + (No client certificate requested) + by olra.theworths.org (Postfix) with ESMTPS id 3953D431FD0 + for ; Tue, 11 Mar 2014 16:02:01 -0700 (PDT) +Received: from remotemail by yantan.tethera.net with local (Exim 4.80) + (envelope-from ) + id 1WNVgO-0001uX-AX; Tue, 11 Mar 2014 20:02:00 -0300 +Received: (nullmailer pid 25857 invoked by uid 1000); Tue, 11 Mar 2014 + 23:01:46 -0000 +From: David Bremner +To: notmuch@notmuchmail.org +Subject: [Patch v6 09/14] test: add database upgrade test from format version + 1 to 2 +Date: Tue, 11 Mar 2014 20:01:35 -0300 +Message-Id: <1394578900-25618-10-git-send-email-david@tethera.net> +X-Mailer: git-send-email 1.8.5.3 +In-Reply-To: <1394578900-25618-1-git-send-email-david@tethera.net> +References: <1394578900-25618-1-git-send-email-david@tethera.net> +X-BeenThere: notmuch@notmuchmail.org +X-Mailman-Version: 2.1.13 +Precedence: list +List-Id: "Use and development of the notmuch mail system." + +List-Unsubscribe: , + +List-Archive: +List-Post: +List-Help: +List-Subscribe: , + +X-List-Received-Date: Tue, 11 Mar 2014 23:02:19 -0000 + +From: Jani Nikula + +Test the upgrade from probabilistic to boolean folder: terms, and +addition of path: terms. + +The test depends on the pre-built test corpus and database tarball and +checksum file being in place. If it's not, the test is skipped. The +mechanism to fetch the test database will be added later. + +At the time of writing, a working test database and checksum file is +available at + + http://notmuchmail.org/releases/test-databases/ + +It has been noted that some non-GNU environments make lack +sha256sum. We leave this portability issue for a followup patch. +--- + test/T530-upgrade.sh | 111 +++++++++++++++++++++++++++++++++++++++++++++++++++ + 1 file changed, 111 insertions(+) + create mode 100755 test/T530-upgrade.sh + +diff --git a/test/T530-upgrade.sh b/test/T530-upgrade.sh +new file mode 100755 +index 0000000..2139618 +--- /dev/null ++++ b/test/T530-upgrade.sh +@@ -0,0 +1,111 @@ ++#!/usr/bin/env bash ++test_description="database upgrade" ++ ++. ./test-lib.sh ++ ++dbtarball=database-v1.tar.xz ++ ++# XXX: Accomplish the same with test lib helpers ++if [ ! -e ${TEST_DIRECTORY}/test-databases/${dbtarball} ]; then ++ test_subtest_missing_external_prereq_["${dbtarball}"]=t ++fi ++ ++test_expect_success \ ++ 'database checksum' \ ++ '( cd $TEST_DIRECTORY/test-databases && ++ sha256sum --quiet --check --status ${dbtarball}.sha256 )' ++ ++tar xf $TEST_DIRECTORY/test-databases/${dbtarball} -C ${MAIL_DIR} --strip-components=1 ++ ++test_begin_subtest "folder: search does not work with old database version" ++output=$(notmuch search folder:foo) ++test_expect_equal "$output" "" ++ ++test_begin_subtest "path: search does not work with old database version" ++output=$(notmuch search path:foo) ++test_expect_equal "$output" "" ++ ++test_begin_subtest "database upgrade from format version 1" ++output=$(notmuch new) ++test_expect_equal "$output" "\ ++Welcome to a new version of notmuch! Your database will now be upgraded. ++Your notmuch database has now been upgraded to database format version 2. ++No new mail." ++ ++test_begin_subtest "folder: no longer matches in the middle of path" ++output=$(notmuch search folder:baz) ++test_expect_equal "$output" "" ++ ++test_begin_subtest "folder: search" ++output=$(notmuch search --output=files folder:foo | notmuch_search_files_sanitize | sort) ++test_expect_equal "$output" "MAIL_DIR/foo/06:2, ++MAIL_DIR/foo/cur/07:2, ++MAIL_DIR/foo/cur/08:2, ++MAIL_DIR/foo/new/03:2, ++MAIL_DIR/foo/new/09:2, ++MAIL_DIR/foo/new/10:2," ++ ++test_begin_subtest "top level folder: search" ++output=$(notmuch search --output=files folder:'""' | notmuch_search_files_sanitize | sort) ++# bar/18:2, is a duplicate of cur/51:2, ++test_expect_equal "$output" "MAIL_DIR/01:2, ++MAIL_DIR/02:2, ++MAIL_DIR/bar/18:2, ++MAIL_DIR/cur/29:2, ++MAIL_DIR/cur/30:2, ++MAIL_DIR/cur/31:2, ++MAIL_DIR/cur/32:2, ++MAIL_DIR/cur/33:2, ++MAIL_DIR/cur/34:2, ++MAIL_DIR/cur/35:2, ++MAIL_DIR/cur/36:2, ++MAIL_DIR/cur/37:2, ++MAIL_DIR/cur/38:2, ++MAIL_DIR/cur/39:2, ++MAIL_DIR/cur/40:2, ++MAIL_DIR/cur/41:2, ++MAIL_DIR/cur/42:2, ++MAIL_DIR/cur/43:2, ++MAIL_DIR/cur/44:2, ++MAIL_DIR/cur/45:2, ++MAIL_DIR/cur/46:2, ++MAIL_DIR/cur/47:2, ++MAIL_DIR/cur/48:2, ++MAIL_DIR/cur/49:2, ++MAIL_DIR/cur/50:2, ++MAIL_DIR/cur/51:2, ++MAIL_DIR/cur/52:2, ++MAIL_DIR/cur/53:2, ++MAIL_DIR/new/04:2," ++ ++test_begin_subtest "path: search" ++output=$(notmuch search --output=files path:"bar" | notmuch_search_files_sanitize | sort) ++# cur/51:2, is a duplicate of bar/18:2, ++test_expect_equal "$output" "MAIL_DIR/bar/17:2, ++MAIL_DIR/bar/18:2, ++MAIL_DIR/cur/51:2," ++ ++test_begin_subtest "top level path: search" ++output=$(notmuch search --output=files path:'""' | notmuch_search_files_sanitize | sort) ++test_expect_equal "$output" "MAIL_DIR/01:2, ++MAIL_DIR/02:2," ++ ++test_begin_subtest "recursive path: search" ++output=$(notmuch search --output=files path:"bar/**" | notmuch_search_files_sanitize | sort) ++# cur/51:2, is a duplicate of bar/18:2, ++test_expect_equal "$output" "MAIL_DIR/bar/17:2, ++MAIL_DIR/bar/18:2, ++MAIL_DIR/bar/baz/05:2, ++MAIL_DIR/bar/baz/23:2, ++MAIL_DIR/bar/baz/24:2, ++MAIL_DIR/bar/baz/cur/25:2, ++MAIL_DIR/bar/baz/cur/26:2, ++MAIL_DIR/bar/baz/new/27:2, ++MAIL_DIR/bar/baz/new/28:2, ++MAIL_DIR/bar/cur/19:2, ++MAIL_DIR/bar/cur/20:2, ++MAIL_DIR/bar/new/21:2, ++MAIL_DIR/bar/new/22:2, ++MAIL_DIR/cur/51:2," ++ ++test_done +-- +1.8.5.3 +