controller/volume: simplify sync logic in syncBoundClaim
This commit is contained in:
		| @@ -271,22 +271,19 @@ func (ctrl *PersistentVolumeController) syncBoundClaim(claim *api.PersistentVolu | ||||
| 	// [Unit test set 3] | ||||
| 	if claim.Spec.VolumeName == "" { | ||||
| 		// Claim was bound before but not any more. | ||||
| 		if _, err := ctrl.updateClaimPhaseWithEvent(claim, api.ClaimLost, api.EventTypeWarning, "ClaimLost", "Bound claim has lost reference to PersistentVolume. Data on the volume is lost!"); err != nil { | ||||
| 		_, err := ctrl.updateClaimPhaseWithEvent(claim, api.ClaimLost, api.EventTypeWarning, "ClaimLost", "Bound claim has lost reference to PersistentVolume. Data on the volume is lost!") | ||||
| 		return err | ||||
| 	} | ||||
| 		return nil | ||||
| 	} | ||||
|  | ||||
| 	obj, found, err := ctrl.volumes.store.GetByKey(claim.Spec.VolumeName) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if !found { | ||||
| 		// Claim is bound to a non-existing volume. | ||||
| 		if _, err = ctrl.updateClaimPhaseWithEvent(claim, api.ClaimLost, api.EventTypeWarning, "ClaimLost", "Bound claim has lost its PersistentVolume. Data on the volume is lost!"); err != nil { | ||||
| 		_, err = ctrl.updateClaimPhaseWithEvent(claim, api.ClaimLost, api.EventTypeWarning, "ClaimLost", "Bound claim has lost its PersistentVolume. Data on the volume is lost!") | ||||
| 		return err | ||||
| 	} | ||||
| 		return nil | ||||
| 	} else { | ||||
| 	volume, ok := obj.(*api.PersistentVolume) | ||||
| 	if !ok { | ||||
| 		return fmt.Errorf("Cannot convert object from volume cache to volume %q!?: %+v", claim.Spec.VolumeName, obj) | ||||
| @@ -304,7 +301,8 @@ func (ctrl *PersistentVolumeController) syncBoundClaim(claim *api.PersistentVolu | ||||
| 			return err | ||||
| 		} | ||||
| 		return nil | ||||
| 		} else if volume.Spec.ClaimRef.UID == claim.UID { | ||||
| 	} | ||||
| 	if volume.Spec.ClaimRef.UID == claim.UID { | ||||
| 		// All is well | ||||
| 		// NOTE: syncPV can handle this so it can be left out. | ||||
| 		// NOTE: bind() call here will do nothing in most cases as | ||||
| @@ -315,16 +313,13 @@ func (ctrl *PersistentVolumeController) syncBoundClaim(claim *api.PersistentVolu | ||||
| 			return err | ||||
| 		} | ||||
| 		return nil | ||||
| 		} else { | ||||
| 	} | ||||
|  | ||||
| 	// Claim is bound but volume has a different claimant. | ||||
| 	// Set the claim phase to 'Lost', which is a terminal | ||||
| 	// phase. | ||||
| 			if _, err = ctrl.updateClaimPhaseWithEvent(claim, api.ClaimLost, api.EventTypeWarning, "ClaimMisbound", "Two claims are bound to the same volume, this one is bound incorrectly"); err != nil { | ||||
| 	_, err = ctrl.updateClaimPhaseWithEvent(claim, api.ClaimLost, api.EventTypeWarning, "ClaimMisbound", "Two claims are bound to the same volume, this one is bound incorrectly") | ||||
| 	return err | ||||
| 			} | ||||
| 			return nil | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
|  | ||||
| // syncVolume is the main controller method to decide what to do with a volume. | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Xiang Li
					Xiang Li