From febac1e0c8794b1fc9ab0b6945cfd6941ccdedb8 Mon Sep 17 00:00:00 2001 From: David Bremner Date: Sun, 9 Mar 2014 17:19:43 +2000 Subject: [PATCH] [Patch v3 13/15] devel: add script to generate test databases --- f1/b6a90b9aa602914864118cebe6fbe3fb6d88fa | 201 ++++++++++++++++++++++ 1 file changed, 201 insertions(+) create mode 100644 f1/b6a90b9aa602914864118cebe6fbe3fb6d88fa diff --git a/f1/b6a90b9aa602914864118cebe6fbe3fb6d88fa b/f1/b6a90b9aa602914864118cebe6fbe3fb6d88fa new file mode 100644 index 000000000..926ac4f5f --- /dev/null +++ b/f1/b6a90b9aa602914864118cebe6fbe3fb6d88fa @@ -0,0 +1,201 @@ +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 887C5431FC0 + for ; Sat, 8 Mar 2014 13:21:31 -0800 (PST) +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 0HE53Oay1AlG for ; + Sat, 8 Mar 2014 13:21:26 -0800 (PST) +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 B5107431FD0 + for ; Sat, 8 Mar 2014 13:20:47 -0800 (PST) +Received: from remotemail by yantan.tethera.net with local (Exim 4.80) + (envelope-from ) + id 1WMOfn-00059g-6A; Sat, 08 Mar 2014 17:20:47 -0400 +Received: (nullmailer pid 28552 invoked by uid 1000); Sat, 08 Mar 2014 + 21:20:03 -0000 +From: David Bremner +To: notmuch@notmuchmail.org +Subject: [Patch v3 13/15] devel: add script to generate test databases +Date: Sat, 8 Mar 2014 17:19:43 -0400 +Message-Id: <1394313585-28422-14-git-send-email-david@tethera.net> +X-Mailer: git-send-email 1.8.5.3 +In-Reply-To: <1394313585-28422-1-git-send-email-david@tethera.net> +References: <1394313585-28422-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: Sat, 08 Mar 2014 21:21:31 -0000 + +From: Jani Nikula + +Add script to generate notmuch test databases using specified versions +of notmuch. This is useful for generating material for database +upgrade tests. + +This reuses the test infrastructure to have a sandbox environment for +notmuch new etc. +--- + devel/gen-testdb.sh | 131 ++++++++++++++++++++++++++++++++++++++++++++++++++++ + 1 file changed, 131 insertions(+) + create mode 100755 devel/gen-testdb.sh + +diff --git a/devel/gen-testdb.sh b/devel/gen-testdb.sh +new file mode 100755 +index 0000000..621b31e +--- /dev/null ++++ b/devel/gen-testdb.sh +@@ -0,0 +1,131 @@ ++#!/usr/bin/env bash ++# ++# NAME ++# gen-testdb.sh - generate test databases ++# ++# SYNOPSIS ++# gen-testdb.sh -v NOTMUCH-VERSION [-c CORPUS-PATH] [-s TAR-SUFFIX] ++# ++# DESCRIPTION ++# Generate a tarball containing the specified test corpus and ++# the corresponding notmuch database, indexed using a specific ++# version of notmuch, resulting in a specific version of the ++# database. ++# ++# The specific version of notmuch will be built on the fly. ++# Therefore the script must be run within a git repository to be ++# able to build the old versions of notmuch. ++# ++# This script reuses the test infrastructure, and the script ++# must be run from within the test directory. ++# ++# The output tarballs, named database-.tar.gz, are ++# placed in the test/test-databases directory. ++# ++# OPTIONS ++# -v NOTMUCH-VERSION ++# Notmuch version in terms of a git tag or commit to use ++# for generating the database. Required. ++# ++# -c CORPUS-PATH ++# Path to a corpus to use for generating the ++# database. Due to CWD changes within the test ++# infrastructure, use absolute paths. Defaults to the ++# test corpus. ++# ++# -s TAR-SUFFIX ++# Suffix for the tarball basename. Empty by default. ++# ++# EXAMPLE ++# ++# Generate a database indexed with notmuch 0.17. Use the default ++# test corpus. Name the tarball database-v1.tar.gz to reflect ++# the fact that notmuch 0.17 used database version 1. ++# ++# $ cd test ++# $ ../devel/gen-testdb.sh -v 0.17 -s v1 ++# ++# CAVEATS ++# Test infrastructure options won't work. ++# ++# Any existing databases with the same name will be overwritten. ++# ++# It may not be possible to build old versions of notmuch with ++# the set of dependencies that satisfy building the current ++# version of notmuch. ++# ++# AUTHOR ++# Jani Nikula ++# ++# LICENSE ++# Same as notmuch test infrastructure (GPLv2+). ++# ++ ++test_description="database generation abusing test infrastructure" ++ ++# immediate exit on subtest failure; see test_failure_ in test-lib.sh ++immediate=t ++ ++VERSION= ++CORPUS= ++SUFFIX= ++ ++while getopts v:c:s: opt; do ++ case "$opt" in ++ v) VERSION="$OPTARG";; ++ c) CORPUS="$OPTARG";; ++ s) SUFFIX="-$OPTARG";; ++ esac ++done ++shift `expr $OPTIND - 1` ++ ++. ./test-lib.sh ++ ++SHORT_CORPUS=$(basename ${CORPUS:-database}) ++DBNAME=${SHORT_CORPUS}${SUFFIX} ++TARBALLNAME=${DBNAME}.tar.xz ++ ++CORPUS=${CORPUS:-${TEST_DIRECTORY}/corpus} ++ ++test_expect_code 0 "notmuch version specified on the command line" \ ++ "test -n ${VERSION}" ++ ++test_expect_code 0 "the specified version ${VERSION} refers to a commit" \ ++ "git show ${VERSION} >/dev/null 2>&1" ++ ++BUILD_DIR="notmuch-${VERSION}" ++test_expect_code 0 "generate snapshot of notmuch version ${VERSION}" \ ++ "git -C $TEST_DIRECTORY/.. archive --prefix=${BUILD_DIR}/ --format=tar ${VERSION} | tar x" ++ ++# force version string ++git describe --match '[0-9.]*' ${VERSION} > ${BUILD_DIR}/version ++ ++test_expect_code 0 "configure and build notmuch version ${VERSION}" \ ++ "make -C ${BUILD_DIR}" ++ ++# use the newly built notmuch ++export PATH=./${BUILD_DIR}:$PATH ++ ++test_begin_subtest "verify the newly built notmuch version" ++test_expect_equal "`notmuch --version`" "notmuch `cat ${BUILD_DIR}/version`" ++ ++# replace the existing mails, if any, with the specified corpus ++rm -rf ${MAIL_DIR} ++cp -a ${CORPUS} ${MAIL_DIR} ++ ++test_expect_code 0 "index the corpus" \ ++ "notmuch new" ++ ++# wrap the resulting mail store and database in a tarball ++ ++cp -a ${MAIL_DIR} ${TMP_DIRECTORY}/${DBNAME} ++tar Jcf ${TMP_DIRECTORY}/${TARBALLNAME} -C ${TMP_DIRECTORY} ${DBNAME} ++mkdir -p ${TEST_DIRECTORY}/test-databases ++cp -a ${TMP_DIRECTORY}/${TARBALLNAME} ${TEST_DIRECTORY}/test-databases ++test_expect_code 0 "create the output tarball ${TARBALLNAME}" \ ++ "test -f ${TEST_DIRECTORY}/test-databases/${TARBALLNAME}" ++ ++# generate a checksum file ++test_expect_code 0 "compute checksum" \ ++ "(cd ${TEST_DIRECTORY}/test-databases/ && sha256sum ${TARBALLNAME} > ${TARBALLNAME}.sha256)" ++test_done +-- +1.8.5.3 + -- 2.26.2