155 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Go
		
	
	
	
			
		
		
	
	
			155 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Go
		
	
	
	
| package e2e
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 	"testing"
 | |
| 
 | |
| 	"github.com/jenkinsci/kubernetes-operator/pkg/apis/jenkins/v1alpha2"
 | |
| 	jenkinsclient "github.com/jenkinsci/kubernetes-operator/pkg/controller/jenkins/client"
 | |
| 	"github.com/jenkinsci/kubernetes-operator/pkg/controller/jenkins/configuration/base/resources"
 | |
| 
 | |
| 	framework "github.com/operator-framework/operator-sdk/pkg/test"
 | |
| 	"k8s.io/api/core/v1"
 | |
| 	corev1 "k8s.io/api/core/v1"
 | |
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
 | |
| 	"k8s.io/apimachinery/pkg/labels"
 | |
| 	"k8s.io/apimachinery/pkg/types"
 | |
| 	"k8s.io/apimachinery/pkg/util/intstr"
 | |
| )
 | |
| 
 | |
| func getJenkins(t *testing.T, namespace, name string) *v1alpha2.Jenkins {
 | |
| 	jenkins := &v1alpha2.Jenkins{}
 | |
| 	namespaceName := types.NamespacedName{Namespace: namespace, Name: name}
 | |
| 	if err := framework.Global.Client.Get(context.TODO(), namespaceName, jenkins); err != nil {
 | |
| 		t.Fatal(err)
 | |
| 	}
 | |
| 
 | |
| 	return jenkins
 | |
| }
 | |
| 
 | |
| func getJenkinsMasterPod(t *testing.T, jenkins *v1alpha2.Jenkins) *v1.Pod {
 | |
| 	lo := metav1.ListOptions{
 | |
| 		LabelSelector: labels.SelectorFromSet(resources.BuildResourceLabels(jenkins)).String(),
 | |
| 	}
 | |
| 	podList, err := framework.Global.KubeClient.CoreV1().Pods(jenkins.ObjectMeta.Namespace).List(lo)
 | |
| 	if err != nil {
 | |
| 		t.Fatal(err)
 | |
| 	}
 | |
| 	if len(podList.Items) != 1 {
 | |
| 		t.Fatalf("Jenkins pod not found, pod list: %+v", podList)
 | |
| 	}
 | |
| 	return &podList.Items[0]
 | |
| }
 | |
| 
 | |
| func createJenkinsAPIClient(jenkins *v1alpha2.Jenkins) (jenkinsclient.Jenkins, error) {
 | |
| 	adminSecret := &v1.Secret{}
 | |
| 	namespaceName := types.NamespacedName{Namespace: jenkins.Namespace, Name: resources.GetOperatorCredentialsSecretName(jenkins)}
 | |
| 	if err := framework.Global.Client.Get(context.TODO(), namespaceName, adminSecret); err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 
 | |
| 	jenkinsAPIURL, err := jenkinsclient.BuildJenkinsAPIUrl(jenkins.ObjectMeta.Namespace, resources.GetJenkinsHTTPServiceName(jenkins), resources.HTTPPortInt, true, true)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 
 | |
| 	return jenkinsclient.New(
 | |
| 		jenkinsAPIURL,
 | |
| 		string(adminSecret.Data[resources.OperatorCredentialsSecretUserNameKey]),
 | |
| 		string(adminSecret.Data[resources.OperatorCredentialsSecretTokenKey]),
 | |
| 	)
 | |
| }
 | |
| 
 | |
| func createJenkinsCR(t *testing.T, name, namespace string, seedJob *[]v1alpha2.SeedJob, volumes []corev1.Volume) *v1alpha2.Jenkins {
 | |
| 	var seedJobs []v1alpha2.SeedJob
 | |
| 	if seedJob != nil {
 | |
| 		seedJobs = append(seedJobs, *seedJob...)
 | |
| 	}
 | |
| 
 | |
| 	jenkins := &v1alpha2.Jenkins{
 | |
| 		TypeMeta: v1alpha2.JenkinsTypeMeta(),
 | |
| 		ObjectMeta: metav1.ObjectMeta{
 | |
| 			Name:      name,
 | |
| 			Namespace: namespace,
 | |
| 		},
 | |
| 		Spec: v1alpha2.JenkinsSpec{
 | |
| 			Master: v1alpha2.JenkinsMaster{
 | |
| 				Annotations: map[string]string{"test": "label"},
 | |
| 				Containers: []v1alpha2.Container{
 | |
| 					{
 | |
| 						Name: resources.JenkinsMasterContainerName,
 | |
| 						Env: []v1.EnvVar{
 | |
| 							{
 | |
| 								Name:  "TEST_ENV",
 | |
| 								Value: "test_env_value",
 | |
| 							},
 | |
| 						},
 | |
| 						ReadinessProbe: &corev1.Probe{
 | |
| 							Handler: corev1.Handler{
 | |
| 								HTTPGet: &corev1.HTTPGetAction{
 | |
| 									Path:   "/login",
 | |
| 									Port:   intstr.FromString("http"),
 | |
| 									Scheme: corev1.URISchemeHTTP,
 | |
| 								},
 | |
| 							},
 | |
| 							InitialDelaySeconds: int32(80),
 | |
| 							TimeoutSeconds:      int32(4),
 | |
| 							FailureThreshold:    int32(10),
 | |
| 						},
 | |
| 						LivenessProbe: &corev1.Probe{
 | |
| 							Handler: corev1.Handler{
 | |
| 								HTTPGet: &corev1.HTTPGetAction{
 | |
| 									Path:   "/login",
 | |
| 									Port:   intstr.FromString("http"),
 | |
| 									Scheme: corev1.URISchemeHTTP,
 | |
| 								},
 | |
| 							},
 | |
| 							InitialDelaySeconds: int32(80),
 | |
| 							TimeoutSeconds:      int32(4),
 | |
| 							FailureThreshold:    int32(10),
 | |
| 						},
 | |
| 					},
 | |
| 					{
 | |
| 						Name:  "envoyproxy",
 | |
| 						Image: "envoyproxy/envoy-alpine",
 | |
| 					},
 | |
| 				},
 | |
| 				Plugins: []v1alpha2.Plugin{
 | |
| 					{Name: "audit-trail", Version: "2.4"},
 | |
| 					{Name: "simple-theme-plugin", Version: "0.5.1"},
 | |
| 				},
 | |
| 				NodeSelector: map[string]string{"kubernetes.io/hostname": "minikube"},
 | |
| 				Volumes:      volumes,
 | |
| 			},
 | |
| 			SeedJobs: seedJobs,
 | |
| 		},
 | |
| 	}
 | |
| 
 | |
| 	t.Logf("Jenkins CR %+v", *jenkins)
 | |
| 	if err := framework.Global.Client.Create(context.TODO(), jenkins, nil); err != nil {
 | |
| 		t.Fatal(err)
 | |
| 	}
 | |
| 
 | |
| 	return jenkins
 | |
| }
 | |
| 
 | |
| func verifyJenkinsAPIConnection(t *testing.T, jenkins *v1alpha2.Jenkins) jenkinsclient.Jenkins {
 | |
| 	client, err := createJenkinsAPIClient(jenkins)
 | |
| 	if err != nil {
 | |
| 		t.Fatal(err)
 | |
| 	}
 | |
| 
 | |
| 	t.Log("I can establish connection to Jenkins API")
 | |
| 	return client
 | |
| }
 | |
| 
 | |
| func restartJenkinsMasterPod(t *testing.T, jenkins *v1alpha2.Jenkins) {
 | |
| 	t.Log("Restarting Jenkins master pod")
 | |
| 	jenkinsPod := getJenkinsMasterPod(t, jenkins)
 | |
| 	err := framework.Global.Client.Delete(context.TODO(), jenkinsPod)
 | |
| 	if err != nil {
 | |
| 		t.Fatal(err)
 | |
| 	}
 | |
| 	t.Log("Jenkins master pod has been restarted")
 | |
| }
 |