mirror of
https://git.notmuchmail.org/git/notmuch
synced 2025-01-10 02:31:48 +01:00
02a2eeb427
The files (test) scripts source (with builtin command `.`) provides information which the scripts depend, and without the `source` to succeed allowing script to continue may lead to dangerous situations (e.g. rm -rf "${undefined_variable}"/*). At the end of all source (.) lines construct ' || exit 1' was added; In our case the script script will exit if it cannot find (or read) the file to be sourced. Additionally script would also exits if the last command of the sourced file exited nonzero.
131 lines
3.8 KiB
Bash
Executable file
131 lines
3.8 KiB
Bash
Executable file
#!/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 || exit 1
|
|
|
|
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
|