summaryrefslogtreecommitdiff
path: root/t/t9103-git-svn-graft-branches.sh
blob: 183ae3b1c2f0511810c18418c109a2e1412fa8a8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
#!/bin/sh
test_description='git-svn graft-branches'
. ./lib-git-svn.sh

svnrepo="$svnrepo/test-git-svn"

test_expect_success 'initialize repo' "
	mkdir import &&
	cd import &&
	mkdir -p trunk branches tags &&
	echo hello > trunk/readme &&
	svn import -m 'import for git-svn' . $svnrepo &&
	cd .. &&
	svn cp -m 'tag a' $svnrepo/trunk $svnrepo/tags/a &&
	svn cp -m 'branch a' $svnrepo/trunk $svnrepo/branches/a &&
	svn co $svnrepo wc &&
	cd wc &&
	echo feedme >> branches/a/readme &&
	poke branches/a/readme &&
	svn commit -m hungry &&
	cd trunk &&
	svn merge -r3:4 $svnrepo/branches/a &&
	svn commit -m 'merge with a' &&
	cd ../.. &&
	git-svn multi-init $svnrepo -T trunk -b branches -t tags &&
	git-svn multi-fetch
	"

r1=`git-rev-list remotes/trunk | tail -n1`
r2=`git-rev-list remotes/tags/a | tail -n1`
r3=`git-rev-list remotes/a | tail -n1`
r4=`git-rev-parse remotes/a`
r5=`git-rev-parse remotes/trunk`

test_expect_success 'test graft-branches regexes and copies' "
	test -n "$r1" &&
	test -n "$r2" &&
	test -n "$r3" &&
	test -n "$r4" &&
	test -n "$r5" &&
	git-svn graft-branches &&
	grep '^$r2 $r1' $GIT_DIR/info/grafts &&
	grep '^$r3 $r1' $GIT_DIR/info/grafts &&
	grep '^$r5 ' $GIT_DIR/info/grafts | grep '$r4' | grep '$r1'
	"

test_debug 'gitk --all & sleep 1'

test_expect_success 'test graft-branches with tree-joins' "
	rm $GIT_DIR/info/grafts &&
	git-svn graft-branches --no-default-regex --no-graft-copy -B &&
	grep '^$r3 ' $GIT_DIR/info/grafts | grep '$r1' | grep '$r2' &&
	grep '^$r2 $r1' $GIT_DIR/info/grafts &&
	grep '^$r5 ' $GIT_DIR/info/grafts | grep '$r1' | grep '$r4'
	"

# the result of this is kinda funky, we have a strange history and
# this is just a test :)
test_debug 'gitk --all &'

test_done