Merge pull request #77443 from cofyc/fix77085
Remove private copies and update the code to use shared annotations
This commit is contained in:
		| @@ -24,6 +24,7 @@ import ( | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| 	utilfeature "k8s.io/apiserver/pkg/util/feature" | ||||
| 	utilfeaturetesting "k8s.io/apiserver/pkg/util/feature/testing" | ||||
| 	pvutil "k8s.io/kubernetes/pkg/controller/volume/persistentvolume/util" | ||||
| 	"k8s.io/kubernetes/pkg/features" | ||||
| ) | ||||
|  | ||||
| @@ -46,9 +47,9 @@ func TestSync(t *testing.T) { | ||||
| 			// syncClaim binds to a matching unbound volume. | ||||
| 			"1-1 - successful bind", | ||||
| 			newVolumeArray("volume1-1", "1Gi", "", "", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty), | ||||
| 			newVolumeArray("volume1-1", "1Gi", "uid1-1", "claim1-1", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController), | ||||
| 			newVolumeArray("volume1-1", "1Gi", "uid1-1", "claim1-1", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController), | ||||
| 			newClaimArray("claim1-1", "uid1-1", "1Gi", "", v1.ClaimPending, nil), | ||||
| 			newClaimArray("claim1-1", "uid1-1", "1Gi", "volume1-1", v1.ClaimBound, nil, annBoundByController, annBindCompleted), | ||||
| 			newClaimArray("claim1-1", "uid1-1", "1Gi", "volume1-1", v1.ClaimBound, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| @@ -81,10 +82,10 @@ func TestSync(t *testing.T) { | ||||
| 			}, | ||||
| 			[]*v1.PersistentVolume{ | ||||
| 				newVolume("volume1-4_1", "10Gi", "", "", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty), | ||||
| 				newVolume("volume1-4_2", "1Gi", "uid1-4", "claim1-4", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController), | ||||
| 				newVolume("volume1-4_2", "1Gi", "uid1-4", "claim1-4", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController), | ||||
| 			}, | ||||
| 			newClaimArray("claim1-4", "uid1-4", "1Gi", "", v1.ClaimPending, nil), | ||||
| 			newClaimArray("claim1-4", "uid1-4", "1Gi", "volume1-4_2", v1.ClaimBound, nil, annBoundByController, annBindCompleted), | ||||
| 			newClaimArray("claim1-4", "uid1-4", "1Gi", "volume1-4_2", v1.ClaimBound, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| @@ -100,7 +101,7 @@ func TestSync(t *testing.T) { | ||||
| 				newVolume("volume1-5_2", "1Gi", "", "", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty), | ||||
| 			}, | ||||
| 			newClaimArray("claim1-5", "uid1-5", "1Gi", "", v1.ClaimPending, nil), | ||||
| 			withExpectedCapacity("10Gi", newClaimArray("claim1-5", "uid1-5", "1Gi", "volume1-5_1", v1.ClaimBound, nil, annBoundByController, annBindCompleted)), | ||||
| 			withExpectedCapacity("10Gi", newClaimArray("claim1-5", "uid1-5", "1Gi", "volume1-5_1", v1.ClaimBound, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted)), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| @@ -116,7 +117,7 @@ func TestSync(t *testing.T) { | ||||
| 				newVolume("volume1-6_2", "1Gi", "", "", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty), | ||||
| 			}, | ||||
| 			newClaimArray("claim1-6", "uid1-6", "1Gi", "", v1.ClaimPending, nil), | ||||
| 			withExpectedCapacity("10Gi", newClaimArray("claim1-6", "uid1-6", "1Gi", "volume1-6_1", v1.ClaimBound, nil, annBoundByController, annBindCompleted)), | ||||
| 			withExpectedCapacity("10Gi", newClaimArray("claim1-6", "uid1-6", "1Gi", "volume1-6_1", v1.ClaimBound, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted)), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| @@ -134,39 +135,39 @@ func TestSync(t *testing.T) { | ||||
| 			// syncClaim completes binding - simulates controller crash after | ||||
| 			// PV.ClaimRef is saved | ||||
| 			"1-8 - complete bind after crash - PV bound", | ||||
| 			newVolumeArray("volume1-8", "1Gi", "uid1-8", "claim1-8", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController), | ||||
| 			newVolumeArray("volume1-8", "1Gi", "uid1-8", "claim1-8", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController), | ||||
| 			newVolumeArray("volume1-8", "1Gi", "uid1-8", "claim1-8", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController), | ||||
| 			newVolumeArray("volume1-8", "1Gi", "uid1-8", "claim1-8", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController), | ||||
| 			newClaimArray("claim1-8", "uid1-8", "1Gi", "", v1.ClaimPending, nil), | ||||
| 			newClaimArray("claim1-8", "uid1-8", "1Gi", "volume1-8", v1.ClaimBound, nil, annBoundByController, annBindCompleted), | ||||
| 			newClaimArray("claim1-8", "uid1-8", "1Gi", "volume1-8", v1.ClaimBound, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| 			// syncClaim completes binding - simulates controller crash after | ||||
| 			// PV.Status is saved | ||||
| 			"1-9 - complete bind after crash - PV status saved", | ||||
| 			newVolumeArray("volume1-9", "1Gi", "uid1-9", "claim1-9", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController), | ||||
| 			newVolumeArray("volume1-9", "1Gi", "uid1-9", "claim1-9", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController), | ||||
| 			newVolumeArray("volume1-9", "1Gi", "uid1-9", "claim1-9", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController), | ||||
| 			newVolumeArray("volume1-9", "1Gi", "uid1-9", "claim1-9", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController), | ||||
| 			newClaimArray("claim1-9", "uid1-9", "1Gi", "", v1.ClaimPending, nil), | ||||
| 			newClaimArray("claim1-9", "uid1-9", "1Gi", "volume1-9", v1.ClaimBound, nil, annBoundByController, annBindCompleted), | ||||
| 			newClaimArray("claim1-9", "uid1-9", "1Gi", "volume1-9", v1.ClaimBound, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| 			// syncClaim completes binding - simulates controller crash after | ||||
| 			// PVC.VolumeName is saved | ||||
| 			"1-10 - complete bind after crash - PVC bound", | ||||
| 			newVolumeArray("volume1-10", "1Gi", "uid1-10", "claim1-10", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController), | ||||
| 			newVolumeArray("volume1-10", "1Gi", "uid1-10", "claim1-10", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController), | ||||
| 			newClaimArray("claim1-10", "uid1-10", "1Gi", "volume1-10", v1.ClaimPending, nil, annBoundByController, annBindCompleted), | ||||
| 			newClaimArray("claim1-10", "uid1-10", "1Gi", "volume1-10", v1.ClaimBound, nil, annBoundByController, annBindCompleted), | ||||
| 			newVolumeArray("volume1-10", "1Gi", "uid1-10", "claim1-10", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController), | ||||
| 			newVolumeArray("volume1-10", "1Gi", "uid1-10", "claim1-10", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController), | ||||
| 			newClaimArray("claim1-10", "uid1-10", "1Gi", "volume1-10", v1.ClaimPending, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted), | ||||
| 			newClaimArray("claim1-10", "uid1-10", "1Gi", "volume1-10", v1.ClaimBound, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| 			// syncClaim binds a claim only when the label selector matches the volume | ||||
| 			"1-11 - bind when selector matches", | ||||
| 			withLabels(labels, newVolumeArray("volume1-1", "1Gi", "", "", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty)), | ||||
| 			withLabels(labels, newVolumeArray("volume1-1", "1Gi", "uid1-1", "claim1-1", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController)), | ||||
| 			withLabels(labels, newVolumeArray("volume1-1", "1Gi", "uid1-1", "claim1-1", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController)), | ||||
| 			withLabelSelector(labels, newClaimArray("claim1-1", "uid1-1", "1Gi", "", v1.ClaimPending, nil)), | ||||
| 			withLabelSelector(labels, newClaimArray("claim1-1", "uid1-1", "1Gi", "volume1-1", v1.ClaimBound, nil, annBoundByController, annBindCompleted)), | ||||
| 			withLabelSelector(labels, newClaimArray("claim1-1", "uid1-1", "1Gi", "volume1-1", v1.ClaimBound, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted)), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| @@ -195,7 +196,7 @@ func TestSync(t *testing.T) { | ||||
| 			newVolumeArray("volume1-1", "1Gi", "", "claim1-1", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classWait), | ||||
| 			newVolumeArray("volume1-1", "1Gi", "uid1-1", "claim1-1", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classWait), | ||||
| 			newClaimArray("claim1-1", "uid1-1", "1Gi", "", v1.ClaimPending, &classWait), | ||||
| 			newClaimArray("claim1-1", "uid1-1", "1Gi", "volume1-1", v1.ClaimBound, &classWait, annBoundByController, annBindCompleted), | ||||
| 			newClaimArray("claim1-1", "uid1-1", "1Gi", "volume1-1", v1.ClaimBound, &classWait, pvutil.AnnBoundByController, pvutil.AnnBindCompleted), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| @@ -207,11 +208,11 @@ func TestSync(t *testing.T) { | ||||
| 				newVolume("volume1-15_2", "1Gi", "", "", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty), | ||||
| 			}, | ||||
| 			[]*v1.PersistentVolume{ | ||||
| 				newVolume("volume1-15_1", "10Gi", "uid1-15", "claim1-15", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController), | ||||
| 				newVolume("volume1-15_1", "10Gi", "uid1-15", "claim1-15", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController), | ||||
| 				newVolume("volume1-15_2", "1Gi", "", "", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty), | ||||
| 			}, | ||||
| 			newClaimArray("claim1-15", "uid1-15", "1Gi", "volume1-15_1", v1.ClaimPending, nil), | ||||
| 			withExpectedCapacity("10Gi", newClaimArray("claim1-15", "uid1-15", "1Gi", "volume1-15_1", v1.ClaimBound, nil, annBindCompleted)), | ||||
| 			withExpectedCapacity("10Gi", newClaimArray("claim1-15", "uid1-15", "1Gi", "volume1-15_1", v1.ClaimBound, nil, pvutil.AnnBindCompleted)), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| @@ -272,33 +273,33 @@ func TestSync(t *testing.T) { | ||||
| 		}, | ||||
| 		{ | ||||
| 			// syncClaim with claim pre-bound to a PV that exists and is | ||||
| 			// unbound. Check it gets bound and no annBoundByController is set. | ||||
| 			// unbound. Check it gets bound and no pvutil.AnnBoundByController is set. | ||||
| 			"2-3 - claim prebound to unbound volume", | ||||
| 			newVolumeArray("volume2-3", "1Gi", "", "", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty), | ||||
| 			newVolumeArray("volume2-3", "1Gi", "uid2-3", "claim2-3", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController), | ||||
| 			newVolumeArray("volume2-3", "1Gi", "uid2-3", "claim2-3", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController), | ||||
| 			newClaimArray("claim2-3", "uid2-3", "1Gi", "volume2-3", v1.ClaimPending, nil), | ||||
| 			newClaimArray("claim2-3", "uid2-3", "1Gi", "volume2-3", v1.ClaimBound, nil, annBindCompleted), | ||||
| 			newClaimArray("claim2-3", "uid2-3", "1Gi", "volume2-3", v1.ClaimBound, nil, pvutil.AnnBindCompleted), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| 			// claim with claim pre-bound to a PV that is pre-bound to the claim | ||||
| 			// by name. Check it gets bound and no annBoundByController is set. | ||||
| 			// by name. Check it gets bound and no pvutil.AnnBoundByController is set. | ||||
| 			"2-4 - claim prebound to prebound volume by name", | ||||
| 			newVolumeArray("volume2-4", "1Gi", "", "claim2-4", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty), | ||||
| 			newVolumeArray("volume2-4", "1Gi", "uid2-4", "claim2-4", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty), | ||||
| 			newClaimArray("claim2-4", "uid2-4", "1Gi", "volume2-4", v1.ClaimPending, nil), | ||||
| 			newClaimArray("claim2-4", "uid2-4", "1Gi", "volume2-4", v1.ClaimBound, nil, annBindCompleted), | ||||
| 			newClaimArray("claim2-4", "uid2-4", "1Gi", "volume2-4", v1.ClaimBound, nil, pvutil.AnnBindCompleted), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| 			// syncClaim with claim pre-bound to a PV that is pre-bound to the | ||||
| 			// claim by UID. Check it gets bound and no annBoundByController is | ||||
| 			// claim by UID. Check it gets bound and no pvutil.AnnBoundByController is | ||||
| 			// set. | ||||
| 			"2-5 - claim prebound to prebound volume by UID", | ||||
| 			newVolumeArray("volume2-5", "1Gi", "uid2-5", "claim2-5", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty), | ||||
| 			newVolumeArray("volume2-5", "1Gi", "uid2-5", "claim2-5", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty), | ||||
| 			newClaimArray("claim2-5", "uid2-5", "1Gi", "volume2-5", v1.ClaimPending, nil), | ||||
| 			newClaimArray("claim2-5", "uid2-5", "1Gi", "volume2-5", v1.ClaimBound, nil, annBindCompleted), | ||||
| 			newClaimArray("claim2-5", "uid2-5", "1Gi", "volume2-5", v1.ClaimBound, nil, pvutil.AnnBindCompleted), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| @@ -317,19 +318,19 @@ func TestSync(t *testing.T) { | ||||
| 			"2-7 - claim bound by controller to already bound volume", | ||||
| 			newVolumeArray("volume2-7", "1Gi", "uid2-7_1", "claim2-7_1", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty), | ||||
| 			newVolumeArray("volume2-7", "1Gi", "uid2-7_1", "claim2-7_1", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty), | ||||
| 			newClaimArray("claim2-7", "uid2-7", "1Gi", "volume2-7", v1.ClaimBound, nil, annBoundByController), | ||||
| 			newClaimArray("claim2-7", "uid2-7", "1Gi", "volume2-7", v1.ClaimBound, nil, annBoundByController), | ||||
| 			newClaimArray("claim2-7", "uid2-7", "1Gi", "volume2-7", v1.ClaimBound, nil, pvutil.AnnBoundByController), | ||||
| 			newClaimArray("claim2-7", "uid2-7", "1Gi", "volume2-7", v1.ClaimBound, nil, pvutil.AnnBoundByController), | ||||
| 			noevents, noerrors, testSyncClaimError, | ||||
| 		}, | ||||
| 		{ | ||||
| 			// syncClaim with claim pre-bound to a PV that exists and is | ||||
| 			// unbound, but does not match the selector. Check it gets bound | ||||
| 			// and no annBoundByController is set. | ||||
| 			// and no pvutil.AnnBoundByController is set. | ||||
| 			"2-8 - claim prebound to unbound volume that does not match the selector", | ||||
| 			newVolumeArray("volume2-8", "1Gi", "", "", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty), | ||||
| 			newVolumeArray("volume2-8", "1Gi", "uid2-8", "claim2-8", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController), | ||||
| 			newVolumeArray("volume2-8", "1Gi", "uid2-8", "claim2-8", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController), | ||||
| 			withLabelSelector(labels, newClaimArray("claim2-8", "uid2-8", "1Gi", "volume2-8", v1.ClaimPending, nil)), | ||||
| 			withLabelSelector(labels, newClaimArray("claim2-8", "uid2-8", "1Gi", "volume2-8", v1.ClaimBound, nil, annBindCompleted)), | ||||
| 			withLabelSelector(labels, newClaimArray("claim2-8", "uid2-8", "1Gi", "volume2-8", v1.ClaimBound, nil, pvutil.AnnBindCompleted)), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| @@ -361,8 +362,8 @@ func TestSync(t *testing.T) { | ||||
| 			"3-1 - bound claim with missing VolumeName", | ||||
| 			novolumes, | ||||
| 			novolumes, | ||||
| 			newClaimArray("claim3-1", "uid3-1", "10Gi", "", v1.ClaimBound, nil, annBoundByController, annBindCompleted), | ||||
| 			newClaimArray("claim3-1", "uid3-1", "10Gi", "", v1.ClaimLost, nil, annBoundByController, annBindCompleted), | ||||
| 			newClaimArray("claim3-1", "uid3-1", "10Gi", "", v1.ClaimBound, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted), | ||||
| 			newClaimArray("claim3-1", "uid3-1", "10Gi", "", v1.ClaimLost, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted), | ||||
| 			[]string{"Warning ClaimLost"}, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| @@ -371,8 +372,8 @@ func TestSync(t *testing.T) { | ||||
| 			"3-2 - bound claim with missing volume", | ||||
| 			novolumes, | ||||
| 			novolumes, | ||||
| 			newClaimArray("claim3-2", "uid3-2", "10Gi", "volume3-2", v1.ClaimBound, nil, annBoundByController, annBindCompleted), | ||||
| 			newClaimArray("claim3-2", "uid3-2", "10Gi", "volume3-2", v1.ClaimLost, nil, annBoundByController, annBindCompleted), | ||||
| 			newClaimArray("claim3-2", "uid3-2", "10Gi", "volume3-2", v1.ClaimBound, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted), | ||||
| 			newClaimArray("claim3-2", "uid3-2", "10Gi", "volume3-2", v1.ClaimLost, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted), | ||||
| 			[]string{"Warning ClaimLost"}, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| @@ -380,9 +381,9 @@ func TestSync(t *testing.T) { | ||||
| 			// Also check that Pending phase is set to Bound | ||||
| 			"3-3 - bound claim with unbound volume", | ||||
| 			newVolumeArray("volume3-3", "10Gi", "", "", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty), | ||||
| 			newVolumeArray("volume3-3", "10Gi", "uid3-3", "claim3-3", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController), | ||||
| 			newClaimArray("claim3-3", "uid3-3", "10Gi", "volume3-3", v1.ClaimPending, nil, annBoundByController, annBindCompleted), | ||||
| 			newClaimArray("claim3-3", "uid3-3", "10Gi", "volume3-3", v1.ClaimBound, nil, annBoundByController, annBindCompleted), | ||||
| 			newVolumeArray("volume3-3", "10Gi", "uid3-3", "claim3-3", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController), | ||||
| 			newClaimArray("claim3-3", "uid3-3", "10Gi", "volume3-3", v1.ClaimPending, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted), | ||||
| 			newClaimArray("claim3-3", "uid3-3", "10Gi", "volume3-3", v1.ClaimBound, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| @@ -391,8 +392,8 @@ func TestSync(t *testing.T) { | ||||
| 			"3-4 - bound claim with prebound volume", | ||||
| 			newVolumeArray("volume3-4", "10Gi", "claim3-4-x", "claim3-4", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty), | ||||
| 			newVolumeArray("volume3-4", "10Gi", "claim3-4-x", "claim3-4", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty), | ||||
| 			newClaimArray("claim3-4", "uid3-4", "10Gi", "volume3-4", v1.ClaimPending, nil, annBoundByController, annBindCompleted), | ||||
| 			newClaimArray("claim3-4", "uid3-4", "10Gi", "volume3-4", v1.ClaimLost, nil, annBoundByController, annBindCompleted), | ||||
| 			newClaimArray("claim3-4", "uid3-4", "10Gi", "volume3-4", v1.ClaimPending, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted), | ||||
| 			newClaimArray("claim3-4", "uid3-4", "10Gi", "volume3-4", v1.ClaimLost, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted), | ||||
| 			[]string{"Warning ClaimMisbound"}, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| @@ -402,8 +403,8 @@ func TestSync(t *testing.T) { | ||||
| 			"3-5 - bound claim with bound volume", | ||||
| 			newVolumeArray("volume3-5", "10Gi", "uid3-5", "claim3-5", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty), | ||||
| 			newVolumeArray("volume3-5", "10Gi", "uid3-5", "claim3-5", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty), | ||||
| 			newClaimArray("claim3-5", "uid3-5", "10Gi", "volume3-5", v1.ClaimPending, nil, annBindCompleted), | ||||
| 			newClaimArray("claim3-5", "uid3-5", "10Gi", "volume3-5", v1.ClaimBound, nil, annBindCompleted), | ||||
| 			newClaimArray("claim3-5", "uid3-5", "10Gi", "volume3-5", v1.ClaimPending, nil, pvutil.AnnBindCompleted), | ||||
| 			newClaimArray("claim3-5", "uid3-5", "10Gi", "volume3-5", v1.ClaimBound, nil, pvutil.AnnBindCompleted), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| @@ -413,8 +414,8 @@ func TestSync(t *testing.T) { | ||||
| 			"3-6 - bound claim with bound volume", | ||||
| 			newVolumeArray("volume3-6", "10Gi", "uid3-6-x", "claim3-6-x", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty), | ||||
| 			newVolumeArray("volume3-6", "10Gi", "uid3-6-x", "claim3-6-x", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty), | ||||
| 			newClaimArray("claim3-6", "uid3-6", "10Gi", "volume3-6", v1.ClaimPending, nil, annBindCompleted), | ||||
| 			newClaimArray("claim3-6", "uid3-6", "10Gi", "volume3-6", v1.ClaimLost, nil, annBindCompleted), | ||||
| 			newClaimArray("claim3-6", "uid3-6", "10Gi", "volume3-6", v1.ClaimPending, nil, pvutil.AnnBindCompleted), | ||||
| 			newClaimArray("claim3-6", "uid3-6", "10Gi", "volume3-6", v1.ClaimLost, nil, pvutil.AnnBindCompleted), | ||||
| 			[]string{"Warning ClaimMisbound"}, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| @@ -423,9 +424,9 @@ func TestSync(t *testing.T) { | ||||
| 			// check that Pending phase is set to Bound | ||||
| 			"3-7 - bound claim with unbound volume where selector doesn't match", | ||||
| 			newVolumeArray("volume3-3", "10Gi", "", "", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty), | ||||
| 			newVolumeArray("volume3-3", "10Gi", "uid3-3", "claim3-3", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController), | ||||
| 			withLabelSelector(labels, newClaimArray("claim3-3", "uid3-3", "10Gi", "volume3-3", v1.ClaimPending, nil, annBoundByController, annBindCompleted)), | ||||
| 			withLabelSelector(labels, newClaimArray("claim3-3", "uid3-3", "10Gi", "volume3-3", v1.ClaimBound, nil, annBoundByController, annBindCompleted)), | ||||
| 			newVolumeArray("volume3-3", "10Gi", "uid3-3", "claim3-3", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController), | ||||
| 			withLabelSelector(labels, newClaimArray("claim3-3", "uid3-3", "10Gi", "volume3-3", v1.ClaimPending, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted)), | ||||
| 			withLabelSelector(labels, newClaimArray("claim3-3", "uid3-3", "10Gi", "volume3-3", v1.ClaimBound, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted)), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		// [Unit test set 4] All syncVolume tests. | ||||
| @@ -464,16 +465,16 @@ func TestSync(t *testing.T) { | ||||
| 			"4-4 - volume bound to claim with different UID", | ||||
| 			newVolumeArray("volume4-4", "10Gi", "uid4-4", "claim4-4", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty), | ||||
| 			newVolumeArray("volume4-4", "10Gi", "uid4-4", "claim4-4", v1.VolumeReleased, v1.PersistentVolumeReclaimRetain, classEmpty), | ||||
| 			newClaimArray("claim4-4", "uid4-4-x", "10Gi", "volume4-4", v1.ClaimBound, nil, annBindCompleted), | ||||
| 			newClaimArray("claim4-4", "uid4-4-x", "10Gi", "volume4-4", v1.ClaimBound, nil, annBindCompleted), | ||||
| 			newClaimArray("claim4-4", "uid4-4-x", "10Gi", "volume4-4", v1.ClaimBound, nil, pvutil.AnnBindCompleted), | ||||
| 			newClaimArray("claim4-4", "uid4-4-x", "10Gi", "volume4-4", v1.ClaimBound, nil, pvutil.AnnBindCompleted), | ||||
| 			noevents, noerrors, testSyncVolume, | ||||
| 		}, | ||||
| 		{ | ||||
| 			// syncVolume with volume bound by controller to unbound claim. | ||||
| 			// Check syncVolume does not do anything. | ||||
| 			"4-5 - volume bound by controller to unbound claim", | ||||
| 			newVolumeArray("volume4-5", "10Gi", "uid4-5", "claim4-5", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController), | ||||
| 			newVolumeArray("volume4-5", "10Gi", "uid4-5", "claim4-5", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController), | ||||
| 			newVolumeArray("volume4-5", "10Gi", "uid4-5", "claim4-5", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController), | ||||
| 			newVolumeArray("volume4-5", "10Gi", "uid4-5", "claim4-5", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController), | ||||
| 			newClaimArray("claim4-5", "uid4-5", "10Gi", "", v1.ClaimPending, nil), | ||||
| 			newClaimArray("claim4-5", "uid4-5", "10Gi", "", v1.ClaimPending, nil), | ||||
| 			noevents, noerrors, testSyncVolume, | ||||
| @@ -502,7 +503,7 @@ func TestSync(t *testing.T) { | ||||
| 			// syncVolume with volume bound by controller to claim bound to | ||||
| 			// another volume. Check that the volume is rolled back. | ||||
| 			"4-7 - volume bound by controller to claim bound somewhere else", | ||||
| 			newVolumeArray("volume4-7", "10Gi", "uid4-7", "claim4-7", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController), | ||||
| 			newVolumeArray("volume4-7", "10Gi", "uid4-7", "claim4-7", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController), | ||||
| 			newVolumeArray("volume4-7", "10Gi", "", "", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty), | ||||
| 			newClaimArray("claim4-7", "uid4-7", "10Gi", "volume4-7-x", v1.ClaimBound, nil), | ||||
| 			newClaimArray("claim4-7", "uid4-7", "10Gi", "volume4-7-x", v1.ClaimBound, nil), | ||||
| @@ -531,10 +532,10 @@ func TestSync(t *testing.T) { | ||||
| 			}, | ||||
| 			[]*v1.PersistentVolume{ | ||||
| 				newVolume("volume13-1-1", "1Gi", "", "", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty), | ||||
| 				newVolume("volume13-1-2", "10Gi", "uid13-1", "claim13-1", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classGold, annBoundByController), | ||||
| 				newVolume("volume13-1-2", "10Gi", "uid13-1", "claim13-1", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classGold, pvutil.AnnBoundByController), | ||||
| 			}, | ||||
| 			newClaimArray("claim13-1", "uid13-1", "1Gi", "", v1.ClaimPending, &classGold), | ||||
| 			withExpectedCapacity("10Gi", newClaimArray("claim13-1", "uid13-1", "1Gi", "volume13-1-2", v1.ClaimBound, &classGold, annBoundByController, annBindCompleted)), | ||||
| 			withExpectedCapacity("10Gi", newClaimArray("claim13-1", "uid13-1", "1Gi", "volume13-1-2", v1.ClaimBound, &classGold, pvutil.AnnBoundByController, pvutil.AnnBindCompleted)), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| @@ -547,10 +548,10 @@ func TestSync(t *testing.T) { | ||||
| 			}, | ||||
| 			[]*v1.PersistentVolume{ | ||||
| 				newVolume("volume13-2-1", "1Gi", "", "", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classGold), | ||||
| 				newVolume("volume13-2-2", "10Gi", "uid13-2", "claim13-2", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController), | ||||
| 				newVolume("volume13-2-2", "10Gi", "uid13-2", "claim13-2", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController), | ||||
| 			}, | ||||
| 			newClaimArray("claim13-2", "uid13-2", "1Gi", "", v1.ClaimPending, nil), | ||||
| 			withExpectedCapacity("10Gi", newClaimArray("claim13-2", "uid13-2", "1Gi", "volume13-2-2", v1.ClaimBound, nil, annBoundByController, annBindCompleted)), | ||||
| 			withExpectedCapacity("10Gi", newClaimArray("claim13-2", "uid13-2", "1Gi", "volume13-2-2", v1.ClaimBound, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted)), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| @@ -563,10 +564,10 @@ func TestSync(t *testing.T) { | ||||
| 			}, | ||||
| 			[]*v1.PersistentVolume{ | ||||
| 				newVolume("volume13-3-1", "1Gi", "", "", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classSilver), | ||||
| 				newVolume("volume13-3-2", "10Gi", "uid13-3", "claim13-3", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classGold, annBoundByController), | ||||
| 				newVolume("volume13-3-2", "10Gi", "uid13-3", "claim13-3", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classGold, pvutil.AnnBoundByController), | ||||
| 			}, | ||||
| 			newClaimArray("claim13-3", "uid13-3", "1Gi", "", v1.ClaimPending, &classGold), | ||||
| 			withExpectedCapacity("10Gi", newClaimArray("claim13-3", "uid13-3", "1Gi", "volume13-3-2", v1.ClaimBound, &classGold, annBoundByController, annBindCompleted)), | ||||
| 			withExpectedCapacity("10Gi", newClaimArray("claim13-3", "uid13-3", "1Gi", "volume13-3-2", v1.ClaimBound, &classGold, pvutil.AnnBoundByController, pvutil.AnnBindCompleted)), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| @@ -574,9 +575,9 @@ func TestSync(t *testing.T) { | ||||
| 			// class="" | ||||
| 			"13-4 - empty class", | ||||
| 			newVolumeArray("volume13-4", "1Gi", "", "", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty), | ||||
| 			newVolumeArray("volume13-4", "1Gi", "uid13-4", "claim13-4", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController), | ||||
| 			newVolumeArray("volume13-4", "1Gi", "uid13-4", "claim13-4", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController), | ||||
| 			newClaimArray("claim13-4", "uid13-4", "1Gi", "", v1.ClaimPending, &classEmpty), | ||||
| 			newClaimArray("claim13-4", "uid13-4", "1Gi", "volume13-4", v1.ClaimBound, &classEmpty, annBoundByController, annBindCompleted), | ||||
| 			newClaimArray("claim13-4", "uid13-4", "1Gi", "volume13-4", v1.ClaimBound, &classEmpty, pvutil.AnnBoundByController, pvutil.AnnBindCompleted), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| @@ -584,9 +585,9 @@ func TestSync(t *testing.T) { | ||||
| 			// class = "" | ||||
| 			"13-5 - nil class", | ||||
| 			newVolumeArray("volume13-5", "1Gi", "", "", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty), | ||||
| 			newVolumeArray("volume13-5", "1Gi", "uid13-5", "claim13-5", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController), | ||||
| 			newVolumeArray("volume13-5", "1Gi", "uid13-5", "claim13-5", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController), | ||||
| 			newClaimArray("claim13-5", "uid13-5", "1Gi", "", v1.ClaimPending, nil), | ||||
| 			newClaimArray("claim13-5", "uid13-5", "1Gi", "volume13-5", v1.ClaimBound, nil, annBoundByController, annBindCompleted), | ||||
| 			newClaimArray("claim13-5", "uid13-5", "1Gi", "volume13-5", v1.ClaimBound, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 	} | ||||
| @@ -609,45 +610,45 @@ func TestSyncBlockVolumeDisabled(t *testing.T) { | ||||
| 			// syncVolume binds a requested block claim to a block volume | ||||
| 			"14-1 - binding to volumeMode block", | ||||
| 			withVolumeVolumeMode(&modeBlock, newVolumeArray("volume14-1", "10Gi", "", "", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty)), | ||||
| 			withVolumeVolumeMode(&modeBlock, newVolumeArray("volume14-1", "10Gi", "uid14-1", "claim14-1", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController)), | ||||
| 			withVolumeVolumeMode(&modeBlock, newVolumeArray("volume14-1", "10Gi", "uid14-1", "claim14-1", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController)), | ||||
| 			withClaimVolumeMode(&modeBlock, newClaimArray("claim14-1", "uid14-1", "10Gi", "", v1.ClaimPending, nil)), | ||||
| 			withClaimVolumeMode(&modeBlock, newClaimArray("claim14-1", "uid14-1", "10Gi", "volume14-1", v1.ClaimBound, nil, annBoundByController, annBindCompleted)), | ||||
| 			withClaimVolumeMode(&modeBlock, newClaimArray("claim14-1", "uid14-1", "10Gi", "volume14-1", v1.ClaimBound, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted)), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| 			// syncVolume binds a requested filesystem claim to a filesystem volume | ||||
| 			"14-2 - binding to volumeMode filesystem", | ||||
| 			withVolumeVolumeMode(&modeFile, newVolumeArray("volume14-2", "10Gi", "", "", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty)), | ||||
| 			withVolumeVolumeMode(&modeFile, newVolumeArray("volume14-2", "10Gi", "uid14-2", "claim14-2", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController)), | ||||
| 			withVolumeVolumeMode(&modeFile, newVolumeArray("volume14-2", "10Gi", "uid14-2", "claim14-2", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController)), | ||||
| 			withClaimVolumeMode(&modeFile, newClaimArray("claim14-2", "uid14-2", "10Gi", "", v1.ClaimPending, nil)), | ||||
| 			withClaimVolumeMode(&modeFile, newClaimArray("claim14-2", "uid14-2", "10Gi", "volume14-2", v1.ClaimBound, nil, annBoundByController, annBindCompleted)), | ||||
| 			withClaimVolumeMode(&modeFile, newClaimArray("claim14-2", "uid14-2", "10Gi", "volume14-2", v1.ClaimBound, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted)), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| 			// syncVolume binds an unspecified volumemode for claim to a specified filesystem volume | ||||
| 			"14-3 - binding to volumeMode filesystem using default for claim", | ||||
| 			withVolumeVolumeMode(&modeFile, newVolumeArray("volume14-3", "10Gi", "", "", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty)), | ||||
| 			withVolumeVolumeMode(&modeFile, newVolumeArray("volume14-3", "10Gi", "uid14-3", "claim14-3", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController)), | ||||
| 			withVolumeVolumeMode(&modeFile, newVolumeArray("volume14-3", "10Gi", "uid14-3", "claim14-3", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController)), | ||||
| 			withClaimVolumeMode(nil, newClaimArray("claim14-3", "uid14-3", "10Gi", "", v1.ClaimPending, nil)), | ||||
| 			withClaimVolumeMode(nil, newClaimArray("claim14-3", "uid14-3", "10Gi", "volume14-3", v1.ClaimBound, nil, annBoundByController, annBindCompleted)), | ||||
| 			withClaimVolumeMode(nil, newClaimArray("claim14-3", "uid14-3", "10Gi", "volume14-3", v1.ClaimBound, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted)), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| 			// syncVolume binds a requested filesystem claim to an unspecified volumeMode for volume | ||||
| 			"14-4 - binding to unspecified volumeMode using requested filesystem for claim", | ||||
| 			withVolumeVolumeMode(nil, newVolumeArray("volume14-4", "10Gi", "", "", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty)), | ||||
| 			withVolumeVolumeMode(nil, newVolumeArray("volume14-4", "10Gi", "uid14-4", "claim14-4", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController)), | ||||
| 			withVolumeVolumeMode(nil, newVolumeArray("volume14-4", "10Gi", "uid14-4", "claim14-4", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController)), | ||||
| 			withClaimVolumeMode(&modeFile, newClaimArray("claim14-4", "uid14-4", "10Gi", "", v1.ClaimPending, nil)), | ||||
| 			withClaimVolumeMode(&modeFile, newClaimArray("claim14-4", "uid14-4", "10Gi", "volume14-4", v1.ClaimBound, nil, annBoundByController, annBindCompleted)), | ||||
| 			withClaimVolumeMode(&modeFile, newClaimArray("claim14-4", "uid14-4", "10Gi", "volume14-4", v1.ClaimBound, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted)), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| 			// syncVolume binds a requested filesystem claim to an unspecified volumeMode for volume | ||||
| 			"14-5 - binding different volumeModes should be ignored", | ||||
| 			withVolumeVolumeMode(&modeBlock, newVolumeArray("volume14-5", "10Gi", "", "", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty)), | ||||
| 			withVolumeVolumeMode(&modeBlock, newVolumeArray("volume14-5", "10Gi", "uid14-5", "claim14-5", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController)), | ||||
| 			withVolumeVolumeMode(&modeBlock, newVolumeArray("volume14-5", "10Gi", "uid14-5", "claim14-5", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController)), | ||||
| 			withClaimVolumeMode(&modeFile, newClaimArray("claim14-5", "uid14-5", "10Gi", "", v1.ClaimPending, nil)), | ||||
| 			withClaimVolumeMode(&modeFile, newClaimArray("claim14-5", "uid14-5", "10Gi", "volume14-5", v1.ClaimBound, nil, annBoundByController, annBindCompleted)), | ||||
| 			withClaimVolumeMode(&modeFile, newClaimArray("claim14-5", "uid14-5", "10Gi", "volume14-5", v1.ClaimBound, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted)), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 	} | ||||
| @@ -672,18 +673,18 @@ func TestSyncBlockVolume(t *testing.T) { | ||||
| 			// syncVolume binds a requested block claim to a block volume | ||||
| 			"14-1 - binding to volumeMode block", | ||||
| 			withVolumeVolumeMode(&modeBlock, newVolumeArray("volume14-1", "10Gi", "", "", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty)), | ||||
| 			withVolumeVolumeMode(&modeBlock, newVolumeArray("volume14-1", "10Gi", "uid14-1", "claim14-1", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController)), | ||||
| 			withVolumeVolumeMode(&modeBlock, newVolumeArray("volume14-1", "10Gi", "uid14-1", "claim14-1", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController)), | ||||
| 			withClaimVolumeMode(&modeBlock, newClaimArray("claim14-1", "uid14-1", "10Gi", "", v1.ClaimPending, nil)), | ||||
| 			withClaimVolumeMode(&modeBlock, newClaimArray("claim14-1", "uid14-1", "10Gi", "volume14-1", v1.ClaimBound, nil, annBoundByController, annBindCompleted)), | ||||
| 			withClaimVolumeMode(&modeBlock, newClaimArray("claim14-1", "uid14-1", "10Gi", "volume14-1", v1.ClaimBound, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted)), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| 			// syncVolume binds a requested filesystem claim to a filesystem volume | ||||
| 			"14-2 - binding to volumeMode filesystem", | ||||
| 			withVolumeVolumeMode(&modeFile, newVolumeArray("volume14-2", "10Gi", "", "", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty)), | ||||
| 			withVolumeVolumeMode(&modeFile, newVolumeArray("volume14-2", "10Gi", "uid14-2", "claim14-2", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController)), | ||||
| 			withVolumeVolumeMode(&modeFile, newVolumeArray("volume14-2", "10Gi", "uid14-2", "claim14-2", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController)), | ||||
| 			withClaimVolumeMode(&modeFile, newClaimArray("claim14-2", "uid14-2", "10Gi", "", v1.ClaimPending, nil)), | ||||
| 			withClaimVolumeMode(&modeFile, newClaimArray("claim14-2", "uid14-2", "10Gi", "volume14-2", v1.ClaimBound, nil, annBoundByController, annBindCompleted)), | ||||
| 			withClaimVolumeMode(&modeFile, newClaimArray("claim14-2", "uid14-2", "10Gi", "volume14-2", v1.ClaimBound, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted)), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| @@ -742,7 +743,7 @@ func TestSyncBlockVolume(t *testing.T) { | ||||
| 			withVolumeVolumeMode(&modeBlock, newVolumeArray("volume14-7", "10Gi", "", "claim14-7", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty)), | ||||
| 			withVolumeVolumeMode(&modeBlock, newVolumeArray("volume14-7", "10Gi", "uid14-7", "claim14-7", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty)), | ||||
| 			withClaimVolumeMode(&modeBlock, newClaimArray("claim14-7", "uid14-7", "10Gi", "", v1.ClaimPending, nil)), | ||||
| 			withClaimVolumeMode(&modeBlock, newClaimArray("claim14-7", "uid14-7", "10Gi", "volume14-7", v1.ClaimBound, nil, annBoundByController, annBindCompleted)), | ||||
| 			withClaimVolumeMode(&modeBlock, newClaimArray("claim14-7", "uid14-7", "10Gi", "volume14-7", v1.ClaimBound, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted)), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| @@ -769,9 +770,9 @@ func TestSyncBlockVolume(t *testing.T) { | ||||
| 			// syncVolume binds when pvc is prebound to pv with matching volumeModes block | ||||
| 			"14-9 - bind when pvc is prebound to pv with matching volumeModes block", | ||||
| 			withVolumeVolumeMode(&modeBlock, newVolumeArray("volume14-9", "10Gi", "", "", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty)), | ||||
| 			withVolumeVolumeMode(&modeBlock, newVolumeArray("volume14-9", "10Gi", "uid14-9", "claim14-9", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController)), | ||||
| 			withVolumeVolumeMode(&modeBlock, newVolumeArray("volume14-9", "10Gi", "uid14-9", "claim14-9", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController)), | ||||
| 			withClaimVolumeMode(&modeBlock, newClaimArray("claim14-9", "uid14-9", "10Gi", "volume14-9", v1.ClaimPending, nil)), | ||||
| 			withClaimVolumeMode(&modeBlock, newClaimArray("claim14-9", "uid14-9", "10Gi", "volume14-9", v1.ClaimBound, nil, annBindCompleted)), | ||||
| 			withClaimVolumeMode(&modeBlock, newClaimArray("claim14-9", "uid14-9", "10Gi", "volume14-9", v1.ClaimBound, nil, pvutil.AnnBindCompleted)), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| @@ -780,16 +781,16 @@ func TestSyncBlockVolume(t *testing.T) { | ||||
| 			withVolumeVolumeMode(&modeBlock, newVolumeArray("volume14-10", "10Gi", "", "claim14-10", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty)), | ||||
| 			withVolumeVolumeMode(&modeBlock, newVolumeArray("volume14-10", "10Gi", "uid14-10", "claim14-10", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty)), | ||||
| 			withClaimVolumeMode(&modeBlock, newClaimArray("claim14-10", "uid14-10", "10Gi", "", v1.ClaimPending, nil)), | ||||
| 			withClaimVolumeMode(&modeBlock, newClaimArray("claim14-10", "uid14-10", "10Gi", "volume14-10", v1.ClaimBound, nil, annBoundByController, annBindCompleted)), | ||||
| 			withClaimVolumeMode(&modeBlock, newClaimArray("claim14-10", "uid14-10", "10Gi", "volume14-10", v1.ClaimBound, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted)), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| 			// syncVolume binds when pvc is prebound to pv with matching volumeModes filesystem | ||||
| 			"14-11 - bind when pvc is prebound to pv with matching volumeModes filesystem", | ||||
| 			withVolumeVolumeMode(&modeFile, newVolumeArray("volume14-11", "10Gi", "", "", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty)), | ||||
| 			withVolumeVolumeMode(&modeFile, newVolumeArray("volume14-11", "10Gi", "uid14-11", "claim14-11", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController)), | ||||
| 			withVolumeVolumeMode(&modeFile, newVolumeArray("volume14-11", "10Gi", "uid14-11", "claim14-11", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController)), | ||||
| 			withClaimVolumeMode(&modeFile, newClaimArray("claim14-11", "uid14-11", "10Gi", "volume14-11", v1.ClaimPending, nil)), | ||||
| 			withClaimVolumeMode(&modeFile, newClaimArray("claim14-11", "uid14-11", "10Gi", "volume14-11", v1.ClaimBound, nil, annBindCompleted)), | ||||
| 			withClaimVolumeMode(&modeFile, newClaimArray("claim14-11", "uid14-11", "10Gi", "volume14-11", v1.ClaimBound, nil, pvutil.AnnBindCompleted)), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| @@ -798,14 +799,14 @@ func TestSyncBlockVolume(t *testing.T) { | ||||
| 			withVolumeVolumeMode(&modeFile, newVolumeArray("volume14-12", "10Gi", "", "claim14-12", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty)), | ||||
| 			withVolumeVolumeMode(&modeFile, newVolumeArray("volume14-12", "10Gi", "uid14-12", "claim14-12", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty)), | ||||
| 			withClaimVolumeMode(&modeFile, newClaimArray("claim14-12", "uid14-12", "10Gi", "", v1.ClaimPending, nil)), | ||||
| 			withClaimVolumeMode(&modeFile, newClaimArray("claim14-12", "uid14-12", "10Gi", "volume14-12", v1.ClaimBound, nil, annBoundByController, annBindCompleted)), | ||||
| 			withClaimVolumeMode(&modeFile, newClaimArray("claim14-12", "uid14-12", "10Gi", "volume14-12", v1.ClaimBound, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted)), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| 			// syncVolume output warning when pv is prebound to pvc with mismatching volumeMode | ||||
| 			"14-13 - output warning when pv is prebound to pvc with different volumeModes", | ||||
| 			withVolumeVolumeMode(&modeFile, newVolumeArray("volume14-13", "10Gi", "uid14-13", "claim14-13", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController)), | ||||
| 			withVolumeVolumeMode(&modeFile, newVolumeArray("volume14-13", "10Gi", "uid14-13", "claim14-13", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController)), | ||||
| 			withVolumeVolumeMode(&modeFile, newVolumeArray("volume14-13", "10Gi", "uid14-13", "claim14-13", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController)), | ||||
| 			withVolumeVolumeMode(&modeFile, newVolumeArray("volume14-13", "10Gi", "uid14-13", "claim14-13", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController)), | ||||
| 			withClaimVolumeMode(&modeBlock, newClaimArray("claim14-13", "uid14-13", "10Gi", "", v1.ClaimPending, nil)), | ||||
| 			withClaimVolumeMode(&modeBlock, newClaimArray("claim14-13", "uid14-13", "10Gi", "", v1.ClaimPending, nil)), | ||||
| 			[]string{"Warning VolumeMismatch"}, | ||||
| @@ -814,8 +815,8 @@ func TestSyncBlockVolume(t *testing.T) { | ||||
| 		{ | ||||
| 			// syncVolume output warning when pv is prebound to pvc with mismatching volumeMode | ||||
| 			"14-13-1 - output warning when pv is prebound to pvc with different volumeModes", | ||||
| 			withVolumeVolumeMode(&modeBlock, newVolumeArray("volume14-13-1", "10Gi", "uid14-13-1", "claim14-13-1", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController)), | ||||
| 			withVolumeVolumeMode(&modeBlock, newVolumeArray("volume14-13-1", "10Gi", "uid14-13-1", "claim14-13-1", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController)), | ||||
| 			withVolumeVolumeMode(&modeBlock, newVolumeArray("volume14-13-1", "10Gi", "uid14-13-1", "claim14-13-1", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController)), | ||||
| 			withVolumeVolumeMode(&modeBlock, newVolumeArray("volume14-13-1", "10Gi", "uid14-13-1", "claim14-13-1", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController)), | ||||
| 			withClaimVolumeMode(&modeFile, newClaimArray("claim14-13-1", "uid14-13-1", "10Gi", "", v1.ClaimPending, nil)), | ||||
| 			withClaimVolumeMode(&modeFile, newClaimArray("claim14-13-1", "uid14-13-1", "10Gi", "", v1.ClaimPending, nil)), | ||||
| 			[]string{"Warning VolumeMismatch"}, | ||||
| @@ -824,8 +825,8 @@ func TestSyncBlockVolume(t *testing.T) { | ||||
| 		{ | ||||
| 			// syncVolume waits for synClaim without warning when pv is prebound to pvc with matching volumeMode block | ||||
| 			"14-14 - wait for synClaim without warning when pv is prebound to pvc with matching volumeModes block", | ||||
| 			withVolumeVolumeMode(&modeBlock, newVolumeArray("volume14-14", "10Gi", "uid14-14", "claim14-14", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController)), | ||||
| 			withVolumeVolumeMode(&modeBlock, newVolumeArray("volume14-14", "10Gi", "uid14-14", "claim14-14", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController)), | ||||
| 			withVolumeVolumeMode(&modeBlock, newVolumeArray("volume14-14", "10Gi", "uid14-14", "claim14-14", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController)), | ||||
| 			withVolumeVolumeMode(&modeBlock, newVolumeArray("volume14-14", "10Gi", "uid14-14", "claim14-14", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController)), | ||||
| 			withClaimVolumeMode(&modeBlock, newClaimArray("claim14-14", "uid14-14", "10Gi", "", v1.ClaimPending, nil)), | ||||
| 			withClaimVolumeMode(&modeBlock, newClaimArray("claim14-14", "uid14-14", "10Gi", "", v1.ClaimPending, nil)), | ||||
| 			noevents, noerrors, testSyncVolume, | ||||
| @@ -833,8 +834,8 @@ func TestSyncBlockVolume(t *testing.T) { | ||||
| 		{ | ||||
| 			// syncVolume waits for synClaim without warning when pv is prebound to pvc with matching volumeMode file | ||||
| 			"14-14-1 - wait for synClaim without warning when pv is prebound to pvc with matching volumeModes file", | ||||
| 			withVolumeVolumeMode(&modeFile, newVolumeArray("volume14-14-1", "10Gi", "uid14-14-1", "claim14-14-1", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController)), | ||||
| 			withVolumeVolumeMode(&modeFile, newVolumeArray("volume14-14-1", "10Gi", "uid14-14-1", "claim14-14-1", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController)), | ||||
| 			withVolumeVolumeMode(&modeFile, newVolumeArray("volume14-14-1", "10Gi", "uid14-14-1", "claim14-14-1", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController)), | ||||
| 			withVolumeVolumeMode(&modeFile, newVolumeArray("volume14-14-1", "10Gi", "uid14-14-1", "claim14-14-1", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController)), | ||||
| 			withClaimVolumeMode(&modeFile, newClaimArray("claim14-14-1", "uid14-14-1", "10Gi", "", v1.ClaimPending, nil)), | ||||
| 			withClaimVolumeMode(&modeFile, newClaimArray("claim14-14-1", "uid14-14-1", "10Gi", "", v1.ClaimPending, nil)), | ||||
| 			noevents, noerrors, testSyncVolume, | ||||
| @@ -867,9 +868,9 @@ func TestMultiSync(t *testing.T) { | ||||
| 			// syncClaim binds to a matching unbound volume. | ||||
| 			"10-1 - successful bind", | ||||
| 			newVolumeArray("volume10-1", "1Gi", "", "", v1.VolumePending, v1.PersistentVolumeReclaimRetain, classEmpty), | ||||
| 			newVolumeArray("volume10-1", "1Gi", "uid10-1", "claim10-1", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController), | ||||
| 			newVolumeArray("volume10-1", "1Gi", "uid10-1", "claim10-1", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController), | ||||
| 			newClaimArray("claim10-1", "uid10-1", "1Gi", "", v1.ClaimPending, nil), | ||||
| 			newClaimArray("claim10-1", "uid10-1", "1Gi", "volume10-1", v1.ClaimBound, nil, annBoundByController, annBindCompleted), | ||||
| 			newClaimArray("claim10-1", "uid10-1", "1Gi", "volume10-1", v1.ClaimBound, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 		{ | ||||
| @@ -877,15 +878,15 @@ func TestMultiSync(t *testing.T) { | ||||
| 			// wins and the second rolls back. | ||||
| 			"10-2 - bind PV race", | ||||
| 			[]*v1.PersistentVolume{ | ||||
| 				newVolume("volume10-2-1", "1Gi", "uid10-2", "claim10-2", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController), | ||||
| 				newVolume("volume10-2-2", "1Gi", "uid10-2", "claim10-2", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController), | ||||
| 				newVolume("volume10-2-1", "1Gi", "uid10-2", "claim10-2", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController), | ||||
| 				newVolume("volume10-2-2", "1Gi", "uid10-2", "claim10-2", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController), | ||||
| 			}, | ||||
| 			[]*v1.PersistentVolume{ | ||||
| 				newVolume("volume10-2-1", "1Gi", "uid10-2", "claim10-2", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController), | ||||
| 				newVolume("volume10-2-1", "1Gi", "uid10-2", "claim10-2", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController), | ||||
| 				newVolume("volume10-2-2", "1Gi", "", "", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty), | ||||
| 			}, | ||||
| 			newClaimArray("claim10-2", "uid10-2", "1Gi", "volume10-2-1", v1.ClaimBound, nil, annBoundByController, annBindCompleted), | ||||
| 			newClaimArray("claim10-2", "uid10-2", "1Gi", "volume10-2-1", v1.ClaimBound, nil, annBoundByController, annBindCompleted), | ||||
| 			newClaimArray("claim10-2", "uid10-2", "1Gi", "volume10-2-1", v1.ClaimBound, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted), | ||||
| 			newClaimArray("claim10-2", "uid10-2", "1Gi", "volume10-2-1", v1.ClaimBound, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted), | ||||
| 			noevents, noerrors, testSyncClaim, | ||||
| 		}, | ||||
| 	} | ||||
|   | ||||
| @@ -23,6 +23,7 @@ import ( | ||||
| 	"k8s.io/api/core/v1" | ||||
| 	storage "k8s.io/api/storage/v1" | ||||
| 	pvtesting "k8s.io/kubernetes/pkg/controller/volume/persistentvolume/testing" | ||||
| 	pvutil "k8s.io/kubernetes/pkg/controller/volume/persistentvolume/util" | ||||
| ) | ||||
|  | ||||
| // Test single call to syncVolume, expecting recycling to happen. | ||||
| @@ -34,7 +35,7 @@ func TestDeleteSync(t *testing.T) { | ||||
| 		{ | ||||
| 			// delete volume bound by controller | ||||
| 			"8-1 - successful delete", | ||||
| 			newVolumeArray("volume8-1", "1Gi", "uid8-1", "claim8-1", v1.VolumeBound, v1.PersistentVolumeReclaimDelete, classEmpty, annBoundByController), | ||||
| 			newVolumeArray("volume8-1", "1Gi", "uid8-1", "claim8-1", v1.VolumeBound, v1.PersistentVolumeReclaimDelete, classEmpty, pvutil.AnnBoundByController), | ||||
| 			novolumes, | ||||
| 			noclaims, | ||||
| 			noclaims, | ||||
| @@ -102,8 +103,8 @@ func TestDeleteSync(t *testing.T) { | ||||
| 			// starts. This simulates "volume no longer needs recycling, | ||||
| 			// skipping". | ||||
| 			"8-7 - volume is bound before deleting", | ||||
| 			newVolumeArray("volume8-7", "1Gi", "uid8-7", "claim8-7", v1.VolumeBound, v1.PersistentVolumeReclaimDelete, classEmpty, annBoundByController), | ||||
| 			newVolumeArray("volume8-7", "1Gi", "uid8-7", "claim8-7", v1.VolumeBound, v1.PersistentVolumeReclaimDelete, classEmpty, annBoundByController), | ||||
| 			newVolumeArray("volume8-7", "1Gi", "uid8-7", "claim8-7", v1.VolumeBound, v1.PersistentVolumeReclaimDelete, classEmpty, pvutil.AnnBoundByController), | ||||
| 			newVolumeArray("volume8-7", "1Gi", "uid8-7", "claim8-7", v1.VolumeBound, v1.PersistentVolumeReclaimDelete, classEmpty, pvutil.AnnBoundByController), | ||||
| 			noclaims, | ||||
| 			newClaimArray("claim8-7", "uid8-7", "10Gi", "volume8-7", v1.ClaimBound, nil), | ||||
| 			noevents, noerrors, | ||||
| @@ -131,15 +132,15 @@ func TestDeleteSync(t *testing.T) { | ||||
| 		{ | ||||
| 			// PV requires external deleter | ||||
| 			"8-10 - external deleter", | ||||
| 			newVolumeArray("volume8-10", "1Gi", "uid10-1", "claim10-1", v1.VolumeBound, v1.PersistentVolumeReclaimDelete, classEmpty, annBoundByController), | ||||
| 			newVolumeArray("volume8-10", "1Gi", "uid10-1", "claim10-1", v1.VolumeReleased, v1.PersistentVolumeReclaimDelete, classEmpty, annBoundByController), | ||||
| 			newVolumeArray("volume8-10", "1Gi", "uid10-1", "claim10-1", v1.VolumeBound, v1.PersistentVolumeReclaimDelete, classEmpty, pvutil.AnnBoundByController), | ||||
| 			newVolumeArray("volume8-10", "1Gi", "uid10-1", "claim10-1", v1.VolumeReleased, v1.PersistentVolumeReclaimDelete, classEmpty, pvutil.AnnBoundByController), | ||||
| 			noclaims, | ||||
| 			noclaims, | ||||
| 			noevents, noerrors, | ||||
| 			func(ctrl *PersistentVolumeController, reactor *pvtesting.VolumeReactor, test controllerTest) error { | ||||
| 				// Inject external deleter annotation | ||||
| 				test.initialVolumes[0].Annotations[annDynamicallyProvisioned] = "external.io/test" | ||||
| 				test.expectedVolumes[0].Annotations[annDynamicallyProvisioned] = "external.io/test" | ||||
| 				test.initialVolumes[0].Annotations[pvutil.AnnDynamicallyProvisioned] = "external.io/test" | ||||
| 				test.expectedVolumes[0].Annotations[pvutil.AnnDynamicallyProvisioned] = "external.io/test" | ||||
| 				return testSyncVolume(ctrl, reactor, test) | ||||
| 			}, | ||||
| 		}, | ||||
| @@ -148,11 +149,11 @@ func TestDeleteSync(t *testing.T) { | ||||
| 			// One of the PVs is deleted. | ||||
| 			"8-11 - two PVs provisioned for a single claim", | ||||
| 			[]*v1.PersistentVolume{ | ||||
| 				newVolume("volume8-11-1", "1Gi", "uid8-11", "claim8-11", v1.VolumeBound, v1.PersistentVolumeReclaimDelete, classEmpty, annDynamicallyProvisioned), | ||||
| 				newVolume("volume8-11-2", "1Gi", "uid8-11", "claim8-11", v1.VolumeBound, v1.PersistentVolumeReclaimDelete, classEmpty, annDynamicallyProvisioned), | ||||
| 				newVolume("volume8-11-1", "1Gi", "uid8-11", "claim8-11", v1.VolumeBound, v1.PersistentVolumeReclaimDelete, classEmpty, pvutil.AnnDynamicallyProvisioned), | ||||
| 				newVolume("volume8-11-2", "1Gi", "uid8-11", "claim8-11", v1.VolumeBound, v1.PersistentVolumeReclaimDelete, classEmpty, pvutil.AnnDynamicallyProvisioned), | ||||
| 			}, | ||||
| 			[]*v1.PersistentVolume{ | ||||
| 				newVolume("volume8-11-2", "1Gi", "uid8-11", "claim8-11", v1.VolumeBound, v1.PersistentVolumeReclaimDelete, classEmpty, annDynamicallyProvisioned), | ||||
| 				newVolume("volume8-11-2", "1Gi", "uid8-11", "claim8-11", v1.VolumeBound, v1.PersistentVolumeReclaimDelete, classEmpty, pvutil.AnnDynamicallyProvisioned), | ||||
| 			}, | ||||
| 			// the claim is bound to volume8-11-2 -> volume8-11-1 has lost the race and will be deleted | ||||
| 			newClaimArray("claim8-11", "uid8-11", "10Gi", "volume8-11-2", v1.ClaimBound, nil), | ||||
| @@ -168,12 +169,12 @@ func TestDeleteSync(t *testing.T) { | ||||
| 			// external provisioner. | ||||
| 			"8-12 - two PVs externally provisioned for a single claim", | ||||
| 			[]*v1.PersistentVolume{ | ||||
| 				newVolume("volume8-12-1", "1Gi", "uid8-12", "claim8-12", v1.VolumeBound, v1.PersistentVolumeReclaimDelete, classEmpty, annDynamicallyProvisioned), | ||||
| 				newVolume("volume8-12-2", "1Gi", "uid8-12", "claim8-12", v1.VolumeBound, v1.PersistentVolumeReclaimDelete, classEmpty, annDynamicallyProvisioned), | ||||
| 				newVolume("volume8-12-1", "1Gi", "uid8-12", "claim8-12", v1.VolumeBound, v1.PersistentVolumeReclaimDelete, classEmpty, pvutil.AnnDynamicallyProvisioned), | ||||
| 				newVolume("volume8-12-2", "1Gi", "uid8-12", "claim8-12", v1.VolumeBound, v1.PersistentVolumeReclaimDelete, classEmpty, pvutil.AnnDynamicallyProvisioned), | ||||
| 			}, | ||||
| 			[]*v1.PersistentVolume{ | ||||
| 				newVolume("volume8-12-1", "1Gi", "uid8-12", "claim8-12", v1.VolumeReleased, v1.PersistentVolumeReclaimDelete, classEmpty, annDynamicallyProvisioned), | ||||
| 				newVolume("volume8-12-2", "1Gi", "uid8-12", "claim8-12", v1.VolumeBound, v1.PersistentVolumeReclaimDelete, classEmpty, annDynamicallyProvisioned), | ||||
| 				newVolume("volume8-12-1", "1Gi", "uid8-12", "claim8-12", v1.VolumeReleased, v1.PersistentVolumeReclaimDelete, classEmpty, pvutil.AnnDynamicallyProvisioned), | ||||
| 				newVolume("volume8-12-2", "1Gi", "uid8-12", "claim8-12", v1.VolumeBound, v1.PersistentVolumeReclaimDelete, classEmpty, pvutil.AnnDynamicallyProvisioned), | ||||
| 			}, | ||||
| 			// the claim is bound to volume8-12-2 -> volume8-12-1 has lost the race and will be "Released" | ||||
| 			newClaimArray("claim8-12", "uid8-12", "10Gi", "volume8-12-2", v1.ClaimBound, nil), | ||||
| @@ -181,8 +182,8 @@ func TestDeleteSync(t *testing.T) { | ||||
| 			noevents, noerrors, | ||||
| 			func(ctrl *PersistentVolumeController, reactor *pvtesting.VolumeReactor, test controllerTest) error { | ||||
| 				// Inject external deleter annotation | ||||
| 				test.initialVolumes[0].Annotations[annDynamicallyProvisioned] = "external.io/test" | ||||
| 				test.expectedVolumes[0].Annotations[annDynamicallyProvisioned] = "external.io/test" | ||||
| 				test.initialVolumes[0].Annotations[pvutil.AnnDynamicallyProvisioned] = "external.io/test" | ||||
| 				test.expectedVolumes[0].Annotations[pvutil.AnnDynamicallyProvisioned] = "external.io/test" | ||||
| 				return testSyncVolume(ctrl, reactor, test) | ||||
| 			}, | ||||
| 		}, | ||||
|   | ||||
| @@ -43,6 +43,7 @@ import ( | ||||
| 	"k8s.io/kubernetes/pkg/api/testapi" | ||||
| 	"k8s.io/kubernetes/pkg/controller" | ||||
| 	pvtesting "k8s.io/kubernetes/pkg/controller/volume/persistentvolume/testing" | ||||
| 	pvutil "k8s.io/kubernetes/pkg/controller/volume/persistentvolume/util" | ||||
| 	vol "k8s.io/kubernetes/pkg/volume" | ||||
| 	"k8s.io/kubernetes/pkg/volume/util/recyclerclient" | ||||
| ) | ||||
| @@ -275,7 +276,7 @@ func newVolume(name, capacity, boundToClaimUID, boundToClaimName string, phase v | ||||
| 		volume.Annotations = make(map[string]string) | ||||
| 		for _, a := range annotations { | ||||
| 			switch a { | ||||
| 			case annDynamicallyProvisioned: | ||||
| 			case pvutil.AnnDynamicallyProvisioned: | ||||
| 				volume.Annotations[a] = mockPluginName | ||||
| 			default: | ||||
| 				volume.Annotations[a] = "yes" | ||||
| @@ -380,7 +381,7 @@ func newClaim(name, claimUID, capacity, boundToVolume string, phase v1.Persisten | ||||
| 		claim.Annotations = make(map[string]string) | ||||
| 		for _, a := range annotations { | ||||
| 			switch a { | ||||
| 			case annStorageProvisioner: | ||||
| 			case pvutil.AnnStorageProvisioner: | ||||
| 				claim.Annotations[a] = mockPluginName | ||||
| 			default: | ||||
| 				claim.Annotations[a] = "yes" | ||||
|   | ||||
| @@ -26,6 +26,7 @@ import ( | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| 	api "k8s.io/kubernetes/pkg/apis/core" | ||||
| 	pvtesting "k8s.io/kubernetes/pkg/controller/volume/persistentvolume/testing" | ||||
| 	pvutil "k8s.io/kubernetes/pkg/controller/volume/persistentvolume/util" | ||||
| ) | ||||
|  | ||||
| var class1Parameters = map[string]string{ | ||||
| @@ -134,10 +135,10 @@ func TestProvisionSync(t *testing.T) { | ||||
| 			// Provision a volume (with a default class) | ||||
| 			"11-1 - successful provision with storage class 1", | ||||
| 			novolumes, | ||||
| 			newVolumeArray("pvc-uid11-1", "1Gi", "uid11-1", "claim11-1", v1.VolumeBound, v1.PersistentVolumeReclaimDelete, classGold, annBoundByController, annDynamicallyProvisioned), | ||||
| 			newVolumeArray("pvc-uid11-1", "1Gi", "uid11-1", "claim11-1", v1.VolumeBound, v1.PersistentVolumeReclaimDelete, classGold, pvutil.AnnBoundByController, pvutil.AnnDynamicallyProvisioned), | ||||
| 			newClaimArray("claim11-1", "uid11-1", "1Gi", "", v1.ClaimPending, &classGold), | ||||
| 			// Binding will be completed in the next syncClaim | ||||
| 			newClaimArray("claim11-1", "uid11-1", "1Gi", "", v1.ClaimPending, &classGold, annStorageProvisioner), | ||||
| 			newClaimArray("claim11-1", "uid11-1", "1Gi", "", v1.ClaimPending, &classGold, pvutil.AnnStorageProvisioner), | ||||
| 			[]string{"Normal ProvisioningSucceeded"}, noerrors, wrapTestWithProvisionCalls([]provisionCall{provision1Success}, testSyncClaim), | ||||
| 		}, | ||||
| 		{ | ||||
| @@ -156,7 +157,7 @@ func TestProvisionSync(t *testing.T) { | ||||
| 			novolumes, | ||||
| 			novolumes, | ||||
| 			newClaimArray("claim11-3", "uid11-3", "1Gi", "", v1.ClaimPending, &classGold), | ||||
| 			newClaimArray("claim11-3", "uid11-3", "1Gi", "", v1.ClaimPending, &classGold, annStorageProvisioner), | ||||
| 			newClaimArray("claim11-3", "uid11-3", "1Gi", "", v1.ClaimPending, &classGold, pvutil.AnnStorageProvisioner), | ||||
| 			[]string{"Warning ProvisioningFailed"}, noerrors, | ||||
| 			wrapTestWithProvisionCalls([]provisionCall{}, testSyncClaim), | ||||
| 		}, | ||||
| @@ -166,7 +167,7 @@ func TestProvisionSync(t *testing.T) { | ||||
| 			novolumes, | ||||
| 			novolumes, | ||||
| 			newClaimArray("claim11-4", "uid11-4", "1Gi", "", v1.ClaimPending, &classGold), | ||||
| 			newClaimArray("claim11-4", "uid11-4", "1Gi", "", v1.ClaimPending, &classGold, annStorageProvisioner), | ||||
| 			newClaimArray("claim11-4", "uid11-4", "1Gi", "", v1.ClaimPending, &classGold, pvutil.AnnStorageProvisioner), | ||||
| 			[]string{"Warning ProvisioningFailed"}, noerrors, | ||||
| 			wrapTestWithProvisionCalls([]provisionCall{provision1Error}, testSyncClaim), | ||||
| 		}, | ||||
| @@ -174,9 +175,9 @@ func TestProvisionSync(t *testing.T) { | ||||
| 			// No provisioning if there is a matching volume available | ||||
| 			"11-6 - provisioning when there is a volume available", | ||||
| 			newVolumeArray("volume11-6", "1Gi", "", "", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classGold), | ||||
| 			newVolumeArray("volume11-6", "1Gi", "uid11-6", "claim11-6", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classGold, annBoundByController), | ||||
| 			newVolumeArray("volume11-6", "1Gi", "uid11-6", "claim11-6", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classGold, pvutil.AnnBoundByController), | ||||
| 			newClaimArray("claim11-6", "uid11-6", "1Gi", "", v1.ClaimPending, &classGold), | ||||
| 			newClaimArray("claim11-6", "uid11-6", "1Gi", "volume11-6", v1.ClaimBound, &classGold, annBoundByController, annBindCompleted), | ||||
| 			newClaimArray("claim11-6", "uid11-6", "1Gi", "volume11-6", v1.ClaimBound, &classGold, pvutil.AnnBoundByController, pvutil.AnnBindCompleted), | ||||
| 			noevents, noerrors, | ||||
| 			// No provisioning plugin confingure - makes the test fail when | ||||
| 			// the controller erroneously tries to provision something | ||||
| @@ -187,15 +188,15 @@ func TestProvisionSync(t *testing.T) { | ||||
| 			// a volume. | ||||
| 			"11-7 - claim is bound before provisioning", | ||||
| 			novolumes, | ||||
| 			newVolumeArray("pvc-uid11-7", "1Gi", "uid11-7", "claim11-7", v1.VolumeBound, v1.PersistentVolumeReclaimDelete, classGold, annBoundByController, annDynamicallyProvisioned), | ||||
| 			newVolumeArray("pvc-uid11-7", "1Gi", "uid11-7", "claim11-7", v1.VolumeBound, v1.PersistentVolumeReclaimDelete, classGold, pvutil.AnnBoundByController, pvutil.AnnDynamicallyProvisioned), | ||||
| 			newClaimArray("claim11-7", "uid11-7", "1Gi", "", v1.ClaimPending, &classGold), | ||||
| 			// The claim would be bound in next syncClaim | ||||
| 			newClaimArray("claim11-7", "uid11-7", "1Gi", "", v1.ClaimPending, &classGold, annStorageProvisioner), | ||||
| 			newClaimArray("claim11-7", "uid11-7", "1Gi", "", v1.ClaimPending, &classGold, pvutil.AnnStorageProvisioner), | ||||
| 			noevents, noerrors, | ||||
| 			wrapTestWithInjectedOperation(wrapTestWithProvisionCalls([]provisionCall{}, testSyncClaim), func(ctrl *PersistentVolumeController, reactor *pvtesting.VolumeReactor) { | ||||
| 				// Create a volume before provisionClaimOperation starts. | ||||
| 				// This similates a parallel controller provisioning the volume. | ||||
| 				volume := newVolume("pvc-uid11-7", "1Gi", "uid11-7", "claim11-7", v1.VolumeBound, v1.PersistentVolumeReclaimDelete, classGold, annBoundByController, annDynamicallyProvisioned) | ||||
| 				volume := newVolume("pvc-uid11-7", "1Gi", "uid11-7", "claim11-7", v1.VolumeBound, v1.PersistentVolumeReclaimDelete, classGold, pvutil.AnnBoundByController, pvutil.AnnDynamicallyProvisioned) | ||||
| 				reactor.AddVolume(volume) | ||||
| 			}), | ||||
| 		}, | ||||
| @@ -204,10 +205,10 @@ func TestProvisionSync(t *testing.T) { | ||||
| 			// second retry succeeds | ||||
| 			"11-8 - cannot save provisioned volume", | ||||
| 			novolumes, | ||||
| 			newVolumeArray("pvc-uid11-8", "1Gi", "uid11-8", "claim11-8", v1.VolumeBound, v1.PersistentVolumeReclaimDelete, classGold, annBoundByController, annDynamicallyProvisioned), | ||||
| 			newVolumeArray("pvc-uid11-8", "1Gi", "uid11-8", "claim11-8", v1.VolumeBound, v1.PersistentVolumeReclaimDelete, classGold, pvutil.AnnBoundByController, pvutil.AnnDynamicallyProvisioned), | ||||
| 			newClaimArray("claim11-8", "uid11-8", "1Gi", "", v1.ClaimPending, &classGold), | ||||
| 			// Binding will be completed in the next syncClaim | ||||
| 			newClaimArray("claim11-8", "uid11-8", "1Gi", "", v1.ClaimPending, &classGold, annStorageProvisioner), | ||||
| 			newClaimArray("claim11-8", "uid11-8", "1Gi", "", v1.ClaimPending, &classGold, pvutil.AnnStorageProvisioner), | ||||
| 			[]string{"Normal ProvisioningSucceeded"}, | ||||
| 			[]pvtesting.ReactorError{ | ||||
| 				// Inject error to the first | ||||
| @@ -224,7 +225,7 @@ func TestProvisionSync(t *testing.T) { | ||||
| 			novolumes, | ||||
| 			novolumes, | ||||
| 			newClaimArray("claim11-9", "uid11-9", "1Gi", "", v1.ClaimPending, &classGold), | ||||
| 			newClaimArray("claim11-9", "uid11-9", "1Gi", "", v1.ClaimPending, &classGold, annStorageProvisioner), | ||||
| 			newClaimArray("claim11-9", "uid11-9", "1Gi", "", v1.ClaimPending, &classGold, pvutil.AnnStorageProvisioner), | ||||
| 			[]string{"Warning ProvisioningFailed"}, | ||||
| 			[]pvtesting.ReactorError{ | ||||
| 				// Inject error to five kubeclient.PersistentVolumes.Create() | ||||
| @@ -249,7 +250,7 @@ func TestProvisionSync(t *testing.T) { | ||||
| 			novolumes, | ||||
| 			novolumes, | ||||
| 			newClaimArray("claim11-10", "uid11-10", "1Gi", "", v1.ClaimPending, &classGold), | ||||
| 			newClaimArray("claim11-10", "uid11-10", "1Gi", "", v1.ClaimPending, &classGold, annStorageProvisioner), | ||||
| 			newClaimArray("claim11-10", "uid11-10", "1Gi", "", v1.ClaimPending, &classGold, pvutil.AnnStorageProvisioner), | ||||
| 			[]string{"Warning ProvisioningFailed", "Warning ProvisioningCleanupFailed"}, | ||||
| 			[]pvtesting.ReactorError{ | ||||
| 				// Inject error to five kubeclient.PersistentVolumes.Create() | ||||
| @@ -270,7 +271,7 @@ func TestProvisionSync(t *testing.T) { | ||||
| 			novolumes, | ||||
| 			novolumes, | ||||
| 			newClaimArray("claim11-11", "uid11-11", "1Gi", "", v1.ClaimPending, &classGold), | ||||
| 			newClaimArray("claim11-11", "uid11-11", "1Gi", "", v1.ClaimPending, &classGold, annStorageProvisioner), | ||||
| 			newClaimArray("claim11-11", "uid11-11", "1Gi", "", v1.ClaimPending, &classGold, pvutil.AnnStorageProvisioner), | ||||
| 			[]string{"Warning ProvisioningFailed", "Warning ProvisioningCleanupFailed"}, | ||||
| 			[]pvtesting.ReactorError{ | ||||
| 				// Inject error to five kubeclient.PersistentVolumes.Create() | ||||
| @@ -300,7 +301,7 @@ func TestProvisionSync(t *testing.T) { | ||||
| 			novolumes, | ||||
| 			novolumes, | ||||
| 			newClaimArray("claim11-12", "uid11-12", "1Gi", "", v1.ClaimPending, &classGold), | ||||
| 			newClaimArray("claim11-12", "uid11-12", "1Gi", "", v1.ClaimPending, &classGold, annStorageProvisioner), | ||||
| 			newClaimArray("claim11-12", "uid11-12", "1Gi", "", v1.ClaimPending, &classGold, pvutil.AnnStorageProvisioner), | ||||
| 			[]string{"Warning ProvisioningFailed"}, | ||||
| 			[]pvtesting.ReactorError{ | ||||
| 				// Inject error to five kubeclient.PersistentVolumes.Create() | ||||
| @@ -325,10 +326,10 @@ func TestProvisionSync(t *testing.T) { | ||||
| 			// Provision a volume (with non-default class) | ||||
| 			"11-13 - successful provision with storage class 2", | ||||
| 			novolumes, | ||||
| 			newVolumeArray("pvc-uid11-13", "1Gi", "uid11-13", "claim11-13", v1.VolumeBound, v1.PersistentVolumeReclaimDelete, classSilver, annBoundByController, annDynamicallyProvisioned), | ||||
| 			newVolumeArray("pvc-uid11-13", "1Gi", "uid11-13", "claim11-13", v1.VolumeBound, v1.PersistentVolumeReclaimDelete, classSilver, pvutil.AnnBoundByController, pvutil.AnnDynamicallyProvisioned), | ||||
| 			newClaimArray("claim11-13", "uid11-13", "1Gi", "", v1.ClaimPending, &classSilver), | ||||
| 			// Binding will be completed in the next syncClaim | ||||
| 			newClaimArray("claim11-13", "uid11-13", "1Gi", "", v1.ClaimPending, &classSilver, annStorageProvisioner), | ||||
| 			newClaimArray("claim11-13", "uid11-13", "1Gi", "", v1.ClaimPending, &classSilver, pvutil.AnnStorageProvisioner), | ||||
| 			[]string{"Normal ProvisioningSucceeded"}, noerrors, wrapTestWithProvisionCalls([]provisionCall{provision2Success}, testSyncClaim), | ||||
| 		}, | ||||
| 		{ | ||||
| @@ -364,7 +365,7 @@ func TestProvisionSync(t *testing.T) { | ||||
| 			novolumes, | ||||
| 			novolumes, | ||||
| 			newClaimArray("claim11-17", "uid11-17", "1Gi", "", v1.ClaimPending, &classExternal), | ||||
| 			claimWithAnnotation(annStorageProvisioner, "vendor.com/my-volume", | ||||
| 			claimWithAnnotation(pvutil.AnnStorageProvisioner, "vendor.com/my-volume", | ||||
| 				newClaimArray("claim11-17", "uid11-17", "1Gi", "", v1.ClaimPending, &classExternal)), | ||||
| 			[]string{"Normal ExternalProvisioning"}, | ||||
| 			noerrors, wrapTestWithProvisionCalls([]provisionCall{}, testSyncClaim), | ||||
| @@ -394,7 +395,7 @@ func TestProvisionSync(t *testing.T) { | ||||
| 			// end of the test is empty. | ||||
| 			novolumes, | ||||
| 			newClaimArray("claim11-19", "uid11-19", "1Gi", "", v1.ClaimPending, &classGold), | ||||
| 			newClaimArray("claim11-19", "uid11-19", "1Gi", "", v1.ClaimPending, &classGold, annStorageProvisioner), | ||||
| 			newClaimArray("claim11-19", "uid11-19", "1Gi", "", v1.ClaimPending, &classGold, pvutil.AnnStorageProvisioner), | ||||
| 			noevents, | ||||
| 			[]pvtesting.ReactorError{ | ||||
| 				// Inject errors to simulate crashed API server during | ||||
| @@ -415,7 +416,7 @@ func TestProvisionSync(t *testing.T) { | ||||
| 			novolumes, | ||||
| 			novolumes, | ||||
| 			newClaimArray("claim11-20", "uid11-20", "1Gi", "", v1.ClaimPending, &classUnsupportedMountOptions), | ||||
| 			newClaimArray("claim11-20", "uid11-20", "1Gi", "", v1.ClaimPending, &classUnsupportedMountOptions, annStorageProvisioner), | ||||
| 			newClaimArray("claim11-20", "uid11-20", "1Gi", "", v1.ClaimPending, &classUnsupportedMountOptions, pvutil.AnnStorageProvisioner), | ||||
| 			// Expect event to be prefixed with "Mount options" because saving PV will fail anyway | ||||
| 			[]string{"Warning ProvisioningFailed Mount options"}, | ||||
| 			noerrors, wrapTestWithProvisionCalls([]provisionCall{}, testSyncClaim), | ||||
| @@ -426,7 +427,7 @@ func TestProvisionSync(t *testing.T) { | ||||
| 			novolumes, | ||||
| 			novolumes, | ||||
| 			newClaimArray("claim11-21", "uid11-21", "1Gi", "", v1.ClaimPending, &classGold), | ||||
| 			claimWithAnnotation(annStorageProvisioner, "vendor.com/MockCSIPlugin", | ||||
| 			claimWithAnnotation(pvutil.AnnStorageProvisioner, "vendor.com/MockCSIPlugin", | ||||
| 				newClaimArray("claim11-21", "uid11-21", "1Gi", "", v1.ClaimPending, &classGold)), | ||||
| 			[]string{"Normal ExternalProvisioning"}, | ||||
| 			noerrors, wrapTestWithCSIMigrationProvisionCalls(testSyncClaim), | ||||
| @@ -455,9 +456,9 @@ func TestProvisionMultiSync(t *testing.T) { | ||||
| 			// Provision a volume with binding | ||||
| 			"12-1 - successful provision", | ||||
| 			novolumes, | ||||
| 			newVolumeArray("pvc-uid12-1", "1Gi", "uid12-1", "claim12-1", v1.VolumeBound, v1.PersistentVolumeReclaimDelete, classGold, annBoundByController, annDynamicallyProvisioned), | ||||
| 			newVolumeArray("pvc-uid12-1", "1Gi", "uid12-1", "claim12-1", v1.VolumeBound, v1.PersistentVolumeReclaimDelete, classGold, pvutil.AnnBoundByController, pvutil.AnnDynamicallyProvisioned), | ||||
| 			newClaimArray("claim12-1", "uid12-1", "1Gi", "", v1.ClaimPending, &classGold), | ||||
| 			newClaimArray("claim12-1", "uid12-1", "1Gi", "pvc-uid12-1", v1.ClaimBound, &classGold, annBoundByController, annBindCompleted, annStorageProvisioner), | ||||
| 			newClaimArray("claim12-1", "uid12-1", "1Gi", "pvc-uid12-1", v1.ClaimBound, &classGold, pvutil.AnnBoundByController, pvutil.AnnBindCompleted, pvutil.AnnStorageProvisioner), | ||||
| 			noevents, noerrors, wrapTestWithProvisionCalls([]provisionCall{provision1Success}, testSyncClaim), | ||||
| 		}, | ||||
| 	} | ||||
|   | ||||
| @@ -116,39 +116,6 @@ import ( | ||||
| // claims at the same time. The controller must recover from any conflicts | ||||
| // that may arise from these conditions. | ||||
|  | ||||
| // annBindCompleted annotation applies to PVCs. It indicates that the lifecycle | ||||
| // of the PVC has passed through the initial setup. This information changes how | ||||
| // we interpret some observations of the state of the objects. Value of this | ||||
| // annotation does not matter. | ||||
| const annBindCompleted = "pv.kubernetes.io/bind-completed" | ||||
|  | ||||
| // annBoundByController annotation applies to PVs and PVCs. It indicates that | ||||
| // the binding (PV->PVC or PVC->PV) was installed by the controller. The | ||||
| // absence of this annotation means the binding was done by the user (i.e. | ||||
| // pre-bound). Value of this annotation does not matter. | ||||
| // External PV binders must bind PV the same way as PV controller, otherwise PV | ||||
| // controller may not handle it correctly. | ||||
| const annBoundByController = "pv.kubernetes.io/bound-by-controller" | ||||
|  | ||||
| // This annotation is added to a PV that has been dynamically provisioned by | ||||
| // Kubernetes. Its value is name of volume plugin that created the volume. | ||||
| // It serves both user (to show where a PV comes from) and Kubernetes (to | ||||
| // recognize dynamically provisioned PVs in its decisions). | ||||
| const annDynamicallyProvisioned = "pv.kubernetes.io/provisioned-by" | ||||
|  | ||||
| // This annotation is added to a PVC that is supposed to be dynamically | ||||
| // provisioned. Its value is name of volume plugin that is supposed to provision | ||||
| // a volume for this PVC. | ||||
| const annStorageProvisioner = "volume.beta.kubernetes.io/storage-provisioner" | ||||
|  | ||||
| // This annotation is added to a PVC that has been triggered by scheduler to | ||||
| // be dynamically provisioned. Its value is the name of the selected node. | ||||
| const annSelectedNode = "volume.kubernetes.io/selected-node" | ||||
|  | ||||
| // If the provisioner name in a storage class is set to "kubernetes.io/no-provisioner", | ||||
| // then dynamic provisioning is not supported by the storage. | ||||
| const notSupportedProvisioner = "kubernetes.io/no-provisioner" | ||||
|  | ||||
| // CloudVolumeCreatedForClaimNamespaceTag is a name of a tag attached to a real volume in cloud (e.g. AWS EBS or GCE PD) | ||||
| // with namespace of a persistent volume claim used to create this volume. | ||||
| const CloudVolumeCreatedForClaimNamespaceTag = "kubernetes.io/created-for/pvc/namespace" | ||||
| @@ -247,7 +214,7 @@ type PersistentVolumeController struct { | ||||
| func (ctrl *PersistentVolumeController) syncClaim(claim *v1.PersistentVolumeClaim) error { | ||||
| 	klog.V(4).Infof("synchronizing PersistentVolumeClaim[%s]: %s", claimToClaimKey(claim), getClaimStatusForLogging(claim)) | ||||
|  | ||||
| 	if !metav1.HasAnnotation(claim.ObjectMeta, annBindCompleted) { | ||||
| 	if !metav1.HasAnnotation(claim.ObjectMeta, pvutil.AnnBindCompleted) { | ||||
| 		return ctrl.syncUnboundClaim(claim) | ||||
| 	} else { | ||||
| 		return ctrl.syncBoundClaim(claim) | ||||
| @@ -295,9 +262,9 @@ func checkVolumeSatisfyClaim(volume *v1.PersistentVolume, claim *v1.PersistentVo | ||||
| func (ctrl *PersistentVolumeController) isDelayBindingProvisioning(claim *v1.PersistentVolumeClaim) bool { | ||||
| 	// When feature VolumeScheduling enabled, | ||||
| 	// Scheduler signal to the PV controller to start dynamic | ||||
| 	// provisioning by setting the "annSelectedNode" annotation | ||||
| 	// provisioning by setting the "AnnSelectedNode" annotation | ||||
| 	// in the PVC | ||||
| 	_, ok := claim.Annotations[annSelectedNode] | ||||
| 	_, ok := claim.Annotations[pvutil.AnnSelectedNode] | ||||
| 	return ok | ||||
| } | ||||
|  | ||||
| @@ -422,7 +389,7 @@ func (ctrl *PersistentVolumeController) syncUnboundClaim(claim *v1.PersistentVol | ||||
| 			} else { | ||||
| 				// User asked for a PV that is claimed by someone else | ||||
| 				// OBSERVATION: pvc is "Pending", pv is "Bound" | ||||
| 				if !metav1.HasAnnotation(claim.ObjectMeta, annBoundByController) { | ||||
| 				if !metav1.HasAnnotation(claim.ObjectMeta, pvutil.AnnBoundByController) { | ||||
| 					klog.V(4).Infof("synchronizing unbound PersistentVolumeClaim[%s]: volume already bound to different claim by user, will retry later", claimToClaimKey(claim)) | ||||
| 					// User asked for a specific PV, retry later | ||||
| 					if _, err = ctrl.updateClaimStatus(claim, v1.ClaimPending, nil); err != nil { | ||||
| @@ -431,7 +398,7 @@ func (ctrl *PersistentVolumeController) syncUnboundClaim(claim *v1.PersistentVol | ||||
| 					return nil | ||||
| 				} else { | ||||
| 					// This should never happen because someone had to remove | ||||
| 					// annBindCompleted annotation on the claim. | ||||
| 					// AnnBindCompleted annotation on the claim. | ||||
| 					klog.V(4).Infof("synchronizing unbound PersistentVolumeClaim[%s]: volume already bound to different claim %q by controller, THIS SHOULD NEVER HAPPEN", claimToClaimKey(claim), claimrefToClaimKey(volume.Spec.ClaimRef)) | ||||
| 					return fmt.Errorf("Invalid binding of claim %q to volume %q: volume already claimed by %q", claimToClaimKey(claim), claim.Spec.VolumeName, claimrefToClaimKey(volume.Spec.ClaimRef)) | ||||
| 				} | ||||
| @@ -443,7 +410,7 @@ func (ctrl *PersistentVolumeController) syncUnboundClaim(claim *v1.PersistentVol | ||||
| // syncBoundClaim is the main controller method to decide what to do with a | ||||
| // bound claim. | ||||
| func (ctrl *PersistentVolumeController) syncBoundClaim(claim *v1.PersistentVolumeClaim) error { | ||||
| 	// HasAnnotation(pvc, annBindCompleted) | ||||
| 	// HasAnnotation(pvc, pvutil.AnnBindCompleted) | ||||
| 	// This PVC has previously been bound | ||||
| 	// OBSERVATION: pvc is not "Pending" | ||||
| 	// [Unit test set 3] | ||||
| @@ -543,7 +510,7 @@ func (ctrl *PersistentVolumeController) syncVolume(volume *v1.PersistentVolume) | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 		if !found && metav1.HasAnnotation(volume.ObjectMeta, annBoundByController) { | ||||
| 		if !found && metav1.HasAnnotation(volume.ObjectMeta, pvutil.AnnBoundByController) { | ||||
| 			// If PV is bound by external PV binder (e.g. kube-scheduler), it's | ||||
| 			// possible on heavy load that corresponding PVC is not synced to | ||||
| 			// controller local cache yet. So we need to double-check PVC in | ||||
| @@ -622,7 +589,7 @@ func (ctrl *PersistentVolumeController) syncVolume(volume *v1.PersistentVolume) | ||||
| 				return nil | ||||
| 			} | ||||
|  | ||||
| 			if metav1.HasAnnotation(volume.ObjectMeta, annBoundByController) { | ||||
| 			if metav1.HasAnnotation(volume.ObjectMeta, pvutil.AnnBoundByController) { | ||||
| 				// The binding is not completed; let PVC sync handle it | ||||
| 				klog.V(4).Infof("synchronizing PersistentVolume[%s]: volume not bound yet, waiting for syncClaim to fix it", volume.Name) | ||||
| 			} else { | ||||
| @@ -649,7 +616,7 @@ func (ctrl *PersistentVolumeController) syncVolume(volume *v1.PersistentVolume) | ||||
| 			return nil | ||||
| 		} else { | ||||
| 			// Volume is bound to a claim, but the claim is bound elsewhere | ||||
| 			if metav1.HasAnnotation(volume.ObjectMeta, annDynamicallyProvisioned) && volume.Spec.PersistentVolumeReclaimPolicy == v1.PersistentVolumeReclaimDelete { | ||||
| 			if metav1.HasAnnotation(volume.ObjectMeta, pvutil.AnnDynamicallyProvisioned) && volume.Spec.PersistentVolumeReclaimPolicy == v1.PersistentVolumeReclaimDelete { | ||||
| 				// This volume was dynamically provisioned for this claim. The | ||||
| 				// claim got bound elsewhere, and thus this volume is not | ||||
| 				// needed. Delete it. | ||||
| @@ -673,7 +640,7 @@ func (ctrl *PersistentVolumeController) syncVolume(volume *v1.PersistentVolume) | ||||
| 			} else { | ||||
| 				// Volume is bound to a claim, but the claim is bound elsewhere | ||||
| 				// and it's not dynamically provisioned. | ||||
| 				if metav1.HasAnnotation(volume.ObjectMeta, annBoundByController) { | ||||
| 				if metav1.HasAnnotation(volume.ObjectMeta, pvutil.AnnBoundByController) { | ||||
| 					// This is part of the normal operation of the controller; the | ||||
| 					// controller tried to use this volume for a claim but the claim | ||||
| 					// was fulfilled by another volume. We did this; fix it. | ||||
| @@ -908,15 +875,15 @@ func (ctrl *PersistentVolumeController) bindClaimToVolume(claim *v1.PersistentVo | ||||
| 		// Bind the claim to the volume | ||||
| 		claimClone.Spec.VolumeName = volume.Name | ||||
|  | ||||
| 		// Set annBoundByController if it is not set yet | ||||
| 		if !metav1.HasAnnotation(claimClone.ObjectMeta, annBoundByController) { | ||||
| 			metav1.SetMetaDataAnnotation(&claimClone.ObjectMeta, annBoundByController, "yes") | ||||
| 		// Set AnnBoundByController if it is not set yet | ||||
| 		if !metav1.HasAnnotation(claimClone.ObjectMeta, pvutil.AnnBoundByController) { | ||||
| 			metav1.SetMetaDataAnnotation(&claimClone.ObjectMeta, pvutil.AnnBoundByController, "yes") | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// Set annBindCompleted if it is not set yet | ||||
| 	if !metav1.HasAnnotation(claimClone.ObjectMeta, annBindCompleted) { | ||||
| 		metav1.SetMetaDataAnnotation(&claimClone.ObjectMeta, annBindCompleted, "yes") | ||||
| 	// Set AnnBindCompleted if it is not set yet | ||||
| 	if !metav1.HasAnnotation(claimClone.ObjectMeta, pvutil.AnnBindCompleted) { | ||||
| 		metav1.SetMetaDataAnnotation(&claimClone.ObjectMeta, pvutil.AnnBindCompleted, "yes") | ||||
| 		dirty = true | ||||
| 	} | ||||
|  | ||||
| @@ -995,10 +962,10 @@ func (ctrl *PersistentVolumeController) unbindVolume(volume *v1.PersistentVolume | ||||
| 	// Save the PV only when any modification is necessary. | ||||
| 	volumeClone := volume.DeepCopy() | ||||
|  | ||||
| 	if metav1.HasAnnotation(volume.ObjectMeta, annBoundByController) { | ||||
| 	if metav1.HasAnnotation(volume.ObjectMeta, pvutil.AnnBoundByController) { | ||||
| 		// The volume was bound by the controller. | ||||
| 		volumeClone.Spec.ClaimRef = nil | ||||
| 		delete(volumeClone.Annotations, annBoundByController) | ||||
| 		delete(volumeClone.Annotations, pvutil.AnnBoundByController) | ||||
| 		if len(volumeClone.Annotations) == 0 { | ||||
| 			// No annotations look better than empty annotation map (and it's easier | ||||
| 			// to test). | ||||
| @@ -1469,7 +1436,7 @@ func (ctrl *PersistentVolumeController) provisionClaimOperation(claim *v1.Persis | ||||
| 	} | ||||
|  | ||||
| 	var selectedNode *v1.Node = nil | ||||
| 	if nodeName, ok := claim.Annotations[annSelectedNode]; ok { | ||||
| 	if nodeName, ok := claim.Annotations[pvutil.AnnSelectedNode]; ok { | ||||
| 		selectedNode, err = ctrl.NodeLister.Get(nodeName) | ||||
| 		if err != nil { | ||||
| 			strerr := fmt.Sprintf("Failed to get target node: %v", err) | ||||
| @@ -1506,9 +1473,9 @@ func (ctrl *PersistentVolumeController) provisionClaimOperation(claim *v1.Persis | ||||
| 	volume.Status.Phase = v1.VolumeBound | ||||
| 	volume.Spec.StorageClassName = claimClass | ||||
|  | ||||
| 	// Add annBoundByController (used in deleting the volume) | ||||
| 	metav1.SetMetaDataAnnotation(&volume.ObjectMeta, annBoundByController, "yes") | ||||
| 	metav1.SetMetaDataAnnotation(&volume.ObjectMeta, annDynamicallyProvisioned, plugin.GetPluginName()) | ||||
| 	// Add AnnBoundByController (used in deleting the volume) | ||||
| 	metav1.SetMetaDataAnnotation(&volume.ObjectMeta, pvutil.AnnBoundByController, "yes") | ||||
| 	metav1.SetMetaDataAnnotation(&volume.ObjectMeta, pvutil.AnnDynamicallyProvisioned, plugin.GetPluginName()) | ||||
|  | ||||
| 	// Try to create the PV object several times | ||||
| 	for i := 0; i < ctrl.createProvisionedPVRetryCount; i++ { | ||||
| @@ -1581,9 +1548,9 @@ func (ctrl *PersistentVolumeController) provisionClaimOperation(claim *v1.Persis | ||||
| } | ||||
|  | ||||
| // rescheduleProvisioning signal back to the scheduler to retry dynamic provisioning | ||||
| // by removing the annSelectedNode annotation | ||||
| // by removing the AnnSelectedNode annotation | ||||
| func (ctrl *PersistentVolumeController) rescheduleProvisioning(claim *v1.PersistentVolumeClaim) { | ||||
| 	if _, ok := claim.Annotations[annSelectedNode]; !ok { | ||||
| 	if _, ok := claim.Annotations[pvutil.AnnSelectedNode]; !ok { | ||||
| 		// Provisioning not triggered by the scheduler, skip | ||||
| 		return | ||||
| 	} | ||||
| @@ -1591,10 +1558,10 @@ func (ctrl *PersistentVolumeController) rescheduleProvisioning(claim *v1.Persist | ||||
| 	// The claim from method args can be pointing to watcher cache. We must not | ||||
| 	// modify these, therefore create a copy. | ||||
| 	newClaim := claim.DeepCopy() | ||||
| 	delete(newClaim.Annotations, annSelectedNode) | ||||
| 	delete(newClaim.Annotations, pvutil.AnnSelectedNode) | ||||
| 	// Try to update the PVC object | ||||
| 	if _, err := ctrl.kubeClient.CoreV1().PersistentVolumeClaims(newClaim.Namespace).Update(newClaim); err != nil { | ||||
| 		klog.V(4).Infof("Failed to delete annotation 'annSelectedNode' for PersistentVolumeClaim %q: %v", claimToClaimKey(newClaim), err) | ||||
| 		klog.V(4).Infof("Failed to delete annotation 'pvutil.AnnSelectedNode' for PersistentVolumeClaim %q: %v", claimToClaimKey(newClaim), err) | ||||
| 		return | ||||
| 	} | ||||
| 	if _, err := ctrl.storeClaimUpdate(newClaim); err != nil { | ||||
| @@ -1669,8 +1636,8 @@ func (ctrl *PersistentVolumeController) findProvisionablePlugin(claim *v1.Persis | ||||
| func (ctrl *PersistentVolumeController) findDeletablePlugin(volume *v1.PersistentVolume) (vol.DeletableVolumePlugin, error) { | ||||
| 	// Find a plugin. Try to find the same plugin that provisioned the volume | ||||
| 	var plugin vol.DeletableVolumePlugin | ||||
| 	if metav1.HasAnnotation(volume.ObjectMeta, annDynamicallyProvisioned) { | ||||
| 		provisionPluginName := volume.Annotations[annDynamicallyProvisioned] | ||||
| 	if metav1.HasAnnotation(volume.ObjectMeta, pvutil.AnnDynamicallyProvisioned) { | ||||
| 		provisionPluginName := volume.Annotations[pvutil.AnnDynamicallyProvisioned] | ||||
| 		if provisionPluginName != "" { | ||||
| 			plugin, err := ctrl.volumePluginMgr.FindDeletablePluginByName(provisionPluginName) | ||||
| 			if err != nil { | ||||
|   | ||||
| @@ -40,6 +40,7 @@ import ( | ||||
| 	cloudprovider "k8s.io/cloud-provider" | ||||
| 	"k8s.io/kubernetes/pkg/controller" | ||||
| 	"k8s.io/kubernetes/pkg/controller/volume/persistentvolume/metrics" | ||||
| 	pvutil "k8s.io/kubernetes/pkg/controller/volume/persistentvolume/util" | ||||
| 	"k8s.io/kubernetes/pkg/util/goroutinemap" | ||||
| 	vol "k8s.io/kubernetes/pkg/volume" | ||||
|  | ||||
| @@ -426,9 +427,9 @@ func (ctrl *PersistentVolumeController) resync() { | ||||
| } | ||||
|  | ||||
| // setClaimProvisioner saves | ||||
| // claim.Annotations[annStorageProvisioner] = class.Provisioner | ||||
| // claim.Annotations[pvutil.AnnStorageProvisioner] = class.Provisioner | ||||
| func (ctrl *PersistentVolumeController) setClaimProvisioner(claim *v1.PersistentVolumeClaim, provisionerName string) (*v1.PersistentVolumeClaim, error) { | ||||
| 	if val, ok := claim.Annotations[annStorageProvisioner]; ok && val == provisionerName { | ||||
| 	if val, ok := claim.Annotations[pvutil.AnnStorageProvisioner]; ok && val == provisionerName { | ||||
| 		// annotation is already set, nothing to do | ||||
| 		return claim, nil | ||||
| 	} | ||||
| @@ -436,7 +437,7 @@ func (ctrl *PersistentVolumeController) setClaimProvisioner(claim *v1.Persistent | ||||
| 	// The volume from method args can be pointing to watcher cache. We must not | ||||
| 	// modify these, therefore create a copy. | ||||
| 	claimClone := claim.DeepCopy() | ||||
| 	metav1.SetMetaDataAnnotation(&claimClone.ObjectMeta, annStorageProvisioner, provisionerName) | ||||
| 	metav1.SetMetaDataAnnotation(&claimClone.ObjectMeta, pvutil.AnnStorageProvisioner, provisionerName) | ||||
| 	newClaim, err := ctrl.kubeClient.CoreV1().PersistentVolumeClaims(claim.Namespace).Update(claimClone) | ||||
| 	if err != nil { | ||||
| 		return newClaim, err | ||||
| @@ -451,14 +452,14 @@ func (ctrl *PersistentVolumeController) setClaimProvisioner(claim *v1.Persistent | ||||
| // Stateless functions | ||||
|  | ||||
| func getClaimStatusForLogging(claim *v1.PersistentVolumeClaim) string { | ||||
| 	bound := metav1.HasAnnotation(claim.ObjectMeta, annBindCompleted) | ||||
| 	boundByController := metav1.HasAnnotation(claim.ObjectMeta, annBoundByController) | ||||
| 	bound := metav1.HasAnnotation(claim.ObjectMeta, pvutil.AnnBindCompleted) | ||||
| 	boundByController := metav1.HasAnnotation(claim.ObjectMeta, pvutil.AnnBoundByController) | ||||
|  | ||||
| 	return fmt.Sprintf("phase: %s, bound to: %q, bindCompleted: %v, boundByController: %v", claim.Status.Phase, claim.Spec.VolumeName, bound, boundByController) | ||||
| } | ||||
|  | ||||
| func getVolumeStatusForLogging(volume *v1.PersistentVolume) string { | ||||
| 	boundByController := metav1.HasAnnotation(volume.ObjectMeta, annBoundByController) | ||||
| 	boundByController := metav1.HasAnnotation(volume.ObjectMeta, pvutil.AnnBoundByController) | ||||
| 	claimName := "" | ||||
| 	if volume.Spec.ClaimRef != nil { | ||||
| 		claimName = fmt.Sprintf("%s/%s (uid: %s)", volume.Spec.ClaimRef.Namespace, volume.Spec.ClaimRef.Name, volume.Spec.ClaimRef.UID) | ||||
|   | ||||
| @@ -31,6 +31,7 @@ import ( | ||||
| 	"k8s.io/klog" | ||||
| 	"k8s.io/kubernetes/pkg/controller" | ||||
| 	pvtesting "k8s.io/kubernetes/pkg/controller/volume/persistentvolume/testing" | ||||
| 	pvutil "k8s.io/kubernetes/pkg/controller/volume/persistentvolume/util" | ||||
| ) | ||||
|  | ||||
| var ( | ||||
| @@ -56,9 +57,9 @@ func TestControllerSync(t *testing.T) { | ||||
| 			// addClaim gets a new claim. Check it's bound to a volume. | ||||
| 			"5-2 - complete bind", | ||||
| 			newVolumeArray("volume5-2", "1Gi", "", "", v1.VolumeAvailable, v1.PersistentVolumeReclaimRetain, classEmpty), | ||||
| 			newVolumeArray("volume5-2", "1Gi", "uid5-2", "claim5-2", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController), | ||||
| 			newVolumeArray("volume5-2", "1Gi", "uid5-2", "claim5-2", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController), | ||||
| 			noclaims, /* added in testAddClaim5_2 */ | ||||
| 			newClaimArray("claim5-2", "uid5-2", "1Gi", "volume5-2", v1.ClaimBound, nil, annBoundByController, annBindCompleted), | ||||
| 			newClaimArray("claim5-2", "uid5-2", "1Gi", "volume5-2", v1.ClaimBound, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted), | ||||
| 			noevents, noerrors, | ||||
| 			// Custom test function that generates an add event | ||||
| 			func(ctrl *PersistentVolumeController, reactor *pvtesting.VolumeReactor, test controllerTest) error { | ||||
| @@ -70,9 +71,9 @@ func TestControllerSync(t *testing.T) { | ||||
| 		{ | ||||
| 			// deleteClaim with a bound claim makes bound volume released. | ||||
| 			"5-3 - delete claim", | ||||
| 			newVolumeArray("volume5-3", "10Gi", "uid5-3", "claim5-3", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController), | ||||
| 			newVolumeArray("volume5-3", "10Gi", "uid5-3", "claim5-3", v1.VolumeReleased, v1.PersistentVolumeReclaimRetain, classEmpty, annBoundByController), | ||||
| 			newClaimArray("claim5-3", "uid5-3", "1Gi", "volume5-3", v1.ClaimBound, nil, annBoundByController, annBindCompleted), | ||||
| 			newVolumeArray("volume5-3", "10Gi", "uid5-3", "claim5-3", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController), | ||||
| 			newVolumeArray("volume5-3", "10Gi", "uid5-3", "claim5-3", v1.VolumeReleased, v1.PersistentVolumeReclaimRetain, classEmpty, pvutil.AnnBoundByController), | ||||
| 			newClaimArray("claim5-3", "uid5-3", "1Gi", "volume5-3", v1.ClaimBound, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted), | ||||
| 			noclaims, | ||||
| 			noevents, noerrors, | ||||
| 			// Custom test function that generates a delete event | ||||
| @@ -88,8 +89,8 @@ func TestControllerSync(t *testing.T) { | ||||
| 			"5-4 - delete volume", | ||||
| 			newVolumeArray("volume5-4", "1Gi", "uid5-4", "claim5-4", v1.VolumeBound, v1.PersistentVolumeReclaimRetain, classEmpty), | ||||
| 			novolumes, | ||||
| 			newClaimArray("claim5-4", "uid5-4", "1Gi", "volume5-4", v1.ClaimBound, nil, annBoundByController, annBindCompleted), | ||||
| 			newClaimArray("claim5-4", "uid5-4", "1Gi", "volume5-4", v1.ClaimLost, nil, annBoundByController, annBindCompleted), | ||||
| 			newClaimArray("claim5-4", "uid5-4", "1Gi", "volume5-4", v1.ClaimBound, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted), | ||||
| 			newClaimArray("claim5-4", "uid5-4", "1Gi", "volume5-4", v1.ClaimLost, nil, pvutil.AnnBoundByController, pvutil.AnnBindCompleted), | ||||
| 			[]string{"Warning ClaimLost"}, noerrors, | ||||
| 			// Custom test function that generates a delete event | ||||
| 			func(ctrl *PersistentVolumeController, reactor *pvtesting.VolumeReactor, test controllerTest) error { | ||||
| @@ -246,7 +247,7 @@ func makePVCClass(scName *string, hasSelectNodeAnno bool) *v1.PersistentVolumeCl | ||||
| 	} | ||||
|  | ||||
| 	if hasSelectNodeAnno { | ||||
| 		claim.Annotations[annSelectedNode] = "node-name" | ||||
| 		claim.Annotations[pvutil.AnnSelectedNode] = "node-name" | ||||
| 	} | ||||
|  | ||||
| 	return claim | ||||
|   | ||||
| @@ -24,6 +24,7 @@ import ( | ||||
| 	storage "k8s.io/api/storage/v1" | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| 	pvtesting "k8s.io/kubernetes/pkg/controller/volume/persistentvolume/testing" | ||||
| 	pvutil "k8s.io/kubernetes/pkg/controller/volume/persistentvolume/util" | ||||
| ) | ||||
|  | ||||
| // Test single call to syncVolume, expecting recycling to happen. | ||||
| @@ -73,7 +74,7 @@ func TestRecycleSync(t *testing.T) { | ||||
| 		{ | ||||
| 			// recycle volume bound by controller | ||||
| 			"6-1 - successful recycle", | ||||
| 			newVolumeArray("volume6-1", "1Gi", "uid6-1", "claim6-1", v1.VolumeBound, v1.PersistentVolumeReclaimRecycle, classEmpty, annBoundByController), | ||||
| 			newVolumeArray("volume6-1", "1Gi", "uid6-1", "claim6-1", v1.VolumeBound, v1.PersistentVolumeReclaimRecycle, classEmpty, pvutil.AnnBoundByController), | ||||
| 			newVolumeArray("volume6-1", "1Gi", "", "", v1.VolumeAvailable, v1.PersistentVolumeReclaimRecycle, classEmpty), | ||||
| 			noclaims, | ||||
| 			noclaims, | ||||
| @@ -141,7 +142,7 @@ func TestRecycleSync(t *testing.T) { | ||||
| 			// at the time new doRecycle() starts. This simulates "volume no | ||||
| 			// longer needs recycling, skipping". | ||||
| 			"6-7 - volume is deleted before recycling", | ||||
| 			newVolumeArray("volume6-7", "1Gi", "uid6-7", "claim6-7", v1.VolumeBound, v1.PersistentVolumeReclaimRecycle, classEmpty, annBoundByController), | ||||
| 			newVolumeArray("volume6-7", "1Gi", "uid6-7", "claim6-7", v1.VolumeBound, v1.PersistentVolumeReclaimRecycle, classEmpty, pvutil.AnnBoundByController), | ||||
| 			newVolumeArray("volume6-7", "1Gi", "", "", v1.VolumeAvailable, v1.PersistentVolumeReclaimRecycle, classEmpty), | ||||
| 			noclaims, | ||||
| 			noclaims, | ||||
| @@ -192,8 +193,8 @@ func TestRecycleSync(t *testing.T) { | ||||
| 		{ | ||||
| 			// volume is used by a running pod - failure expected | ||||
| 			"6-11 - used by running pod", | ||||
| 			newVolumeArray("volume6-11", "1Gi", "uid6-11", "runningClaim", v1.VolumeBound, v1.PersistentVolumeReclaimRecycle, classEmpty, annBoundByController), | ||||
| 			newVolumeArray("volume6-11", "1Gi", "uid6-11", "runningClaim", v1.VolumeReleased, v1.PersistentVolumeReclaimRecycle, classEmpty, annBoundByController), | ||||
| 			newVolumeArray("volume6-11", "1Gi", "uid6-11", "runningClaim", v1.VolumeBound, v1.PersistentVolumeReclaimRecycle, classEmpty, pvutil.AnnBoundByController), | ||||
| 			newVolumeArray("volume6-11", "1Gi", "uid6-11", "runningClaim", v1.VolumeReleased, v1.PersistentVolumeReclaimRecycle, classEmpty, pvutil.AnnBoundByController), | ||||
| 			noclaims, | ||||
| 			noclaims, | ||||
| 			[]string{"Normal VolumeFailedRecycle"}, noerrors, testSyncVolume, | ||||
| @@ -201,8 +202,8 @@ func TestRecycleSync(t *testing.T) { | ||||
| 		{ | ||||
| 			// volume is used by a pending pod - failure expected | ||||
| 			"6-12 - used by pending pod", | ||||
| 			newVolumeArray("volume6-12", "1Gi", "uid6-12", "pendingClaim", v1.VolumeBound, v1.PersistentVolumeReclaimRecycle, classEmpty, annBoundByController), | ||||
| 			newVolumeArray("volume6-12", "1Gi", "uid6-12", "pendingClaim", v1.VolumeReleased, v1.PersistentVolumeReclaimRecycle, classEmpty, annBoundByController), | ||||
| 			newVolumeArray("volume6-12", "1Gi", "uid6-12", "pendingClaim", v1.VolumeBound, v1.PersistentVolumeReclaimRecycle, classEmpty, pvutil.AnnBoundByController), | ||||
| 			newVolumeArray("volume6-12", "1Gi", "uid6-12", "pendingClaim", v1.VolumeReleased, v1.PersistentVolumeReclaimRecycle, classEmpty, pvutil.AnnBoundByController), | ||||
| 			noclaims, | ||||
| 			noclaims, | ||||
| 			[]string{"Normal VolumeFailedRecycle"}, noerrors, testSyncVolume, | ||||
| @@ -210,7 +211,7 @@ func TestRecycleSync(t *testing.T) { | ||||
| 		{ | ||||
| 			// volume is used by a completed pod - recycle succeeds | ||||
| 			"6-13 - used by completed pod", | ||||
| 			newVolumeArray("volume6-13", "1Gi", "uid6-13", "completedClaim", v1.VolumeBound, v1.PersistentVolumeReclaimRecycle, classEmpty, annBoundByController), | ||||
| 			newVolumeArray("volume6-13", "1Gi", "uid6-13", "completedClaim", v1.VolumeBound, v1.PersistentVolumeReclaimRecycle, classEmpty, pvutil.AnnBoundByController), | ||||
| 			newVolumeArray("volume6-13", "1Gi", "", "", v1.VolumeAvailable, v1.PersistentVolumeReclaimRecycle, classEmpty), | ||||
| 			noclaims, | ||||
| 			noclaims, | ||||
| @@ -222,7 +223,7 @@ func TestRecycleSync(t *testing.T) { | ||||
| 		{ | ||||
| 			// volume is used by a completed pod, pod using claim with the same name bound to different pv is running, should recycle | ||||
| 			"6-14 - seemingly used by running pod", | ||||
| 			newVolumeArray("volume6-14", "1Gi", "uid6-14", "completedClaim", v1.VolumeBound, v1.PersistentVolumeReclaimRecycle, classEmpty, annBoundByController), | ||||
| 			newVolumeArray("volume6-14", "1Gi", "uid6-14", "completedClaim", v1.VolumeBound, v1.PersistentVolumeReclaimRecycle, classEmpty, pvutil.AnnBoundByController), | ||||
| 			newVolumeArray("volume6-14", "1Gi", "", "", v1.VolumeAvailable, v1.PersistentVolumeReclaimRecycle, classEmpty), | ||||
| 			newClaimArray("completedClaim", "uid6-14-x", "10Gi", "", v1.ClaimBound, nil), | ||||
| 			newClaimArray("completedClaim", "uid6-14-x", "10Gi", "", v1.ClaimBound, nil), | ||||
|   | ||||
| @@ -56,6 +56,17 @@ const ( | ||||
| 	// in storage class to indicate dynamic provisioning is not supported by | ||||
| 	// the storage. | ||||
| 	NotSupportedProvisioner = "kubernetes.io/no-provisioner" | ||||
|  | ||||
| 	// AnnDynamicallyProvisioned annotation is added to a PV that has been dynamically provisioned by | ||||
| 	// Kubernetes. Its value is name of volume plugin that created the volume. | ||||
| 	// It serves both user (to show where a PV comes from) and Kubernetes (to | ||||
| 	// recognize dynamically provisioned PVs in its decisions). | ||||
| 	AnnDynamicallyProvisioned = "pv.kubernetes.io/provisioned-by" | ||||
|  | ||||
| 	// AnnStorageProvisioner annotation is added to a PVC that is supposed to be dynamically | ||||
| 	// provisioned. Its value is name of volume plugin that is supposed to provision | ||||
| 	// a volume for this PVC. | ||||
| 	AnnStorageProvisioner = "volume.beta.kubernetes.io/storage-provisioner" | ||||
| ) | ||||
|  | ||||
| // IsDelayBindingMode checks if claim is in delay binding mode. | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Kubernetes Prow Robot
					Kubernetes Prow Robot