mirror of
https://github.com/git/git.git
synced 2024-11-28 12:34:08 +08:00
e1c0c158b1
These variables were added in 16805d3
(t/t91XX-svn: start
removing use of "git-" from these tests, 2008-09-08) so that
running:
git grep git-
would return fewer hits. At the time, we were transitioning
away from the use of the "dashed" git-foo form.
That transition has been over for years, and grepping for
"git-" in the test suite yields thousands of hits anyway
(all presumably false positives).
With their original purpose gone, these variables serve only
to obfuscate the tests. Let's get rid of them.
Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
198 lines
4.1 KiB
Bash
198 lines
4.1 KiB
Bash
. ./test-lib.sh
|
|
|
|
if test -n "$NO_SVN_TESTS"
|
|
then
|
|
skip_all='skipping git svn tests, NO_SVN_TESTS defined'
|
|
test_done
|
|
fi
|
|
if ! test_have_prereq PERL; then
|
|
skip_all='skipping git svn tests, perl not available'
|
|
test_done
|
|
fi
|
|
|
|
GIT_DIR=$PWD/.git
|
|
GIT_SVN_DIR=$GIT_DIR/svn/refs/remotes/git-svn
|
|
SVN_TREE=$GIT_SVN_DIR/svn-tree
|
|
|
|
svn >/dev/null 2>&1
|
|
if test $? -ne 1
|
|
then
|
|
skip_all='skipping git svn tests, svn not found'
|
|
test_done
|
|
fi
|
|
|
|
svnrepo=$PWD/svnrepo
|
|
export svnrepo
|
|
svnconf=$PWD/svnconf
|
|
export svnconf
|
|
|
|
perl -w -e "
|
|
use SVN::Core;
|
|
use SVN::Repos;
|
|
\$SVN::Core::VERSION gt '1.1.0' or exit(42);
|
|
system(qw/svnadmin create --fs-type fsfs/, \$ENV{svnrepo}) == 0 or exit(41);
|
|
" >&3 2>&4
|
|
x=$?
|
|
if test $x -ne 0
|
|
then
|
|
if test $x -eq 42; then
|
|
skip_all='Perl SVN libraries must be >= 1.1.0'
|
|
elif test $x -eq 41; then
|
|
skip_all='svnadmin failed to create fsfs repository'
|
|
else
|
|
skip_all='Perl SVN libraries not found or unusable'
|
|
fi
|
|
test_done
|
|
fi
|
|
|
|
rawsvnrepo="$svnrepo"
|
|
svnrepo="file://$svnrepo"
|
|
|
|
poke() {
|
|
test-chmtime +1 "$1"
|
|
}
|
|
|
|
# We need this, because we should pass empty configuration directory to
|
|
# the 'svn commit' to avoid automated property changes and other stuff
|
|
# that could be set from user's configuration files in ~/.subversion.
|
|
svn_cmd () {
|
|
[ -d "$svnconf" ] || mkdir "$svnconf"
|
|
orig_svncmd="$1"; shift
|
|
if [ -z "$orig_svncmd" ]; then
|
|
svn
|
|
return
|
|
fi
|
|
svn "$orig_svncmd" --config-dir "$svnconf" "$@"
|
|
}
|
|
|
|
prepare_httpd () {
|
|
for d in \
|
|
"$SVN_HTTPD_PATH" \
|
|
/usr/sbin/apache2 \
|
|
/usr/sbin/httpd \
|
|
; do
|
|
if test -f "$d"
|
|
then
|
|
SVN_HTTPD_PATH="$d"
|
|
break
|
|
fi
|
|
done
|
|
if test -z "$SVN_HTTPD_PATH"
|
|
then
|
|
echo >&2 '*** error: Apache not found'
|
|
return 1
|
|
fi
|
|
for d in \
|
|
"$SVN_HTTPD_MODULE_PATH" \
|
|
/usr/lib/apache2/modules \
|
|
/usr/libexec/apache2 \
|
|
; do
|
|
if test -d "$d"
|
|
then
|
|
SVN_HTTPD_MODULE_PATH="$d"
|
|
break
|
|
fi
|
|
done
|
|
if test -z "$SVN_HTTPD_MODULE_PATH"
|
|
then
|
|
echo >&2 '*** error: Apache module dir not found'
|
|
return 1
|
|
fi
|
|
if test ! -f "$SVN_HTTPD_MODULE_PATH/mod_dav_svn.so"
|
|
then
|
|
echo >&2 '*** error: Apache module "mod_dav_svn" not found'
|
|
return 1
|
|
fi
|
|
|
|
repo_base_path="${1-svn}"
|
|
mkdir "$GIT_DIR"/logs
|
|
|
|
cat > "$GIT_DIR/httpd.conf" <<EOF
|
|
ServerName "git svn test"
|
|
ServerRoot "$GIT_DIR"
|
|
DocumentRoot "$GIT_DIR"
|
|
PidFile "$GIT_DIR/httpd.pid"
|
|
LockFile logs/accept.lock
|
|
Listen 127.0.0.1:$SVN_HTTPD_PORT
|
|
LoadModule dav_module $SVN_HTTPD_MODULE_PATH/mod_dav.so
|
|
LoadModule dav_svn_module $SVN_HTTPD_MODULE_PATH/mod_dav_svn.so
|
|
<Location /$repo_base_path>
|
|
DAV svn
|
|
SVNPath "$rawsvnrepo"
|
|
</Location>
|
|
EOF
|
|
}
|
|
|
|
start_httpd () {
|
|
if test -z "$SVN_HTTPD_PORT"
|
|
then
|
|
echo >&2 'SVN_HTTPD_PORT is not defined!'
|
|
return
|
|
fi
|
|
|
|
prepare_httpd "$1" || return 1
|
|
|
|
"$SVN_HTTPD_PATH" -f "$GIT_DIR"/httpd.conf -k start
|
|
svnrepo="http://127.0.0.1:$SVN_HTTPD_PORT/$repo_base_path"
|
|
}
|
|
|
|
stop_httpd () {
|
|
test -z "$SVN_HTTPD_PORT" && return
|
|
test ! -f "$GIT_DIR/httpd.conf" && return
|
|
"$SVN_HTTPD_PATH" -f "$GIT_DIR"/httpd.conf -k stop
|
|
}
|
|
|
|
convert_to_rev_db () {
|
|
perl -w -- - "$@" <<\EOF
|
|
use strict;
|
|
@ARGV == 2 or die "usage: convert_to_rev_db <input> <output>";
|
|
open my $wr, '+>', $ARGV[1] or die "$!: couldn't open: $ARGV[1]";
|
|
open my $rd, '<', $ARGV[0] or die "$!: couldn't open: $ARGV[0]";
|
|
my $size = (stat($rd))[7];
|
|
($size % 24) == 0 or die "Inconsistent size: $size";
|
|
while (sysread($rd, my $buf, 24) == 24) {
|
|
my ($r, $c) = unpack('NH40', $buf);
|
|
my $offset = $r * 41;
|
|
seek $wr, 0, 2 or die $!;
|
|
my $pos = tell $wr;
|
|
if ($pos < $offset) {
|
|
for (1 .. (($offset - $pos) / 41)) {
|
|
print $wr (('0' x 40),"\n") or die $!;
|
|
}
|
|
}
|
|
seek $wr, $offset, 0 or die $!;
|
|
print $wr $c,"\n" or die $!;
|
|
}
|
|
close $wr or die $!;
|
|
close $rd or die $!;
|
|
EOF
|
|
}
|
|
|
|
require_svnserve () {
|
|
if test -z "$SVNSERVE_PORT"
|
|
then
|
|
skip_all='skipping svnserve test. (set $SVNSERVE_PORT to enable)'
|
|
test_done
|
|
fi
|
|
}
|
|
|
|
start_svnserve () {
|
|
svnserve --listen-port $SVNSERVE_PORT \
|
|
--root "$rawsvnrepo" \
|
|
--listen-once \
|
|
--listen-host 127.0.0.1 &
|
|
}
|
|
|
|
prepare_a_utf8_locale () {
|
|
a_utf8_locale=$(locale -a | sed -n '/\.[uU][tT][fF]-*8$/{
|
|
p
|
|
q
|
|
}')
|
|
if test -n "$a_utf8_locale"
|
|
then
|
|
test_set_prereq UTF8
|
|
else
|
|
say "# UTF-8 locale not available, some tests are skipped"
|
|
fi
|
|
}
|