3 test_description
='pull options'
7 test_expect_success
'setup' '
9 (cd parent && git init &&
10 echo one >file && git add file &&
14 test_expect_success
'git pull -q --no-rebase' '
16 (cd clonedq && git init &&
17 git pull -q --no-rebase "../parent" >out 2>err &&
18 test_must_be_empty err &&
19 test_must_be_empty out)
22 test_expect_success
'git pull -q --rebase' '
24 (cd clonedqrb && git init &&
25 git pull -q --rebase "../parent" >out 2>err &&
26 test_must_be_empty err &&
27 test_must_be_empty out &&
28 git pull -q --rebase "../parent" >out 2>err &&
29 test_must_be_empty err &&
30 test_must_be_empty out)
33 test_expect_success
'git pull --no-rebase' '
35 (cd cloned && git init &&
36 git pull --no-rebase "../parent" >out 2>err &&
38 test_must_be_empty out)
41 test_expect_success
'git pull --rebase' '
43 (cd clonedrb && git init &&
44 git pull --rebase "../parent" >out 2>err &&
46 test_must_be_empty out)
49 test_expect_success
'git pull -v --no-rebase' '
51 (cd clonedv && git init &&
52 git pull -v --no-rebase "../parent" >out 2>err &&
54 test_must_be_empty out)
57 test_expect_success
'git pull -v --rebase' '
59 (cd clonedvrb && git init &&
60 git pull -v --rebase "../parent" >out 2>err &&
62 test_must_be_empty out)
65 test_expect_success
'git pull -v -q --no-rebase' '
67 (cd clonedvq && git init &&
68 git pull -v -q --no-rebase "../parent" >out 2>err &&
69 test_must_be_empty out &&
70 test_must_be_empty err)
73 test_expect_success
'git pull -q -v --no-rebase' '
75 (cd clonedqv && git init &&
76 git pull -q -v --no-rebase "../parent" >out 2>err &&
77 test_must_be_empty out &&
80 test_expect_success
'git pull --cleanup errors early on invalid argument' '
81 mkdir clonedcleanup &&
82 (cd clonedcleanup && git init &&
83 test_must_fail git pull --no-rebase --cleanup invalid "../parent" >out 2>err &&
84 test_must_be_empty out &&
89 test_expect_success
'git pull --force' '
90 mkdir clonedoldstyle &&
91 (cd clonedoldstyle && git init &&
92 cat >>.git/config <<-\EOF &&
95 fetch = refs/heads/master:refs/heads/mirror
98 fetch = refs/heads/master:refs/heads/origin
101 merge = refs/heads/master
105 git branch -f origin &&
106 git pull --all --force
110 test_expect_success
'git pull --all' '
112 (cd clonedmulti && git init &&
113 cat >>.git/config <<-\EOF &&
116 fetch = refs/heads/*:refs/remotes/one/*
119 fetch = refs/heads/*:refs/remotes/two/*
122 merge = refs/heads/master
128 test_expect_success
'git pull --dry-run' '
129 test_when_finished "rm -rf clonedry" &&
133 git pull --dry-run ../parent &&
134 test_path_is_missing .git/FETCH_HEAD &&
135 test_path_is_missing .git/refs/heads/master &&
136 test_path_is_missing .git/index &&
137 test_path_is_missing file
141 test_expect_success
'git pull --all --dry-run' '
142 test_when_finished "rm -rf cloneddry" &&
146 git remote add origin ../parent &&
147 git pull --all --dry-run &&
148 test_path_is_missing .git/FETCH_HEAD &&
149 test_path_is_missing .git/refs/remotes/origin/master &&
150 test_path_is_missing .git/index &&
151 test_path_is_missing file
155 test_expect_success
'git pull --allow-unrelated-histories' '
156 test_when_finished "rm -fr src dst" &&
166 git checkout --orphan side HEAD^ &&
171 test_must_fail git pull ../src side &&
172 git pull --allow-unrelated-histories ../src side
176 test_expect_success
'git pull does not add a sign-off line' '
177 test_when_finished "rm -fr src dst actual" &&
179 test_commit -C src one &&
181 test_commit -C src two &&
182 git -C dst pull --no-ff &&
183 git -C dst show -s --pretty="format:%(trailers)" HEAD >actual &&
184 test_must_be_empty actual
187 test_expect_success
'git pull --no-signoff does not add sign-off line' '
188 test_when_finished "rm -fr src dst actual" &&
190 test_commit -C src one &&
192 test_commit -C src two &&
193 git -C dst pull --no-signoff --no-ff &&
194 git -C dst show -s --pretty="format:%(trailers)" HEAD >actual &&
195 test_must_be_empty actual
198 test_expect_success
'git pull --signoff add a sign-off line' '
199 test_when_finished "rm -fr src dst expected actual" &&
200 echo "Signed-off-by: $GIT_COMMITTER_NAME <$GIT_COMMITTER_EMAIL>" >expected &&
202 test_commit -C src one &&
204 test_commit -C src two &&
205 git -C dst pull --signoff --no-ff &&
206 git -C dst show -s --pretty="format:%(trailers)" HEAD >actual &&
207 test_cmp expected actual
210 test_expect_success
'git pull --no-signoff flag cancels --signoff flag' '
211 test_when_finished "rm -fr src dst actual" &&
213 test_commit -C src one &&
215 test_commit -C src two &&
216 git -C dst pull --signoff --no-signoff --no-ff &&
217 git -C dst show -s --pretty="format:%(trailers)" HEAD >actual &&
218 test_must_be_empty actual