Merge branch 'rj/bisect-already-used-branch'
Allow "git bisect reset" to check out the original branch when the branch is already checked out in a different worktree linked to the same repository. * rj/bisect-already-used-branch: bisect: fix "reset" when branch is checked out elsewhere
This commit is contained in:
commit
c79786c486
@ -245,7 +245,8 @@ static int bisect_reset(const char *commit)
|
|||||||
struct child_process cmd = CHILD_PROCESS_INIT;
|
struct child_process cmd = CHILD_PROCESS_INIT;
|
||||||
|
|
||||||
cmd.git_cmd = 1;
|
cmd.git_cmd = 1;
|
||||||
strvec_pushl(&cmd.args, "checkout", branch.buf, "--", NULL);
|
strvec_pushl(&cmd.args, "checkout", "--ignore-other-worktrees",
|
||||||
|
branch.buf, "--", NULL);
|
||||||
if (run_command(&cmd)) {
|
if (run_command(&cmd)) {
|
||||||
error(_("could not check out original"
|
error(_("could not check out original"
|
||||||
" HEAD '%s'. Try 'git bisect"
|
" HEAD '%s'. Try 'git bisect"
|
||||||
|
@ -122,6 +122,29 @@ test_expect_success 'bisect start without -- takes unknown arg as pathspec' '
|
|||||||
grep bar ".git/BISECT_NAMES"
|
grep bar ".git/BISECT_NAMES"
|
||||||
'
|
'
|
||||||
|
|
||||||
|
test_expect_success 'bisect reset: back in a branch checked out also elsewhere' '
|
||||||
|
echo "shared" > branch.expect &&
|
||||||
|
test_bisect_reset() {
|
||||||
|
git -C $1 bisect start &&
|
||||||
|
git -C $1 bisect good $HASH1 &&
|
||||||
|
git -C $1 bisect bad $HASH3 &&
|
||||||
|
git -C $1 bisect reset &&
|
||||||
|
git -C $1 branch --show-current > branch.output &&
|
||||||
|
cmp branch.expect branch.output
|
||||||
|
} &&
|
||||||
|
test_when_finished "
|
||||||
|
git worktree remove wt1 &&
|
||||||
|
git worktree remove wt2 &&
|
||||||
|
git branch -d shared
|
||||||
|
" &&
|
||||||
|
git worktree add wt1 -b shared &&
|
||||||
|
git worktree add wt2 -f shared &&
|
||||||
|
# we test in both worktrees to ensure that works
|
||||||
|
# as expected with "first" and "next" worktrees
|
||||||
|
test_bisect_reset wt1 &&
|
||||||
|
test_bisect_reset wt2
|
||||||
|
'
|
||||||
|
|
||||||
test_expect_success 'bisect reset: back in the main branch' '
|
test_expect_success 'bisect reset: back in the main branch' '
|
||||||
git bisect reset &&
|
git bisect reset &&
|
||||||
echo "* main" > branch.expect &&
|
echo "* main" > branch.expect &&
|
||||||
|
Loading…
Reference in New Issue
Block a user