3 test_description='behavior of diff when reading objects in a partial clone'
7 test_expect_success 'git show batches blobs' '
8 test_when_finished "rm -rf server client trace" &&
10 test_create_repo server &&
13 git -C server add a b &&
14 git -C server commit -m x &&
16 test_config -C server uploadpack.allowfilter 1 &&
17 test_config -C server uploadpack.allowanysha1inwant 1 &&
18 git clone --bare --filter=blob:limit=0 "file://$(pwd)/server" client &&
20 # Ensure that there is exactly 1 negotiation by checking that there is
21 # only 1 "done" line sent. ("done" marks the end of negotiation.)
22 GIT_TRACE_PACKET="$(pwd)/trace" git -C client show HEAD &&
23 grep "git> done" trace >done_lines &&
24 test_line_count = 1 done_lines
27 test_expect_success 'diff batches blobs' '
28 test_when_finished "rm -rf server client trace" &&
30 test_create_repo server &&
33 git -C server add a b &&
34 git -C server commit -m x &&
37 git -C server add c d &&
38 git -C server commit -m x &&
40 test_config -C server uploadpack.allowfilter 1 &&
41 test_config -C server uploadpack.allowanysha1inwant 1 &&
42 git clone --bare --filter=blob:limit=0 "file://$(pwd)/server" client &&
44 # Ensure that there is exactly 1 negotiation by checking that there is
45 # only 1 "done" line sent. ("done" marks the end of negotiation.)
46 GIT_TRACE_PACKET="$(pwd)/trace" git -C client diff HEAD^ HEAD &&
47 grep "git> done" trace >done_lines &&
48 test_line_count = 1 done_lines
51 test_expect_success 'diff skips same-OID blobs' '
52 test_when_finished "rm -rf server client trace" &&
54 test_create_repo server &&
57 git -C server add a b &&
58 git -C server commit -m x &&
59 echo another-a >server/a &&
60 git -C server add a &&
61 git -C server commit -m x &&
63 test_config -C server uploadpack.allowfilter 1 &&
64 test_config -C server uploadpack.allowanysha1inwant 1 &&
65 git clone --bare --filter=blob:limit=0 "file://$(pwd)/server" client &&
67 echo a | git hash-object --stdin >hash-old-a &&
68 echo another-a | git hash-object --stdin >hash-new-a &&
69 echo b | git hash-object --stdin >hash-b &&
71 # Ensure that only a and another-a are fetched.
72 GIT_TRACE_PACKET="$(pwd)/trace" git -C client diff HEAD^ HEAD &&
73 grep "want $(cat hash-old-a)" trace &&
74 grep "want $(cat hash-new-a)" trace &&
75 ! grep "want $(cat hash-b)" trace
78 test_expect_success 'when fetching missing objects, diff skips GITLINKs' '
79 test_when_finished "rm -rf sub server client trace" &&
81 test_create_repo sub &&
82 test_commit -C sub first &&
84 test_create_repo server &&
86 git -C server add a &&
87 git -C server submodule add "file://$(pwd)/sub" &&
88 git -C server commit -m x &&
90 test_commit -C server/sub second &&
91 echo another-a >server/a &&
92 git -C server add a sub &&
93 git -C server commit -m x &&
95 test_config -C server uploadpack.allowfilter 1 &&
96 test_config -C server uploadpack.allowanysha1inwant 1 &&
97 git clone --bare --filter=blob:limit=0 "file://$(pwd)/server" client &&
99 echo a | git hash-object --stdin >hash-old-a &&
100 echo another-a | git hash-object --stdin >hash-new-a &&
102 # Ensure that a and another-a are fetched, and check (by successful
103 # execution of the diff) that no invalid OIDs are sent.
104 GIT_TRACE_PACKET="$(pwd)/trace" git -C client diff HEAD^ HEAD &&
105 grep "want $(cat hash-old-a)" trace &&
106 grep "want $(cat hash-new-a)" trace
109 test_expect_success 'diff with rename detection batches blobs' '
110 test_when_finished "rm -rf server client trace" &&
112 test_create_repo server &&
114 printf "b\nb\nb\nb\nb\n" >server/b &&
115 git -C server add a b &&
116 git -C server commit -m x &&
118 printf "b\nb\nb\nb\nbX\n" >server/c &&
119 git -C server add c &&
120 git -C server commit -a -m x &&
122 test_config -C server uploadpack.allowfilter 1 &&
123 test_config -C server uploadpack.allowanysha1inwant 1 &&
124 git clone --bare --filter=blob:limit=0 "file://$(pwd)/server" client &&
126 # Ensure that there is exactly 1 negotiation by checking that there is
127 # only 1 "done" line sent. ("done" marks the end of negotiation.)
128 GIT_TRACE_PACKET="$(pwd)/trace" git -C client diff --raw -M HEAD^ HEAD >out &&
129 grep ":100644 100644.*R[0-9][0-9][0-9].*b.*c" out &&
130 grep "git> done" trace >done_lines &&
131 test_line_count = 1 done_lines
134 test_expect_success 'diff does not fetch anything if inexact rename detection is not needed' '
135 test_when_finished "rm -rf server client trace" &&
137 test_create_repo server &&
139 printf "b\nb\nb\nb\nb\n" >server/b &&
140 git -C server add a b &&
141 git -C server commit -m x &&
142 mv server/b server/c &&
143 git -C server add c &&
144 git -C server commit -a -m x &&
146 test_config -C server uploadpack.allowfilter 1 &&
147 test_config -C server uploadpack.allowanysha1inwant 1 &&
148 git clone --bare --filter=blob:limit=0 "file://$(pwd)/server" client &&
151 GIT_TRACE_PACKET="$(pwd)/trace" git -C client diff --raw -M HEAD^ HEAD &&
152 ! test_path_exists trace
155 test_expect_success 'diff --break-rewrites fetches only if necessary, and batches blobs if it does' '
156 test_when_finished "rm -rf server client trace" &&
158 test_create_repo server &&
160 printf "b\nb\nb\nb\nb\n" >server/b &&
161 git -C server add a b &&
162 git -C server commit -m x &&
163 printf "c\nc\nc\nc\nc\n" >server/b &&
164 git -C server commit -a -m x &&
166 test_config -C server uploadpack.allowfilter 1 &&
167 test_config -C server uploadpack.allowanysha1inwant 1 &&
168 git clone --bare --filter=blob:limit=0 "file://$(pwd)/server" client &&
171 GIT_TRACE_PACKET="$(pwd)/trace" git -C client diff --raw -M HEAD^ HEAD &&
172 ! test_path_exists trace &&
174 # But with --break-rewrites, ensure that there is exactly 1 negotiation
175 # by checking that there is only 1 "done" line sent. ("done" marks the
176 # end of negotiation.)
177 GIT_TRACE_PACKET="$(pwd)/trace" git -C client diff --break-rewrites --raw -M HEAD^ HEAD &&
178 grep "git> done" trace >done_lines &&
179 test_line_count = 1 done_lines