#!/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-SUFFIX>.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 <jani@nikula.org> # # 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