#!/bin/bash # # Tests when a git mirror fails that it keeps the backups around # # Copyright (C) 2012-2013 Codethink Limited # # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation; version 2 of the License. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License along # with this program; if not, write to the Free Software Foundation, Inc., # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. set -e set -o pipefail logfile="$DATADIR/git-backup-test-repo.log" workdir="$DATADIR/work-dir" repo="$DATADIR/git-backup-test-repo" normalize() { DATETIMESPEC='[0-9]*-[0-9]*-[0-9]*-[0-9]*:[0-9]*:[0-9]*' sed -r -e "s|git-pre-update-$DATETIMESPEC|git-pre-update-DATETIME|g" \ -e "s|git-post-fail-$DATETIMESPEC|git-post-fail-DATETIME|g" \ -e "s/pack-[0-9a-z]+\.(idx|pack)$/pack-file/" \ -e '/hooks\/.*\.sample/d' \ -e "/\/objects\/info\/commit-graph$/d" \ -e "/\/objects\/pack\/pack-[0-9a-z]+\.bitmap$/d" \ -e "s|$DATADIR|DATADIR|g" "$@" } # mirror some history "${SRCDIR}/test-lorry" --pull-only --log="$logfile" --working-area="$workdir" --bundle=never \ "$DATADIR/git-backup-test-repo.lorry" | normalize # make upstream disappear to cause errors rm -rf "$repo" if "${SRCDIR}/test-lorry" --pull-only --log="$logfile" --working-area="$workdir" \ "$DATADIR/git-backup-test-repo.lorry" --bundle=never 2>/dev/null \ --keep-multiple-backups | normalize then echo Previous lorry command should have failed >&2 exit 1 else find "$workdir/git-backup-test-repo" | LC_ALL=C sort | normalize grep -H . "$workdir/git-backup-test-repo/git"*"/lorry-update-count" | normalize fi