I like git worktree, but keep getting into situations where the local working directory is not the same as the remote branch, even though git pull says "Already up to date".
Here's a little MRE I did:
- Created a remote repo in the GitLab web interface.
- Cloned it using
git clone --bare <url>
- Added the
main
branch locally usinggit worktree add main
- Added a new branch using
git worktree add new-branch
,cd
ed into it and did agit push
. - Using the GitLab web interface, I added a file
main-branch-change-1
directly in themain
branch, then rebasednew-branch
on top of the newmain
, then added a second filefeature-branch-change-1
innew-branch
. git pull
on the localnew-branch
says "Already up to date", while commit hash andgit log
clearly shows the local is not up to date. The filemain-branch-change-1
is present, but notfeature-branch-change-1
.git fetch --all
in the bare repo followed bygit pull
innew-branch
changes nothing.git pull
in themain
branch followed bygit pull
innew-branch
changes nothing.
What do I have to do to sync these changes?
Some screenshots:
As torek pointed out in a comment, the issue was caused by cloning with
--bare
. That's something I picked up from "ThePrimeagen" here (2 mins in). But rather than having a full (non-bare) repo at the root, which I think I don't want, this command seems to fix it all:Thanks TamaMcGlinn.
I still have to do
git branch --set-upstream-to=origin/new-branch new-branch
from thenew-branch
folder, which failed previously with "error: the requested upstream branch 'origin/main' does not exist", but succeeds after the above command.