2010-06-12 07:33:53 +02:00
|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
# see some sample tests for how to use these functions; there is not
|
|
|
|
# documentation
|
|
|
|
|
|
|
|
testnum=0
|
|
|
|
subtests=0
|
|
|
|
|
|
|
|
# remote local command
|
|
|
|
runlocal() { "$@" > ~/1 2> ~/2; }
|
|
|
|
# remote run command
|
|
|
|
runremote() { ssh gitolite-test@localhost "$@" > ~/1 2> ~/2; }
|
|
|
|
# remote list repositories
|
|
|
|
listrepos() { ssh gitolite-test@localhost find repositories -type d -name "*.git" | sort > ~/1 2> ~/2; }
|
|
|
|
# remote cat compiled pm
|
|
|
|
catconf() { ssh gitolite-test@localhost cat .gitolite/conf/gitolite.conf-compiled.pm > ~/1 2> ~/2; }
|
|
|
|
# remote cat ~/.gitolite.rc
|
|
|
|
catrc() { ssh gitolite-test@localhost cat .gitolite.rc > ~/1 2> ~/2; }
|
|
|
|
# tail gitolite logfile
|
|
|
|
taillog() { ssh gitolite-test@localhost tail $1 .gitolite/logs/gitolite-????-??.log > ~/1 2> ~/2; }
|
|
|
|
hl() { # highlight function
|
|
|
|
normal=`tput sgr0`
|
|
|
|
red=`tput sgr0; tput setaf 1; tput bold`
|
|
|
|
if [[ -n $1 ]]
|
|
|
|
then
|
|
|
|
echo $red"$@"$normal
|
|
|
|
else
|
|
|
|
echo $red
|
|
|
|
cat
|
|
|
|
echo $normal
|
|
|
|
fi
|
|
|
|
}
|
2010-06-25 16:40:55 +02:00
|
|
|
pause() { echo pausing, "$@"\; hit enter or ctrl-c...; read; }
|
2010-06-12 07:33:53 +02:00
|
|
|
|
|
|
|
capture() { cf=$1; shift; "$@" >& $TESTDIR/$cf; }
|
|
|
|
|
|
|
|
editrc() {
|
|
|
|
scp gitolite-test@localhost:.gitolite.rc ~/junk >/dev/null
|
2010-11-06 06:16:44 +01:00
|
|
|
perl -pi -e "print STDERR if not /^#/ and /$1\b/ and s/=.*/= $2;/" ~/junk
|
2010-06-12 07:33:53 +02:00
|
|
|
scp ~/junk gitolite-test@localhost:.gitolite.rc >/dev/null
|
|
|
|
}
|
|
|
|
|
2010-06-26 02:00:15 +02:00
|
|
|
addrc() {
|
|
|
|
ssh gitolite-test@localhost cat .gitolite.rc < /dev/null > ~/junk
|
|
|
|
tee -a ~/junk
|
|
|
|
echo '1;' >> ~/junk
|
|
|
|
scp ~/junk gitolite-test@localhost:.gitolite.rc >/dev/null
|
|
|
|
}
|
|
|
|
|
2010-06-12 07:33:53 +02:00
|
|
|
ugc ()
|
|
|
|
{
|
|
|
|
(
|
|
|
|
cd ~/gitolite-admin;
|
|
|
|
[[ $1 == -r ]] && {
|
|
|
|
shift
|
|
|
|
cat $TESTDIR/basic.conf > conf/gitolite.conf
|
|
|
|
}
|
|
|
|
cat >> conf/gitolite.conf
|
|
|
|
git add conf keydir;
|
|
|
|
git commit --allow-empty -m "$TESTNAME";
|
|
|
|
git push ${1:-gitolite}:gitolite-admin master
|
|
|
|
git fetch origin >/dev/null 2>&1
|
|
|
|
) >~/1 2>~/2
|
2010-07-20 09:09:06 +02:00
|
|
|
grep DBG: ~/2 >/dev/null && grep . ~/1 ~/2
|
2010-06-12 07:33:53 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
mdc()
|
|
|
|
{
|
|
|
|
(
|
|
|
|
echo $RANDOM > ${1:-$RANDOM}
|
|
|
|
git add .
|
|
|
|
git commit -m "$TESTNAME"
|
|
|
|
) >~/1 2>~/2
|
|
|
|
}
|
|
|
|
|
|
|
|
# flush result of last test when next one comes along
|
|
|
|
testdone() {
|
|
|
|
[[ $subtests > 1 ]] && TESTNAME="($subtests) $TESTNAME"
|
|
|
|
echo -e $testnum\\t$TESTNAME
|
|
|
|
}
|
|
|
|
|
|
|
|
# set test name/desc
|
|
|
|
name() {
|
|
|
|
if [[ -n $TESTNAME ]]
|
|
|
|
then
|
|
|
|
if [[ $TESTNAME != INTERNAL ]]
|
|
|
|
then
|
|
|
|
(( testnum++ ))
|
|
|
|
testdone
|
|
|
|
fi
|
|
|
|
subtests=0
|
|
|
|
fi
|
|
|
|
export TESTNAME="$*"
|
|
|
|
}
|
|
|
|
|
|
|
|
notok() {
|
|
|
|
echo ----------
|
|
|
|
head -999 ~/1 ~/2 | sed -e 's/^/ /'
|
|
|
|
}
|
|
|
|
|
|
|
|
expect_filesame() {
|
|
|
|
if cmp ~/1 "$1"
|
|
|
|
then
|
|
|
|
(( subtests++ ))
|
|
|
|
else
|
|
|
|
echo files ~/1 and "$1" are different
|
|
|
|
echo '*** ABORTING ***'
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
die() {
|
|
|
|
echo '***** AAAAARRRGGH! *****'
|
|
|
|
echo ${BASH_LINENO[1]} ${BASH_SOURCE[2]}
|
|
|
|
read
|
|
|
|
cd $TESTDIR
|
|
|
|
vim +${BASH_LINENO[1]} '+r !head ~/1 ~/2 /dev/null' ${BASH_SOURCE[2]}
|
|
|
|
exit 1
|
|
|
|
}
|
|
|
|
|
|
|
|
expect() {
|
|
|
|
if cat ~/1 ~/2 | grep "$1" >/dev/null
|
|
|
|
then
|
|
|
|
(( subtests++ ))
|
|
|
|
else
|
|
|
|
notok
|
|
|
|
echo ----------
|
|
|
|
echo " expecting: $1"
|
|
|
|
echo ----------
|
|
|
|
die $TESTNAME
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
notexpect() {
|
|
|
|
if cat ~/1 ~/2 | grep "$1" >/dev/null
|
|
|
|
then
|
|
|
|
notok
|
|
|
|
echo "NOT expecting: $1"
|
|
|
|
echo ----------
|
|
|
|
die $TESTNAME
|
|
|
|
exit 1
|
|
|
|
else
|
|
|
|
(( subtests++ ))
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
print_summary() {
|
|
|
|
echo -e "==========\n$testnum tests succeeded"
|
|
|
|
}
|
|
|
|
|
|
|
|
expect_push_ok() {
|
|
|
|
expect "$1"
|
|
|
|
notexpect "DENIED"
|
|
|
|
notexpect "failed to push"
|
|
|
|
}
|
|
|
|
|
|
|
|
export TESTDIR=$PWD
|
|
|
|
arg1=$1; shift
|
|
|
|
for testfile in ${arg1:-t??-}*
|
|
|
|
do
|
|
|
|
hl $testfile
|
2010-06-18 18:13:53 +02:00
|
|
|
. $testfile "$@" || die "$testfile failed"
|
2010-06-12 07:33:53 +02:00
|
|
|
cd $TESTDIR
|
|
|
|
done
|
|
|
|
|
|
|
|
print_summary
|