|  |  | @@ -42,13 +42,18 @@ import ( | 
			
		
	
		
		
			
				
					
					|  |  |  | 	uexec "k8s.io/utils/exec" |  |  |  | 	uexec "k8s.io/utils/exec" | 
			
		
	
		
		
			
				
					
					|  |  |  | ) |  |  |  | ) | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | // KubeletOpt type definition | 
			
		
	
		
		
			
				
					
					|  |  |  | type KubeletOpt string |  |  |  | type KubeletOpt string | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | const ( |  |  |  | const ( | 
			
		
	
		
		
			
				
					
					|  |  |  | 	NodeStateTimeout            = 1 * time.Minute |  |  |  | 	// NodeStateTimeout defines Timeout | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 	KStart           KubeletOpt = "start" |  |  |  | 	NodeStateTimeout = 1 * time.Minute | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 	KStop            KubeletOpt = "stop" |  |  |  | 	// KStart defines start value | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 	KRestart         KubeletOpt = "restart" |  |  |  | 	KStart KubeletOpt = "start" | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 	// KStop defines stop value | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 	KStop KubeletOpt = "stop" | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 	// KRestart defines restart value | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 	KRestart KubeletOpt = "restart" | 
			
		
	
		
		
			
				
					
					|  |  |  | ) |  |  |  | ) | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | const ( |  |  |  | const ( | 
			
		
	
	
		
		
			
				
					
					|  |  | @@ -207,7 +212,7 @@ func TestKubeletRestartsAndRestoresMount(c clientset.Interface, f *framework.Fra | 
			
		
	
		
		
			
				
					
					|  |  |  | 	e2elog.Logf("Volume mount detected on pod %s and written file %s is readable post-restart.", clientPod.Name, file) |  |  |  | 	e2elog.Logf("Volume mount detected on pod %s and written file %s is readable post-restart.", clientPod.Name, file) | 
			
		
	
		
		
			
				
					
					|  |  |  | } |  |  |  | } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | // TestVolumeUnmountsFromDeletedPod tests that a volume unmounts if the client pod was deleted while the kubelet was down. |  |  |  | // TestVolumeUnmountsFromDeletedPodWithForceOption tests that a volume unmounts if the client pod was deleted while the kubelet was down. | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | // forceDelete is true indicating whether the pod is forcefully deleted. |  |  |  | // forceDelete is true indicating whether the pod is forcefully deleted. | 
			
		
	
		
		
			
				
					
					|  |  |  | func TestVolumeUnmountsFromDeletedPodWithForceOption(c clientset.Interface, f *framework.Framework, clientPod *v1.Pod, forceDelete bool, checkSubpath bool) { |  |  |  | func TestVolumeUnmountsFromDeletedPodWithForceOption(c clientset.Interface, f *framework.Framework, clientPod *v1.Pod, forceDelete bool, checkSubpath bool) { | 
			
		
	
		
		
			
				
					
					|  |  |  | 	nodeIP, err := framework.GetHostExternalAddress(c, clientPod) |  |  |  | 	nodeIP, err := framework.GetHostExternalAddress(c, clientPod) | 
			
		
	
	
		
		
			
				
					
					|  |  | @@ -278,7 +283,7 @@ func TestVolumeUnmountsFromDeletedPod(c clientset.Interface, f *framework.Framew | 
			
		
	
		
		
			
				
					
					|  |  |  | 	TestVolumeUnmountsFromDeletedPodWithForceOption(c, f, clientPod, false, false) |  |  |  | 	TestVolumeUnmountsFromDeletedPodWithForceOption(c, f, clientPod, false, false) | 
			
		
	
		
		
			
				
					
					|  |  |  | } |  |  |  | } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | // TestVolumeUnmountsFromFoceDeletedPod tests that a volume unmounts if the client pod was forcefully deleted while the kubelet was down. |  |  |  | // TestVolumeUnmountsFromForceDeletedPod tests that a volume unmounts if the client pod was forcefully deleted while the kubelet was down. | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | func TestVolumeUnmountsFromForceDeletedPod(c clientset.Interface, f *framework.Framework, clientPod *v1.Pod) { |  |  |  | func TestVolumeUnmountsFromForceDeletedPod(c clientset.Interface, f *framework.Framework, clientPod *v1.Pod) { | 
			
		
	
		
		
			
				
					
					|  |  |  | 	TestVolumeUnmountsFromDeletedPodWithForceOption(c, f, clientPod, true, false) |  |  |  | 	TestVolumeUnmountsFromDeletedPodWithForceOption(c, f, clientPod, true, false) | 
			
		
	
		
		
			
				
					
					|  |  |  | } |  |  |  | } | 
			
		
	
	
		
		
			
				
					
					|  |  | @@ -330,6 +335,7 @@ func RunInPodWithVolume(c clientset.Interface, ns, claimName, command string) { | 
			
		
	
		
		
			
				
					
					|  |  |  | 	framework.ExpectNoError(e2epod.WaitForPodSuccessInNamespaceSlow(c, pod.Name, pod.Namespace)) |  |  |  | 	framework.ExpectNoError(e2epod.WaitForPodSuccessInNamespaceSlow(c, pod.Name, pod.Namespace)) | 
			
		
	
		
		
			
				
					
					|  |  |  | } |  |  |  | } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | // StartExternalProvisioner create external provisioner pod | 
			
		
	
		
		
			
				
					
					|  |  |  | func StartExternalProvisioner(c clientset.Interface, ns string, externalPluginName string) *v1.Pod { |  |  |  | func StartExternalProvisioner(c clientset.Interface, ns string, externalPluginName string) *v1.Pod { | 
			
		
	
		
		
			
				
					
					|  |  |  | 	podClient := c.CoreV1().Pods(ns) |  |  |  | 	podClient := c.CoreV1().Pods(ns) | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |  | 
			
		
	
	
		
		
			
				
					
					|  |  | @@ -403,6 +409,7 @@ func StartExternalProvisioner(c clientset.Interface, ns string, externalPluginNa | 
			
		
	
		
		
			
				
					
					|  |  |  | 	return pod |  |  |  | 	return pod | 
			
		
	
		
		
			
				
					
					|  |  |  | } |  |  |  | } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | // PrivilegedTestPSPClusterRoleBinding test Pod Security Policy Role bindings | 
			
		
	
		
		
			
				
					
					|  |  |  | func PrivilegedTestPSPClusterRoleBinding(client clientset.Interface, |  |  |  | func PrivilegedTestPSPClusterRoleBinding(client clientset.Interface, | 
			
		
	
		
		
			
				
					
					|  |  |  | 	namespace string, |  |  |  | 	namespace string, | 
			
		
	
		
		
			
				
					
					|  |  |  | 	teardown bool, |  |  |  | 	teardown bool, | 
			
		
	
	
		
		
			
				
					
					|  |  | @@ -450,6 +457,7 @@ func PrivilegedTestPSPClusterRoleBinding(client clientset.Interface, | 
			
		
	
		
		
			
				
					
					|  |  |  | 	} |  |  |  | 	} | 
			
		
	
		
		
			
				
					
					|  |  |  | } |  |  |  | } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | // CheckVolumeModeOfPath check mode of volume | 
			
		
	
		
		
			
				
					
					|  |  |  | func CheckVolumeModeOfPath(pod *v1.Pod, volMode v1.PersistentVolumeMode, path string) { |  |  |  | func CheckVolumeModeOfPath(pod *v1.Pod, volMode v1.PersistentVolumeMode, path string) { | 
			
		
	
		
		
			
				
					
					|  |  |  | 	if volMode == v1.PersistentVolumeBlock { |  |  |  | 	if volMode == v1.PersistentVolumeBlock { | 
			
		
	
		
		
			
				
					
					|  |  |  | 		// Check if block exists |  |  |  | 		// Check if block exists | 
			
		
	
	
		
		
			
				
					
					|  |  | @@ -466,6 +474,7 @@ func CheckVolumeModeOfPath(pod *v1.Pod, volMode v1.PersistentVolumeMode, path st | 
			
		
	
		
		
			
				
					
					|  |  |  | 	} |  |  |  | 	} | 
			
		
	
		
		
			
				
					
					|  |  |  | } |  |  |  | } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | // CheckReadWriteToPath check that path can b e read and written | 
			
		
	
		
		
			
				
					
					|  |  |  | func CheckReadWriteToPath(pod *v1.Pod, volMode v1.PersistentVolumeMode, path string) { |  |  |  | func CheckReadWriteToPath(pod *v1.Pod, volMode v1.PersistentVolumeMode, path string) { | 
			
		
	
		
		
			
				
					
					|  |  |  | 	if volMode == v1.PersistentVolumeBlock { |  |  |  | 	if volMode == v1.PersistentVolumeBlock { | 
			
		
	
		
		
			
				
					
					|  |  |  | 		// random -> file1 |  |  |  | 		// random -> file1 | 
			
		
	
	
		
		
			
				
					
					|  |  | @@ -492,6 +501,7 @@ func CheckReadWriteToPath(pod *v1.Pod, volMode v1.PersistentVolumeMode, path str | 
			
		
	
		
		
			
				
					
					|  |  |  | 	} |  |  |  | 	} | 
			
		
	
		
		
			
				
					
					|  |  |  | } |  |  |  | } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | // genBinDataFromSeed generate binData with random seed | 
			
		
	
		
		
			
				
					
					|  |  |  | func genBinDataFromSeed(len int, seed int64) []byte { |  |  |  | func genBinDataFromSeed(len int, seed int64) []byte { | 
			
		
	
		
		
			
				
					
					|  |  |  | 	binData := make([]byte, len) |  |  |  | 	binData := make([]byte, len) | 
			
		
	
		
		
			
				
					
					|  |  |  | 	rand.Seed(seed) |  |  |  | 	rand.Seed(seed) | 
			
		
	
	
		
		
			
				
					
					|  |  | @@ -504,6 +514,7 @@ func genBinDataFromSeed(len int, seed int64) []byte { | 
			
		
	
		
		
			
				
					
					|  |  |  | 	return binData |  |  |  | 	return binData | 
			
		
	
		
		
			
				
					
					|  |  |  | } |  |  |  | } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | // CheckReadFromPath validate that file can be properly read. | 
			
		
	
		
		
			
				
					
					|  |  |  | func CheckReadFromPath(pod *v1.Pod, volMode v1.PersistentVolumeMode, path string, len int, seed int64) { |  |  |  | func CheckReadFromPath(pod *v1.Pod, volMode v1.PersistentVolumeMode, path string, len int, seed int64) { | 
			
		
	
		
		
			
				
					
					|  |  |  | 	var pathForVolMode string |  |  |  | 	var pathForVolMode string | 
			
		
	
		
		
			
				
					
					|  |  |  | 	if volMode == v1.PersistentVolumeBlock { |  |  |  | 	if volMode == v1.PersistentVolumeBlock { | 
			
		
	
	
		
		
			
				
					
					|  |  | @@ -518,6 +529,7 @@ func CheckReadFromPath(pod *v1.Pod, volMode v1.PersistentVolumeMode, path string | 
			
		
	
		
		
			
				
					
					|  |  |  | 	VerifyExecInPodSucceed(pod, fmt.Sprintf("dd if=%s bs=%d count=1 | sha256sum | grep -Fq %x", pathForVolMode, len, sum)) |  |  |  | 	VerifyExecInPodSucceed(pod, fmt.Sprintf("dd if=%s bs=%d count=1 | sha256sum | grep -Fq %x", pathForVolMode, len, sum)) | 
			
		
	
		
		
			
				
					
					|  |  |  | } |  |  |  | } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | // CheckWriteToPath that file can be properly written. | 
			
		
	
		
		
			
				
					
					|  |  |  | func CheckWriteToPath(pod *v1.Pod, volMode v1.PersistentVolumeMode, path string, len int, seed int64) { |  |  |  | func CheckWriteToPath(pod *v1.Pod, volMode v1.PersistentVolumeMode, path string, len int, seed int64) { | 
			
		
	
		
		
			
				
					
					|  |  |  | 	var pathForVolMode string |  |  |  | 	var pathForVolMode string | 
			
		
	
		
		
			
				
					
					|  |  |  | 	if volMode == v1.PersistentVolumeBlock { |  |  |  | 	if volMode == v1.PersistentVolumeBlock { | 
			
		
	
	
		
		
			
				
					
					|  |  |   |