1 test_expect_success "setup proc-receive hook (option without matching ok, $PROTOCOL/porcelain)" '
2 write_script "$upstream/hooks/proc-receive" <<-EOF
3 printf >&2 "# proc-receive hook\n"
4 test-tool proc-receive -v \
5 -r "option refname refs/pull/123/head" \
10 # Refs of upstream : master(A)
11 # Refs of workbench: master(A) tags/v123
12 # git push : refs/for/next/topic(A) refs/for/a/b/c/topic(A) refs/for/master/topic(A)
13 test_expect_success "proc-receive: report option without matching ok ($PROTOCOL/porcelain)" '
14 test_must_fail git -C workbench push --porcelain origin \
15 HEAD:refs/for/master/topic \
17 make_user_friendly_and_stable_output <out >actual &&
19 remote: # pre-receive hook
20 remote: pre-receive< <ZERO-OID> <COMMIT-A> refs/for/master/topic
21 remote: # proc-receive hook
22 remote: proc-receive< <ZERO-OID> <COMMIT-A> refs/for/master/topic
23 remote: proc-receive> option refname refs/pull/123/head
24 remote: proc-receive> option old-oid <COMMIT-B>
25 remote: error: proc-receive reported "option" without a matching "ok/ng" directive
26 To <URL/of/upstream.git>
27 ! HEAD:refs/for/master/topic [remote rejected] (proc-receive failed to report status)
30 test_cmp expect actual
33 test_expect_success "setup proc-receive hook (option refname, $PROTOCOL/porcelain)" '
34 write_script "$upstream/hooks/proc-receive" <<-EOF
35 printf >&2 "# proc-receive hook\n"
36 test-tool proc-receive -v \
37 -r "ok refs/for/master/topic" \
38 -r "option refname refs/pull/123/head"
42 # Refs of upstream : master(A)
43 # Refs of workbench: master(A) tags/v123
44 # git push : refs/for/next/topic(A) refs/for/a/b/c/topic(A) refs/for/master/topic(A)
45 test_expect_success "proc-receive: report option refname ($PROTOCOL/porcelain)" '
46 git -C workbench push --porcelain origin \
47 HEAD:refs/for/master/topic \
49 make_user_friendly_and_stable_output <out >actual &&
51 remote: # pre-receive hook
52 remote: pre-receive< <ZERO-OID> <COMMIT-A> refs/for/master/topic
53 remote: # proc-receive hook
54 remote: proc-receive< <ZERO-OID> <COMMIT-A> refs/for/master/topic
55 remote: proc-receive> ok refs/for/master/topic
56 remote: proc-receive> option refname refs/pull/123/head
57 remote: # post-receive hook
58 remote: post-receive< <ZERO-OID> <COMMIT-A> refs/pull/123/head
59 To <URL/of/upstream.git>
60 * HEAD:refs/pull/123/head [new reference]
63 test_cmp expect actual
66 test_expect_success "setup proc-receive hook (option refname and forced-update, $PROTOCOL/porcelain)" '
67 write_script "$upstream/hooks/proc-receive" <<-EOF
68 printf >&2 "# proc-receive hook\n"
69 test-tool proc-receive -v \
70 -r "ok refs/for/master/topic" \
71 -r "option refname refs/pull/123/head" \
72 -r "option forced-update"
76 # Refs of upstream : master(A)
77 # Refs of workbench: master(A) tags/v123
78 # git push : refs/for/next/topic(A) refs/for/a/b/c/topic(A) refs/for/master/topic(A)
79 test_expect_success "proc-receive: report option refname and forced-update ($PROTOCOL/porcelain)" '
80 git -C workbench push --porcelain origin \
81 HEAD:refs/for/master/topic \
83 make_user_friendly_and_stable_output <out >actual &&
85 remote: # pre-receive hook
86 remote: pre-receive< <ZERO-OID> <COMMIT-A> refs/for/master/topic
87 remote: # proc-receive hook
88 remote: proc-receive< <ZERO-OID> <COMMIT-A> refs/for/master/topic
89 remote: proc-receive> ok refs/for/master/topic
90 remote: proc-receive> option refname refs/pull/123/head
91 remote: proc-receive> option forced-update
92 remote: # post-receive hook
93 remote: post-receive< <ZERO-OID> <COMMIT-A> refs/pull/123/head
94 To <URL/of/upstream.git>
95 * HEAD:refs/pull/123/head [new reference]
98 test_cmp expect actual
101 test_expect_success "setup proc-receive hook (option refname and old-oid, $PROTOCOL/porcelain)" '
102 write_script "$upstream/hooks/proc-receive" <<-EOF
103 printf >&2 "# proc-receive hook\n"
104 test-tool proc-receive -v \
105 -r "ok refs/for/master/topic" \
106 -r "option refname refs/pull/123/head" \
107 -r "option old-oid $B"
111 # Refs of upstream : master(A)
112 # Refs of workbench: master(A) tags/v123
113 # git push : refs/for/next/topic(A) refs/for/a/b/c/topic(A) refs/for/master/topic(A)
114 test_expect_success "proc-receive: report option refname and old-oid ($PROTOCOL/porcelain)" '
115 git -C workbench push --porcelain origin \
116 HEAD:refs/for/master/topic \
118 make_user_friendly_and_stable_output <out >actual &&
119 cat >expect <<-EOF &&
120 remote: # pre-receive hook
121 remote: pre-receive< <ZERO-OID> <COMMIT-A> refs/for/master/topic
122 remote: # proc-receive hook
123 remote: proc-receive< <ZERO-OID> <COMMIT-A> refs/for/master/topic
124 remote: proc-receive> ok refs/for/master/topic
125 remote: proc-receive> option refname refs/pull/123/head
126 remote: proc-receive> option old-oid <COMMIT-B>
127 remote: # post-receive hook
128 remote: post-receive< <COMMIT-B> <COMMIT-A> refs/pull/123/head
129 To <URL/of/upstream.git>
130 HEAD:refs/pull/123/head <OID-B>..<OID-A>
133 test_cmp expect actual
136 test_expect_success "setup proc-receive hook (option old-oid, $PROTOCOL/porcelain)" '
137 write_script "$upstream/hooks/proc-receive" <<-EOF
138 printf >&2 "# proc-receive hook\n"
139 test-tool proc-receive -v \
140 -r "ok refs/for/master/topic" \
141 -r "option old-oid $B"
145 # Refs of upstream : master(A)
146 # Refs of workbench: master(A) tags/v123
147 # git push : refs/for/next/topic(A) refs/for/a/b/c/topic(A) refs/for/master/topic(A)
148 test_expect_success "proc-receive: report option old-oid ($PROTOCOL/porcelain)" '
149 git -C workbench push --porcelain origin \
150 HEAD:refs/for/master/topic \
152 make_user_friendly_and_stable_output <out >actual &&
153 cat >expect <<-EOF &&
154 remote: # pre-receive hook
155 remote: pre-receive< <ZERO-OID> <COMMIT-A> refs/for/master/topic
156 remote: # proc-receive hook
157 remote: proc-receive< <ZERO-OID> <COMMIT-A> refs/for/master/topic
158 remote: proc-receive> ok refs/for/master/topic
159 remote: proc-receive> option old-oid <COMMIT-B>
160 remote: # post-receive hook
161 remote: post-receive< <COMMIT-B> <COMMIT-A> refs/for/master/topic
162 To <URL/of/upstream.git>
163 HEAD:refs/for/master/topic <OID-B>..<OID-A>
166 test_cmp expect actual
169 test_expect_success "setup proc-receive hook (option old-oid and new-oid, $PROTOCOL/porcelain)" '
170 write_script "$upstream/hooks/proc-receive" <<-EOF
171 printf >&2 "# proc-receive hook\n"
172 test-tool proc-receive -v \
173 -r "ok refs/for/master/topic" \
174 -r "option old-oid $A" \
175 -r "option new-oid $B"
179 # Refs of upstream : master(A)
180 # Refs of workbench: master(A) tags/v123
181 # git push : refs/for/next/topic(A) refs/for/a/b/c/topic(A) refs/for/master/topic(A)
182 test_expect_success "proc-receive: report option old-oid and new-oid ($PROTOCOL/porcelain)" '
183 git -C workbench push --porcelain origin \
184 HEAD:refs/for/master/topic \
186 make_user_friendly_and_stable_output <out >actual &&
187 cat >expect <<-EOF &&
188 remote: # pre-receive hook
189 remote: pre-receive< <ZERO-OID> <COMMIT-A> refs/for/master/topic
190 remote: # proc-receive hook
191 remote: proc-receive< <ZERO-OID> <COMMIT-A> refs/for/master/topic
192 remote: proc-receive> ok refs/for/master/topic
193 remote: proc-receive> option old-oid <COMMIT-A>
194 remote: proc-receive> option new-oid <COMMIT-B>
195 remote: # post-receive hook
196 remote: post-receive< <COMMIT-A> <COMMIT-B> refs/for/master/topic
197 To <URL/of/upstream.git>
198 HEAD:refs/for/master/topic <OID-A>..<OID-B>
201 test_cmp expect actual
204 test_expect_success "setup proc-receive hook (report with multiple rewrites, $PROTOCOL/porcelain)" '
205 write_script "$upstream/hooks/proc-receive" <<-EOF
206 printf >&2 "# proc-receive hook\n"
207 test-tool proc-receive -v \
208 -r "ok refs/for/a/b/c/topic" \
209 -r "ok refs/for/next/topic" \
210 -r "option refname refs/pull/123/head" \
211 -r "ok refs/for/master/topic" \
212 -r "option refname refs/pull/124/head" \
213 -r "option old-oid $B" \
214 -r "option forced-update" \
215 -r "option new-oid $A"
220 # Refs of upstream : master(A)
221 # Refs of workbench: master(A) tags/v123
222 # git push : refs/for/next/topic(A) refs/for/a/b/c/topic(A) refs/for/master/topic(A)
223 test_expect_success "proc-receive: report with multiple rewrites ($PROTOCOL/porcelain)" '
224 git -C workbench push --porcelain origin \
225 HEAD:refs/for/next/topic \
226 HEAD:refs/for/a/b/c/topic \
227 HEAD:refs/for/master/topic \
229 make_user_friendly_and_stable_output <out >actual &&
230 cat >expect <<-EOF &&
231 remote: # pre-receive hook
232 remote: pre-receive< <ZERO-OID> <COMMIT-A> refs/for/next/topic
233 remote: pre-receive< <ZERO-OID> <COMMIT-A> refs/for/a/b/c/topic
234 remote: pre-receive< <ZERO-OID> <COMMIT-A> refs/for/master/topic
235 remote: # proc-receive hook
236 remote: proc-receive< <ZERO-OID> <COMMIT-A> refs/for/next/topic
237 remote: proc-receive< <ZERO-OID> <COMMIT-A> refs/for/a/b/c/topic
238 remote: proc-receive< <ZERO-OID> <COMMIT-A> refs/for/master/topic
239 remote: proc-receive> ok refs/for/a/b/c/topic
240 remote: proc-receive> ok refs/for/next/topic
241 remote: proc-receive> option refname refs/pull/123/head
242 remote: proc-receive> ok refs/for/master/topic
243 remote: proc-receive> option refname refs/pull/124/head
244 remote: proc-receive> option old-oid <COMMIT-B>
245 remote: proc-receive> option forced-update
246 remote: proc-receive> option new-oid <COMMIT-A>
247 remote: # post-receive hook
248 remote: post-receive< <ZERO-OID> <COMMIT-A> refs/pull/123/head
249 remote: post-receive< <ZERO-OID> <COMMIT-A> refs/for/a/b/c/topic
250 remote: post-receive< <COMMIT-B> <COMMIT-A> refs/pull/124/head
251 To <URL/of/upstream.git>
252 * HEAD:refs/pull/123/head [new reference]
253 * HEAD:refs/for/a/b/c/topic [new reference]
254 + HEAD:refs/pull/124/head <OID-B>...<OID-A> (forced update)
257 test_cmp expect actual &&
259 git -C "$upstream" show-ref >out &&
260 make_user_friendly_and_stable_output <out >actual &&
261 cat >expect <<-EOF &&
262 <COMMIT-A> refs/heads/master
264 test_cmp expect actual