]>
Commit | Line | Data |
---|---|---|
60d02ccc EW |
1 | . ./test-lib.sh |
2 | ||
16805d3e NS |
3 | remotes_git_svn=remotes/git""-svn |
4 | git_svn_id=git""-svn-id | |
5 | ||
60d02ccc | 6 | if test -n "$NO_SVN_TESTS" |
36f5b1f0 | 7 | then |
60d02ccc EW |
8 | test_expect_success 'skipping git-svn tests, NO_SVN_TESTS defined' : |
9 | test_done | |
10 | exit | |
36f5b1f0 EW |
11 | fi |
12 | ||
b9c85187 EW |
13 | GIT_DIR=$PWD/.git |
14 | GIT_SVN_DIR=$GIT_DIR/svn/git-svn | |
15 | SVN_TREE=$GIT_SVN_DIR/svn-tree | |
16 | ||
36f5b1f0 | 17 | svn >/dev/null 2>&1 |
4b832e81 | 18 | if test $? -ne 1 |
36f5b1f0 | 19 | then |
60d02ccc | 20 | test_expect_success 'skipping git-svn tests, svn not found' : |
36f5b1f0 EW |
21 | test_done |
22 | exit | |
23 | fi | |
24 | ||
25 | svnrepo=$PWD/svnrepo | |
cdf3ec01 | 26 | export svnrepo |
36f5b1f0 | 27 | |
c6d499a8 EW |
28 | perl -w -e " |
29 | use SVN::Core; | |
30 | use SVN::Repos; | |
31 | \$SVN::Core::VERSION gt '1.1.0' or exit(42); | |
cdf3ec01 | 32 | system(qw/svnadmin create --fs-type fsfs/, \$ENV{svnrepo}) == 0 or exit(41); |
38434f2e | 33 | " >&3 2>&4 |
c6d499a8 EW |
34 | x=$? |
35 | if test $x -ne 0 | |
dc62e25c | 36 | then |
c6d499a8 EW |
37 | if test $x -eq 42; then |
38 | err='Perl SVN libraries must be >= 1.1.0' | |
e66191f4 EW |
39 | elif test $x -eq 41; then |
40 | err='svnadmin failed to create fsfs repository' | |
c6d499a8 EW |
41 | else |
42 | err='Perl SVN libraries not found or unusable, skipping test' | |
43 | fi | |
44 | test_expect_success "$err" : | |
45 | test_done | |
46 | exit | |
dc62e25c EW |
47 | fi |
48 | ||
2edb9c5c | 49 | rawsvnrepo="$svnrepo" |
e1516119 | 50 | svnrepo="file://$svnrepo" |
36f5b1f0 | 51 | |
7b3fab87 | 52 | poke() { |
56cf9806 | 53 | test-chmtime +1 "$1" |
7b3fab87 | 54 | } |
29633bb9 | 55 | |
3644da72 KB |
56 | for d in \ |
57 | "$SVN_HTTPD_PATH" \ | |
58 | /usr/sbin/apache2 \ | |
59 | /usr/sbin/httpd \ | |
60 | ; do | |
61 | if test -f "$d" | |
62 | then | |
63 | SVN_HTTPD_PATH="$d" | |
64 | break | |
65 | fi | |
66 | done | |
67 | for d in \ | |
68 | "$SVN_HTTPD_MODULE_PATH" \ | |
69 | /usr/lib/apache2/modules \ | |
70 | /usr/libexec/apache2 \ | |
71 | ; do | |
72 | if test -d "$d" | |
73 | then | |
74 | SVN_HTTPD_MODULE_PATH="$d" | |
75 | break | |
76 | fi | |
77 | done | |
29633bb9 EW |
78 | |
79 | start_httpd () { | |
d1a8d0ea | 80 | repo_base_path="$1" |
29633bb9 EW |
81 | if test -z "$SVN_HTTPD_PORT" |
82 | then | |
83 | echo >&2 'SVN_HTTPD_PORT is not defined!' | |
84 | return | |
85 | fi | |
d1a8d0ea EW |
86 | if test -z "$repo_base_path" |
87 | then | |
88 | repo_base_path=svn | |
89 | fi | |
29633bb9 EW |
90 | |
91 | mkdir "$GIT_DIR"/logs | |
92 | ||
93 | cat > "$GIT_DIR/httpd.conf" <<EOF | |
94 | ServerName "git-svn test" | |
95 | ServerRoot "$GIT_DIR" | |
96 | DocumentRoot "$GIT_DIR" | |
97 | PidFile "$GIT_DIR/httpd.pid" | |
3644da72 | 98 | LockFile logs/accept.lock |
29633bb9 EW |
99 | Listen 127.0.0.1:$SVN_HTTPD_PORT |
100 | LoadModule dav_module $SVN_HTTPD_MODULE_PATH/mod_dav.so | |
101 | LoadModule dav_svn_module $SVN_HTTPD_MODULE_PATH/mod_dav_svn.so | |
d1a8d0ea | 102 | <Location /$repo_base_path> |
29633bb9 | 103 | DAV svn |
3901a8c8 | 104 | SVNPath "$rawsvnrepo" |
29633bb9 EW |
105 | </Location> |
106 | EOF | |
107 | "$SVN_HTTPD_PATH" -f "$GIT_DIR"/httpd.conf -k start | |
d1a8d0ea | 108 | svnrepo="http://127.0.0.1:$SVN_HTTPD_PORT/$repo_base_path" |
29633bb9 EW |
109 | } |
110 | ||
111 | stop_httpd () { | |
112 | test -z "$SVN_HTTPD_PORT" && return | |
113 | "$SVN_HTTPD_PATH" -f "$GIT_DIR"/httpd.conf -k stop | |
114 | } | |
060610c5 EW |
115 | |
116 | convert_to_rev_db () { | |
117 | perl -w -- - "$@" <<\EOF | |
118 | use strict; | |
119 | @ARGV == 2 or die "Usage: convert_to_rev_db <input> <output>"; | |
120 | open my $wr, '+>', $ARGV[1] or die "$!: couldn't open: $ARGV[1]"; | |
121 | open my $rd, '<', $ARGV[0] or die "$!: couldn't open: $ARGV[0]"; | |
122 | my $size = (stat($rd))[7]; | |
123 | ($size % 24) == 0 or die "Inconsistent size: $size"; | |
124 | while (sysread($rd, my $buf, 24) == 24) { | |
125 | my ($r, $c) = unpack('NH40', $buf); | |
126 | my $offset = $r * 41; | |
127 | seek $wr, 0, 2 or die $!; | |
128 | my $pos = tell $wr; | |
129 | if ($pos < $offset) { | |
130 | for (1 .. (($offset - $pos) / 41)) { | |
131 | print $wr (('0' x 40),"\n") or die $!; | |
132 | } | |
133 | } | |
134 | seek $wr, $offset, 0 or die $!; | |
135 | print $wr $c,"\n" or die $!; | |
136 | } | |
137 | close $wr or die $!; | |
138 | close $rd or die $!; | |
139 | EOF | |
140 | } |