diff options
author | Javi Fontan <jfontan@gmail.com> | 2019-03-01 15:33:49 +0100 |
---|---|---|
committer | Javi Fontan <jfontan@gmail.com> | 2019-03-01 15:33:49 +0100 |
commit | fae29fbd5895363ef5464cc12029db85a1a24529 (patch) | |
tree | 451661799b2619458b36359a79c7ee58f5d8a715 /remote.go | |
parent | 0106daba16494c33d330168e38c8a610b7a9b32c (diff) | |
download | go-git-fae29fbd5895363ef5464cc12029db85a1a24529.tar.gz |
git: fix goroutine block while pushing a remote
On session.ReceivePack error the gororutine doing the encoding got
blocked either writing objects to the pipe or sending error to the done
channel. The problem did not cause a perceived problem but left blocked
goroutines.
Signed-off-by: Javi Fontan <jfontan@gmail.com>
Diffstat (limited to 'remote.go')
-rw-r--r-- | remote.go | 9 |
1 files changed, 8 insertions, 1 deletions
@@ -1020,7 +1020,12 @@ func pushHashes( if err != nil { return nil, err } - done := make(chan error) + + // Set buffer size to 1 so the error message can be written when + // ReceivePack fails. Otherwise the goroutine will be blocked writing + // to the channel. + done := make(chan error, 1) + go func() { e := packfile.NewEncoder(wr, s, useRefDeltas) if _, err := e.Encode(hs, config.Pack.Window); err != nil { @@ -1033,6 +1038,8 @@ func pushHashes( rs, err := sess.ReceivePack(ctx, req) if err != nil { + // close the pipe to unlock encode write + _ = rd.Close() return nil, err } |