Merge pull request #124883 from ardaguclu/create-cronjobs-role-fix
kubectl create cronjobs: Manually set OwnerReferences
This commit is contained in:
		| @@ -35,6 +35,7 @@ import ( | ||||
| 	"k8s.io/kubectl/pkg/util" | ||||
| 	"k8s.io/kubectl/pkg/util/i18n" | ||||
| 	"k8s.io/kubectl/pkg/util/templates" | ||||
| 	"k8s.io/utils/ptr" | ||||
| ) | ||||
|  | ||||
| var ( | ||||
| @@ -261,10 +262,21 @@ func (o *CreateJobOptions) createJobFromCronJob(cronJob *batchv1.CronJob) *batch | ||||
| 		// this is ok because we know exactly how we want to be serialized | ||||
| 		TypeMeta: metav1.TypeMeta{APIVersion: batchv1.SchemeGroupVersion.String(), Kind: "Job"}, | ||||
| 		ObjectMeta: metav1.ObjectMeta{ | ||||
| 			Name:            o.Name, | ||||
| 			Annotations:     annotations, | ||||
| 			Labels:          cronJob.Spec.JobTemplate.Labels, | ||||
| 			OwnerReferences: []metav1.OwnerReference{*metav1.NewControllerRef(cronJob, batchv1.SchemeGroupVersion.WithKind("CronJob"))}, | ||||
| 			Name:        o.Name, | ||||
| 			Annotations: annotations, | ||||
| 			Labels:      cronJob.Spec.JobTemplate.Labels, | ||||
| 			OwnerReferences: []metav1.OwnerReference{ | ||||
| 				{ | ||||
| 					// we are not using metav1.NewControllerRef because it | ||||
| 					// sets BlockOwnerDeletion to true which additionally mandates | ||||
| 					// cronjobs/finalizer role and not backwards-compatible. | ||||
| 					APIVersion: batchv1.SchemeGroupVersion.String(), | ||||
| 					Kind:       "CronJob", | ||||
| 					Name:       cronJob.GetName(), | ||||
| 					UID:        cronJob.GetUID(), | ||||
| 					Controller: ptr.To(true), | ||||
| 				}, | ||||
| 			}, | ||||
| 		}, | ||||
| 		Spec: cronJob.Spec.JobTemplate.Spec, | ||||
| 	} | ||||
|   | ||||
| @@ -24,6 +24,7 @@ import ( | ||||
| 	corev1 "k8s.io/api/core/v1" | ||||
| 	apiequality "k8s.io/apimachinery/pkg/api/equality" | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| 	"k8s.io/utils/ptr" | ||||
| ) | ||||
|  | ||||
| func TestCreateJobValidation(t *testing.T) { | ||||
| @@ -161,9 +162,17 @@ func TestCreateJobFromCronJob(t *testing.T) { | ||||
| 			expected: &batchv1.Job{ | ||||
| 				TypeMeta: metav1.TypeMeta{APIVersion: batchv1.SchemeGroupVersion.String(), Kind: "Job"}, | ||||
| 				ObjectMeta: metav1.ObjectMeta{ | ||||
| 					Name:            jobName, | ||||
| 					Annotations:     map[string]string{"cronjob.kubernetes.io/instantiate": "manual"}, | ||||
| 					OwnerReferences: []metav1.OwnerReference{*metav1.NewControllerRef(cronJob, batchv1.SchemeGroupVersion.WithKind("CronJob"))}, | ||||
| 					Name:        jobName, | ||||
| 					Annotations: map[string]string{"cronjob.kubernetes.io/instantiate": "manual"}, | ||||
| 					OwnerReferences: []metav1.OwnerReference{ | ||||
| 						{ | ||||
| 							APIVersion: batchv1.SchemeGroupVersion.String(), | ||||
| 							Kind:       "CronJob", | ||||
| 							Name:       cronJob.GetName(), | ||||
| 							UID:        cronJob.GetUID(), | ||||
| 							Controller: ptr.To(true), | ||||
| 						}, | ||||
| 					}, | ||||
| 				}, | ||||
| 				Spec: batchv1.JobSpec{ | ||||
| 					Template: corev1.PodTemplateSpec{ | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Kubernetes Prow Robot
					Kubernetes Prow Robot