diff options
author | Felipe Contreras <felipe.contreras@gmail.com> | 2012-11-28 23:24:00 +0100 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2012-12-03 09:57:16 -0800 |
commit | f28e7c904ac82b0c5e43805529e7d5296fa4d13b (patch) | |
tree | 602de6ff18dc2b91a17cb747c2ae248cdeaaf783 /t/t9350-fast-export.sh | |
parent | 49266e8a11cffa1bb41217021470e33d26109bb2 (diff) | |
download | git-f28e7c904ac82b0c5e43805529e7d5296fa4d13b.tar.gz git-f28e7c904ac82b0c5e43805529e7d5296fa4d13b.tar.xz |
fast-export: make sure updated refs get updated
When an object has already been exported (and thus is in the marks) it's
flagged as SHOWN, so it will not be exported again, even if in a later
time it's exported through a different ref.
We don't need the object to be exported again, but we want the ref
updated, which doesn't happen.
Since we can't know if a ref was exported or not, let's just assume that
if the commit was marked (flags & SHOWN), the user still wants the ref
updated.
IOW: If it's specified in the command line, it will get updated,
regardless of whether or not the object was marked.
So:
% git branch test master
% git fast-export $mark_flags master
% git fast-export $mark_flags test
Would export 'test' properly.
Additionally, this fixes issues with remote helpers; now they can push
refs whose objects have already been exported, and a few other issues as
well. Update the tests accordingly.
Signed-off-by: Felipe Contreras <felipe.contreras@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 't/t9350-fast-export.sh')
-rwxr-xr-x | t/t9350-fast-export.sh | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/t/t9350-fast-export.sh b/t/t9350-fast-export.sh index c8e41c1d4..9320b4f94 100755 --- a/t/t9350-fast-export.sh +++ b/t/t9350-fast-export.sh @@ -484,4 +484,19 @@ test_expect_success 'avoid uninteresting refs' ' test_cmp expected actual ' +cat > expected << EOF +reset refs/heads/master +from :14 + +EOF + +test_expect_success 'refs are updated even if no commits need to be exported' ' + > tmp-marks && + git fast-export --import-marks=tmp-marks \ + --export-marks=tmp-marks master > /dev/null && + git fast-export --import-marks=tmp-marks \ + --export-marks=tmp-marks master > actual && + test_cmp expected actual +' + test_done |