Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Improve test coverage of backend pt2 #615

Merged
merged 2 commits into from
Sep 21, 2023
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
123 changes: 116 additions & 7 deletions backend/eventloop/repocred_reconciler_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -9,13 +9,23 @@ import (
managedgitopsv1alpha1 "github.com/redhat-appstudio/managed-gitops/backend-shared/apis/managed-gitops/v1alpha1"
db "github.com/redhat-appstudio/managed-gitops/backend-shared/db"
"github.com/redhat-appstudio/managed-gitops/backend-shared/util/tests"
corev1 "k8s.io/api/core/v1"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/util/uuid"
"sigs.k8s.io/controller-runtime/pkg/client"
"sigs.k8s.io/controller-runtime/pkg/client/fake"
logger "sigs.k8s.io/controller-runtime/pkg/log"
)

func findCondition(conditions []metav1.Condition, typeName string) *metav1.Condition {
for i := range conditions {
if conditions[i].Type == typeName {
return &conditions[i]
}
}
return nil
}

var _ = Describe("RepoCred Reconcile Function Tests", func() {
Context("Testing reconcileRepositoryCredentials function for RepositoryCredentials table entries.", func() {

Expand Down Expand Up @@ -90,39 +100,138 @@ var _ = Describe("RepoCred Reconcile Function Tests", func() {

err = dbq.CreateAPICRToDatabaseMapping(ctx, &apiCRToDatabaseMappingDb)
Expect(err).ToNot(HaveOccurred())
})

It("should skip the reconcile and not blow up if the GitOpsDeploymentRepositoryCredential CR is not found", func() {

defer dbq.CloseDatabase()

By("not creating a GitOpsDeployment CR in cluster and calling the Reconcile function.")
objectMeta := metav1.ObjectMeta{
Name: apiCRToDatabaseMappingDb.APIResourceName,
Namespace: apiCRToDatabaseMappingDb.APIResourceNamespace,
}
reconcileRepositoryCredentialStatus(ctx, k8sClient, dbq, db.APICRToDatabaseMapping{}, objectMeta, log)
})

It("should set an error status for RepositoryCredentials if the secret field is not set in the CR", func() {

defer dbq.CloseDatabase()

By("creating a GitOpsDeployment CR in cluster")
gitopsDeploymentRepositoryCredentialCR := &managedgitopsv1alpha1.GitOpsDeploymentRepositoryCredential{
ObjectMeta: metav1.ObjectMeta{
Name: apiCRToDatabaseMappingDb.APIResourceName,
Namespace: apiCRToDatabaseMappingDb.APIResourceNamespace,
},
}
// Create GitOpsDeployment CR in cluster
err = k8sClient.Create(context.Background(), gitopsDeploymentRepositoryCredentialCR)
err := k8sClient.Create(context.Background(), gitopsDeploymentRepositoryCredentialCR)
Expect(err).ToNot(HaveOccurred())

By("calling the Reconcile function.")
reconcileRepositoryCredentials(ctx, dbq, k8sClient, log)

By("verifing that status is updated for GitopsDeploymentRepositoryCredentialCR.")
objectMeta := metav1.ObjectMeta{
Name: apiCRToDatabaseMappingDb.APIResourceName,
Namespace: apiCRToDatabaseMappingDb.APIResourceNamespace,
}
repoCredCR := &managedgitopsv1alpha1.GitOpsDeploymentRepositoryCredential{ObjectMeta: objectMeta}
err = k8sClient.Get(ctx, client.ObjectKeyFromObject(repoCredCR), repoCredCR)
Expect(err).ToNot(HaveOccurred())
Expect(repoCredCR).NotTo(BeNil())
Expect(repoCredCR.Status.Conditions).To(HaveLen(3))
condition := findCondition(repoCredCR.Status.Conditions, managedgitopsv1alpha1.GitOpsDeploymentRepositoryCredentialConditionErrorOccurred)
Expect(condition).ToNot(BeNil())
Expect(condition.Reason).To(Equal(managedgitopsv1alpha1.RepositoryCredentialReasonSecretNotSpecified))
Expect(condition.Status).To(Equal(metav1.ConditionTrue))
Expect(condition.Message).To(Equal("Secret field is missing value"))
})

It("should reconcile status for RepositoryCredentials if the entry is present in RepositoryCredentials DB", func() {
It("should set an error status for RepositoryCredentials if the secret is not found", func() {

defer dbq.CloseDatabase()

By("Call Reconcile function.")
By("creating a GitOpsDeployment CR in cluster")
gitopsDeploymentRepositoryCredentialCR := &managedgitopsv1alpha1.GitOpsDeploymentRepositoryCredential{
ObjectMeta: metav1.ObjectMeta{
Name: apiCRToDatabaseMappingDb.APIResourceName,
Namespace: apiCRToDatabaseMappingDb.APIResourceNamespace,
},
Spec: managedgitopsv1alpha1.GitOpsDeploymentRepositoryCredentialSpec{
Secret: "test-my-missing-secret",
},
}
err := k8sClient.Create(context.Background(), gitopsDeploymentRepositoryCredentialCR)
Expect(err).ToNot(HaveOccurred())

By("calling the Reconcile function.")
reconcileRepositoryCredentials(ctx, dbq, k8sClient, log)

By("Verify that status is updated for GitopsDeploymentRepositoryCredentialCR.")
By("verifing that status is updated for GitopsDeploymentRepositoryCredentialCR.")
objectMeta := metav1.ObjectMeta{
Name: apiCRToDatabaseMappingDb.APIResourceName,
Namespace: apiCRToDatabaseMappingDb.APIResourceNamespace,
}
repoCredCR := &managedgitopsv1alpha1.GitOpsDeploymentRepositoryCredential{ObjectMeta: objectMeta}

err := k8sClient.Get(ctx, client.ObjectKeyFromObject(repoCredCR), repoCredCR)
err = k8sClient.Get(ctx, client.ObjectKeyFromObject(repoCredCR), repoCredCR)
Expect(err).ToNot(HaveOccurred())
Expect(repoCredCR).NotTo(BeNil())
Expect(repoCredCR.Status.Conditions).To(HaveLen(3))
condition := findCondition(repoCredCR.Status.Conditions, managedgitopsv1alpha1.GitOpsDeploymentRepositoryCredentialConditionErrorOccurred)
Expect(condition).ToNot(BeNil())
Expect(condition.Reason).To(Equal(managedgitopsv1alpha1.RepositoryCredentialReasonSecretNotFound))
Expect(condition.Status).To(Equal(metav1.ConditionTrue))
Expect(condition.Message).To(Equal("Secret specified not found"))
})

It("should set an error status for RepositoryCredentials if the repo and secret exist but the credentials are invalid", func() {

defer dbq.CloseDatabase()

By("creating a secret in the cluster")
secret := &corev1.Secret{
ObjectMeta: metav1.ObjectMeta{
Name: "test-my-repository-credentials-secret",
Namespace: apiCRToDatabaseMappingDb.APIResourceNamespace,
},
Data: map[string][]byte{"username": []byte("username"), "password": []byte("password")},
}
err := k8sClient.Create(ctx, secret)
Expect(err).ToNot(HaveOccurred())

By("creating a GitOpsDeployment CR in cluster")
gitopsDeploymentRepositoryCredentialCR := &managedgitopsv1alpha1.GitOpsDeploymentRepositoryCredential{
ObjectMeta: metav1.ObjectMeta{
Name: apiCRToDatabaseMappingDb.APIResourceName,
Namespace: apiCRToDatabaseMappingDb.APIResourceNamespace,
},
Spec: managedgitopsv1alpha1.GitOpsDeploymentRepositoryCredentialSpec{
Repository: "https://github.com/redhat-appstudio/managed-gitops.git",
Secret: secret.Name,
},
}
err = k8sClient.Create(context.Background(), gitopsDeploymentRepositoryCredentialCR)
Expect(err).ToNot(HaveOccurred())

By("calling the Reconcile function.")
reconcileRepositoryCredentials(ctx, dbq, k8sClient, log)

By("verifing that status is updated for GitopsDeploymentRepositoryCredentialCR.")
objectMeta := metav1.ObjectMeta{
Name: apiCRToDatabaseMappingDb.APIResourceName,
Namespace: apiCRToDatabaseMappingDb.APIResourceNamespace,
}
repoCredCR := &managedgitopsv1alpha1.GitOpsDeploymentRepositoryCredential{ObjectMeta: objectMeta}
err = k8sClient.Get(ctx, client.ObjectKeyFromObject(repoCredCR), repoCredCR)
Expect(err).ToNot(HaveOccurred())
Expect(repoCredCR).NotTo(BeNil())
Expect(repoCredCR.Status.Conditions).To(HaveLen(3))
condition := findCondition(repoCredCR.Status.Conditions, managedgitopsv1alpha1.GitOpsDeploymentRepositoryCredentialConditionErrorOccurred)
Expect(condition).ToNot(BeNil())
Expect(condition.Reason).To(Equal(managedgitopsv1alpha1.RepositoryCredentialReasonInvalidCredentials))
Expect(condition.Status).To(Equal(metav1.ConditionTrue))
Expect(condition.Message).To(Equal("Repository Credentials provided test-my-repository-credentials-secret for Repository https://github.com/redhat-appstudio/managed-gitops.git are invalid"))
})
})
})