git.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* aborted 'git fetch' leaves workspace unusable
@ 2013-12-30 17:07 stephen_leake
  2013-12-30 19:37 ` Junio C Hamano
  2013-12-30 19:54 ` Torsten Bögershausen
  0 siblings, 2 replies; 7+ messages in thread
From: stephen_leake @ 2013-12-30 17:07 UTC (permalink / raw)
  To: git

I forgot to do 'ssh-add', so a 'git fetch' running under Windows Emacs
tried to prompt for the ssh passphrase, could not find an ssh 
passphrase
prompt program, and aborted.

That left the workspace unusable:

- .git/FETCH_HEAD is empty

     that causes 'git rev-parse FETCH_HEAD' to fail with a confusing
     error message.

- 'git fetch' just hangs after outputting:

remote: Counting objects: 15, done.
remote: Compressing objects: 100% (8/8), done.
remote: Total 9 (delta 5), reused 0 (delta 0)

     even with -v --progress

A fresh clone allowed me to continue working, but this will happen
again, so I'd like a better fix.

The fetch is from stephen_leake@git.savannah.gnu.org/emacs/elpa.git

I'm running git 1.7.9 from Cygwin. I have access to Debian, where I can
compile git and run it under the debugger, if that helps. I have not 
yet
tried to reproduce this bug on Debian.

--
-- Stephe

^ permalink raw reply	[flat|nested] 7+ messages in thread
* Re: aborted 'git fetch' leaves workspace unusable
@ 2013-12-31  8:19 stephen_leake
  2014-01-02 18:09 ` Junio C Hamano
  0 siblings, 1 reply; 7+ messages in thread
From: stephen_leake @ 2013-12-31  8:19 UTC (permalink / raw)
  To: git

Junio C Hamano <gitster@pobox.com> writes:

> stephen_leake@stephe-leake.org writes:
> 
>> That left the workspace unusable:
>> 
>> - .git/FETCH_HEAD is empty
>> 
>>     that causes 'git rev-parse FETCH_HEAD' to fail with a confusing
>>     error message.
> 
> This is not limited to your Cygwin environment.  I can see that we
> leave an empty file there after a failed fetch with
> 
> 	$ git fetch ssh://no.such.place/
> 
> But I would not call it leaving "the workspace unusable".  If you
> ask "git rev-parse" "What is in FETCH_HEAD?", you would get "that is
> not even a revision", which is what you would get.

Yes, and I also discovered that FETCH_HEAD is not present after a 
clone.
So in general I need to be tolerant of an empty/missing FETCH_HEAD (I'm
actually working on an Emacs front end for git).

However, in this case, even running the fetch was a mistake; I would
have prefered that it leave FETCH_HEAD in its previous state. Is there
any way to reconstruct it? refs/heads/master was untouched, but I don't
know how to find the fetched head.

>> - 'git fetch' just hangs after outputting:
>> 
>> remote: Counting objects: 15, done.
>> remote: Compressing objects: 100% (8/8), done.
>> remote: Total 9 (delta 5), reused 0 (delta 0)
> 
> This looks more serious, but I suspect it is totally unrelated to
> your previous fetch failing and leaving FETCH_HEAD there.  Is this
> "'git fetch' hangs" reproduce in a clean clone _without_ first
> encountering the failure (due to the forgotton "ssh-add")?

no, the clone worked (so the network is up, the server is up), and a
subsequent 'git fetch' did not hang. Although there was also nothing to
fetch.

I'll have to wait until there is something to fetch, and see if I can
reproduce the bug. Or set up a git server and test branch - not high
enough on my priority list.

--
-- Stephe

^ permalink raw reply	[flat|nested] 7+ messages in thread

end of thread, other threads:[~2014-01-03 17:58 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2013-12-30 17:07 aborted 'git fetch' leaves workspace unusable stephen_leake
2013-12-30 19:37 ` Junio C Hamano
2013-12-30 19:54 ` Torsten Bögershausen
  -- strict thread matches above, loose matches on Subject: below --
2013-12-31  8:19 stephen_leake
2014-01-02 18:09 ` Junio C Hamano
2014-01-03  3:28   ` Stephen Leake
2014-01-03 17:58     ` Junio C Hamano

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).