package clean import ( "testing" "github.com/caos/orbos/mntr" "github.com/caos/orbos/pkg/kubernetes" kubernetesmock "github.com/caos/orbos/pkg/kubernetes/mock" "github.com/caos/orbos/pkg/labels" "github.com/golang/mock/gomock" "github.com/stretchr/testify/assert" corev1 "k8s.io/api/core/v1" macherrs "k8s.io/apimachinery/pkg/api/errors" "k8s.io/apimachinery/pkg/runtime/schema" ) func TestBackup_Adapt1(t *testing.T) { client := kubernetesmock.NewMockClientInt(gomock.NewController(t)) monitor := mntr.Monitor{} namespace := "testNs" databases := []string{"testDb"} nodeselector := map[string]string{"test": "test"} tolerations := []corev1.Toleration{ {Key: "testKey", Operator: "testOp"}} backupName := "testName" image := "testImage" secretKey := "testKey" secretName := "testSecretName" jobName := GetJobName(backupName) componentLabels := labels.MustForComponent(labels.MustForAPI(labels.MustForOperator("testProd", "testOp", "testVersion"), "testKind", "testVersion"), "testComponent") nameLabels := labels.MustForName(componentLabels, jobName) checkDBReady := func(k8sClient kubernetes.ClientInt) error { return nil } jobDef := getJob( namespace, nameLabels, nodeselector, tolerations, secretName, secretKey, getCommand( databases, ), image, ) client.EXPECT().ApplyJob(jobDef).Times(1).Return(nil) client.EXPECT().GetJob(jobDef.Namespace, jobDef.Name).Times(1).Return(nil, macherrs.NewNotFound(schema.GroupResource{"batch", "jobs"}, jobName)) query, _, err := AdaptFunc( monitor, backupName, namespace, componentLabels, databases, nodeselector, tolerations, checkDBReady, secretName, secretKey, image, ) assert.NoError(t, err) queried := map[string]interface{}{} ensure, err := query(client, queried) assert.NoError(t, err) assert.NoError(t, ensure(client)) } func TestBackup_Adapt2(t *testing.T) { client := kubernetesmock.NewMockClientInt(gomock.NewController(t)) monitor := mntr.Monitor{} namespace := "testNs2" databases := []string{"testDb1", "testDb2"} nodeselector := map[string]string{"test2": "test2"} tolerations := []corev1.Toleration{ {Key: "testKey2", Operator: "testOp2"}} backupName := "testName2" image := "testImage2" secretKey := "testKey2" secretName := "testSecretName2" jobName := GetJobName(backupName) componentLabels := labels.MustForComponent(labels.MustForAPI(labels.MustForOperator("testProd2", "testOp2", "testVersion2"), "testKind2", "testVersion2"), "testComponent2") nameLabels := labels.MustForName(componentLabels, jobName) checkDBReady := func(k8sClient kubernetes.ClientInt) error { return nil } jobDef := getJob( namespace, nameLabels, nodeselector, tolerations, secretName, secretKey, getCommand( databases, ), image, ) client.EXPECT().ApplyJob(jobDef).Times(1).Return(nil) client.EXPECT().GetJob(jobDef.Namespace, jobDef.Name).Times(1).Return(nil, macherrs.NewNotFound(schema.GroupResource{"batch", "jobs"}, jobName)) query, _, err := AdaptFunc( monitor, backupName, namespace, componentLabels, databases, nodeselector, tolerations, checkDBReady, secretName, secretKey, image, ) assert.NoError(t, err) queried := map[string]interface{}{} ensure, err := query(client, queried) assert.NoError(t, err) assert.NoError(t, ensure(client)) }