3 test_description='pulling into void'
8 sed -e "$1" <"$2" >"$2.x" &&
14 test_expect_success setup '
18 git commit -a -m original
22 test_expect_success 'pulling into void' '
31 test_expect_success 'checking the results' '
33 test -f cloned/file &&
34 test_cmp file cloned/file
37 test_expect_success 'pulling into void using master:master' '
42 git pull .. master:master
45 test -f cloned-uho/file &&
46 test_cmp file cloned-uho/file
49 test_expect_success 'pulling into void does not overwrite untracked files' '
50 git init cloned-untracked &&
52 cd cloned-untracked &&
53 echo untracked >file &&
54 test_must_fail git pull .. master &&
55 echo untracked >expect &&
60 test_expect_success 'test . as a remote' '
62 git branch copy master &&
63 git config branch.copy.remote . &&
64 git config branch.copy.merge refs/heads/master &&
66 git commit -a -m updated &&
68 test `cat file` = file &&
70 test `cat file` = updated
73 test_expect_success 'the default remote . should not break explicit pull' '
74 git checkout -b second master^ &&
75 echo modified >file &&
76 git commit -a -m modified &&
78 git reset --hard HEAD^ &&
79 test `cat file` = file &&
81 test `cat file` = modified
84 test_expect_success '--rebase' '
85 git branch to-rebase &&
86 echo modified again > file &&
87 git commit -m file file &&
88 git checkout to-rebase &&
91 git commit -m "new file" &&
92 git tag before-rebase &&
93 git pull --rebase . copy &&
94 test $(git rev-parse HEAD^) = $(git rev-parse copy) &&
95 test new = $(git show HEAD:file2)
98 test_expect_success 'branch.to-rebase.rebase' '
99 git reset --hard before-rebase &&
100 git config branch.to-rebase.rebase 1 &&
102 git config branch.to-rebase.rebase 0 &&
103 test $(git rev-parse HEAD^) = $(git rev-parse copy) &&
104 test new = $(git show HEAD:file2)
107 test_expect_success '--rebase with rebased upstream' '
109 git remote add -f me . &&
112 git reset --hard HEAD^ &&
113 echo conflicting modification > file &&
114 git commit -m conflict file &&
115 git checkout to-rebase &&
117 git commit -m to-rebase file2 &&
118 git tag to-rebase-orig &&
119 git pull --rebase me copy &&
120 test "conflicting modification" = "$(cat file)" &&
121 test file = $(cat file2)
125 test_expect_success '--rebase with rebased default upstream' '
127 git update-ref refs/remotes/me/copy copy-orig &&
128 git checkout --track -b to-rebase2 me/copy &&
129 git reset --hard to-rebase-orig &&
131 test "conflicting modification" = "$(cat file)" &&
132 test file = $(cat file2)
136 test_expect_success 'rebased upstream + fetch + pull --rebase' '
138 git update-ref refs/remotes/me/copy copy-orig &&
139 git reset --hard to-rebase-orig &&
140 git checkout --track -b to-rebase3 me/copy &&
141 git reset --hard to-rebase-orig &&
144 test "conflicting modification" = "$(cat file)" &&
145 test file = "$(cat file2)"
149 test_expect_success 'pull --rebase dies early with dirty working directory' '
151 git checkout to-rebase &&
152 git update-ref refs/remotes/me/copy copy^ &&
153 COPY=$(git rev-parse --verify me/copy) &&
154 git rebase --onto $COPY copy &&
155 git config branch.to-rebase.remote me &&
156 git config branch.to-rebase.merge refs/heads/copy &&
157 git config branch.to-rebase.rebase true &&
158 echo dirty >> file &&
160 test_must_fail git pull &&
161 test $COPY = $(git rev-parse --verify me/copy) &&
162 git checkout HEAD -- file &&
164 test $COPY != $(git rev-parse --verify me/copy)
168 test_expect_success 'pull --rebase works on branch yet to be born' '
169 git rev-parse master >expect &&
173 git pull --rebase .. master &&
174 git rev-parse HEAD >../actual
176 test_cmp expect actual
179 test_expect_success 'setup for detecting upstreamed changes' '
183 printf "1\n2\n3\n4\n5\n6\n7\n8\n9\n10\n" > stuff &&
185 git commit -m "Initial revision"
189 modify s/5/43/ stuff &&
190 git commit -a -m "5->43" &&
191 modify s/6/42/ stuff &&
192 git commit -a -m "Make it bigger"
195 modify s/5/43/ stuff &&
196 git commit -a -m "Independent discovery of 5->43"
200 test_expect_success 'git pull --rebase detects upstreamed changes' '
203 test -z "$(git ls-files -u)"
207 test_expect_success 'setup for avoiding reapplying old patches' '
209 test_might_fail git rebase --abort &&
210 git reset --hard origin/master
212 git clone --bare src src-replace.git &&
214 mv src-replace.git src &&
216 modify s/2/22/ stuff &&
217 git commit -a -m "Change 2" &&
218 modify s/3/33/ stuff &&
219 git commit -a -m "Change 3" &&
220 modify s/4/44/ stuff &&
221 git commit -a -m "Change 4" &&
224 modify s/44/55/ stuff &&
225 git commit --amend -a -m "Modified Change 4"
229 test_expect_success 'git pull --rebase does not reapply old patches' '
231 test_must_fail git pull --rebase &&
232 test 1 = $(find .git/rebase-apply -name "000*" | wc -l)
236 test_expect_success 'git pull --rebase against local branch' '
237 git checkout -b copy2 to-rebase-orig &&
238 git pull --rebase . to-rebase &&
239 test "conflicting modification" = "$(cat file)" &&
240 test file = "$(cat file2)"