Browse Source

Merge pull request #10161 from jingyih/automated-cherry-pick-of-#10153-origin-release-3.3

clientv3: automated cherry pick of #10153 to release-3.3
Jingyi Hu 7 years ago
parent
commit
ebe950fc1c
1 changed files with 3 additions and 4 deletions
  1. 3 4
      clientv3/concurrency/mutex.go

+ 3 - 4
clientv3/concurrency/mutex.go

@@ -68,11 +68,10 @@ func (m *Mutex) Lock(ctx context.Context) error {
 
 	// wait for deletion revisions prior to myKey
 	hdr, werr := waitDeletes(ctx, client, m.pfx, m.myRev-1)
-	// release lock key if cancelled
-	select {
-	case <-ctx.Done():
+	// release lock key if wait failed
+	if werr != nil {
 		m.Unlock(client.Ctx())
-	default:
+	} else {
 		m.hdr = hdr
 	}
 	return werr