Message ID | patch-01.20-bea88e382c0-20211013T235900Z-avarab@gmail.com (mailing list archive) |
---|---|
State | Superseded |
Headers | show |
Series | refs: stop having the API set "errno" | expand |
On Wed, Oct 13, 2021 at 8:07 PM Ævar Arnfjörð Bjarmason <avarab@gmail.com> wrote: > Add a test for "git branch" to cover the case where .git/refs is > symlinked. To check availability, refs_verify_refname_available() will > run refs_read_raw_ref() on each prefix, leading to a read() from > .git/refs (which is a directory). > > It would probably be more robust to re-issue the lstat() as a normal > stat(), in which case, we would fall back to the directory case, but > for now let's just test for the existing behavior as-is. This test > covers a regression in a commit that only ever made it to "next", see > [1]. > > Signed-off-by: Han-Wen Nienhuys <hanwen@google.com> > Signed-off-by: Ævar Arnfjörð Bjarmason <avarab@gmail.com> > --- > diff --git a/t/t3200-branch.sh b/t/t3200-branch.sh > @@ -731,6 +731,26 @@ test_expect_success SYMLINKS 'git branch -m u v should fail when the reflog for > +test_expect_success SYMLINKS 'git branch -m with symlinked .git/refs' ' > + test_when_finished "rm -rf subdir" && > + git init subdir && > + > + ( > + cd subdir && > + for d in refs objects packed-refs > + do > + rm -rf .git/$d && > + ln -s ../../.git/$d .git/$d > + done > + ) && Amend the last line of the loop body: ln -s ../../.git/$d .git/$d || exit 1 > + git --git-dir subdir/.git/ branch rename-src && > + git rev-parse rename-src >expect && > + git --git-dir subdir/.git/ branch -m rename-src rename-dest && > + git rev-parse rename-dest >actual && > + test_cmp expect actual && > + git branch -D rename-dest > +'
diff --git a/t/t3200-branch.sh b/t/t3200-branch.sh index e575ffb4ffb..b5242719159 100755 --- a/t/t3200-branch.sh +++ b/t/t3200-branch.sh @@ -731,6 +731,26 @@ test_expect_success SYMLINKS 'git branch -m u v should fail when the reflog for test_must_fail git branch -m u v ' +test_expect_success SYMLINKS 'git branch -m with symlinked .git/refs' ' + test_when_finished "rm -rf subdir" && + git init subdir && + + ( + cd subdir && + for d in refs objects packed-refs + do + rm -rf .git/$d && + ln -s ../../.git/$d .git/$d + done + ) && + git --git-dir subdir/.git/ branch rename-src && + git rev-parse rename-src >expect && + git --git-dir subdir/.git/ branch -m rename-src rename-dest && + git rev-parse rename-dest >actual && + test_cmp expect actual && + git branch -D rename-dest +' + test_expect_success 'test tracking setup via --track' ' git config remote.local.url . && git config remote.local.fetch refs/heads/*:refs/remotes/local/* &&