Because we haven't settled on what the exit status from "git push" command itself should be in such a partial failure case, do not check the exit status from it for now. Signed-off-by: Alex Riesen <raa.lkml@xxxxxxxxx> --- Jeff King, Thu, Nov 15, 2007 05:26:26 +0100: > On Tue, Nov 13, 2007 at 06:10:48PM -0500, Jeff King wrote: > > > > This one is on top of what is in next. It also include the check for > > > deleting remote braches I sent before. Regarding this one: if a remote > > > branch is deleted, shouldn't the matching tracking branch be removed > > > as well? The code in master seem to do that. > > > > Yes, it should (the code in update_tracking_ref seems to handle that > > case, but I haven't tested, so I may have bungled something). I am > > literally walking out the door, now, though, so I will be out of touch > > for at least a day. > > After I became disconnected, I looked at my 'next', and the reason for > the failure to delete the ref seems to be your is_null_sha1 > error-checking patch, which Junio put in next. But maybe you have > figured that out in the intervening time. :) I didn't. But Junio already has all your patches in pu, so I activated the deletion test and rebased it on top of your patches in his tree (jk/send-pack, according to merge commit). Tried: works. t/t5404-tracking-branches.sh | 28 +++++++++++++++++++++++++--- 1 files changed, 25 insertions(+), 3 deletions(-) diff --git a/t/t5404-tracking-branches.sh b/t/t5404-tracking-branches.sh index 20718d4..a6f60ac 100755 --- a/t/t5404-tracking-branches.sh +++ b/t/t5404-tracking-branches.sh @@ -10,6 +10,7 @@ test_expect_success 'setup' ' git commit -m 1 && git branch b1 && git branch b2 && + git branch b3 && git clone . aa && git checkout b1 && echo b1 >>file && @@ -19,10 +20,13 @@ test_expect_success 'setup' ' git commit -a -m b2 ' +start_dir="$(pwd)" + test_expect_success 'check tracking branches updated correctly after push' ' cd aa && b1=$(git rev-parse origin/b1) && b2=$(git rev-parse origin/b2) && + b3=$(git rev-parse origin/b3) && git checkout -b b1 origin/b1 && echo aa-b1 >>file && git commit -a -m aa-b1 && @@ -32,9 +36,27 @@ test_expect_success 'check tracking branches updated correctly after push' ' git checkout master && echo aa-master >>file && git commit -a -m aa-master && - git push && - test "$(git rev-parse origin/b1)" = "$b1" && - test "$(git rev-parse origin/b2)" = "$b2" + { + git push + test "$(git rev-parse origin/b1)" = "$b1" && + test "$(git rev-parse origin/b2)" = "$b2" && + test "$(git rev-parse origin/b3)" = "$b3" && + test "$(git rev-parse origin/master)" = \ + "$(git rev-parse master)" + } +' + +test_expect_success 'delete remote branch' ' + git push origin :refs/heads/b3 + { + git rev-parse --verify origin/b3 + test $? != 0 + } && + cd "$start_dir" && + { + git rev-parse refs/heads/b3 + test $? != 0 + } ' test_done -- 1.5.3.5.692.ge1737 - To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html