3 # Copyright (c) 2010 Sverre Rabbelier
6 test_description
='Test remote-helper import and export commands'
10 if ! type "${BASH-bash}" >/dev
/null
2>&1; then
11 skip_all
='skipping remote-testgit tests, bash not available'
16 git
--git-dir="$1/.git" rev-parse
--verify $2 >expect
&&
17 git
--git-dir="$3/.git" rev-parse
--verify $4 >actual
&&
18 test_cmp expect actual
21 test_expect_success
'setup repository' '
22 git init --bare server/.git &&
23 git clone server public &&
28 git push origin master)
31 test_expect_success
'cloning from local repo' '
32 git clone "testgit::${PWD}/server" localclone &&
33 test_cmp public/file localclone/file
36 test_expect_success
'create new commit on remote' '
38 echo content >>file &&
39 git commit -a -m two &&
43 test_expect_success
'pulling from local repo' '
44 (cd localclone && git pull) &&
45 test_cmp public/file localclone/file
48 test_expect_success
'pushing to local repo' '
50 echo content >>file &&
51 git commit -a -m three &&
53 compare_refs localclone HEAD server HEAD
56 # Generally, skip this test. It demonstrates a now-fixed race in
57 # git-remote-testgit, but is too slow to leave in for general use.
58 : test_expect_success
'racily pushing to local repo' '
59 test_when_finished "rm -rf server2 localclone2" &&
60 cp -R server server2 &&
61 git clone "testgit::${PWD}/server2" localclone2 &&
63 echo content >>file &&
64 git commit -a -m three &&
65 GIT_REMOTE_TESTGIT_SLEEPY=2 git push) &&
66 compare_refs localclone2 HEAD server2 HEAD
69 test_expect_success
'fetch new branch' '
71 git checkout -b new &&
72 echo content >>file &&
73 git commit -a -m five &&
79 compare_refs public HEAD localclone FETCH_HEAD
83 # This is only needed because of a bug not detected by this script. It will be
84 # fixed shortly, but for now lets not cause regressions.
86 test_expect_success
'bump commit in public' '
88 git checkout master &&
90 echo content >>file &&
91 git commit -a -m four &&
93 compare_refs public HEAD server HEAD
96 test_expect_success
'fetch multiple branches' '
100 compare_refs server master localclone refs/remotes/origin/master &&
101 compare_refs server new localclone refs/remotes/origin/new
104 test_expect_success
'push when remote has extra refs' '
106 git reset --hard origin/master &&
107 echo content >>file &&
108 git commit -a -m six &&
111 compare_refs localclone master server master
114 test_expect_success
'push new branch by name' '
116 git checkout -b new-name &&
117 echo content >>file &&
118 git commit -a -m seven &&
119 git push origin new-name
121 compare_refs localclone HEAD server refs/heads/new-name
124 test_expect_failure
'push new branch with old:new refspec' '
126 git push origin new-name:new-refspec
128 compare_refs localclone HEAD server refs/heads/new-refspec