Skip to content

Commit

Permalink
Added key type filter in managed controller
Browse files Browse the repository at this point in the history
  • Loading branch information
ddraganovv committed Jan 13, 2025
1 parent a3459ca commit f3da3cf
Show file tree
Hide file tree
Showing 9 changed files with 35 additions and 11 deletions.
2 changes: 1 addition & 1 deletion api/payloads/service_binding.go
Original file line number Diff line number Diff line change
Expand Up @@ -91,8 +91,8 @@ func (l *ServiceBindingList) ToMessage() repositories.ListServiceBindingsMessage
ServiceInstanceGUIDs: parse.ArrayParam(l.ServiceInstanceGUIDs),
AppGUIDs: parse.ArrayParam(l.AppGUIDs),
LabelSelector: l.LabelSelector,
Type: &l.Type,
PlanGUIDs: parse.ArrayParam(l.PlanGUIDs),
Type: &l.Type,
}
}

Expand Down
2 changes: 1 addition & 1 deletion api/payloads/service_binding_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ var _ = Describe("ServiceBindingList", func() {
Entry("app_guids", "app_guids=app_guid", payloads.ServiceBindingList{AppGUIDs: "app_guid"}),
Entry("service_instance_guids", "service_instance_guids=si_guid", payloads.ServiceBindingList{ServiceInstanceGUIDs: "si_guid"}),
Entry("include", "include=app", payloads.ServiceBindingList{Include: "app"}),
Entry("include", "include=key", payloads.ServiceBindingList{Include: "key"}),
Entry("include", "include=service_instance", payloads.ServiceBindingList{Include: "service_instance"}),
Entry("label_selector=foo", "label_selector=foo", payloads.ServiceBindingList{LabelSelector: "foo"}),
Entry("service_plan_guids=plan-guid", "service_plan_guids=plan-guid", payloads.ServiceBindingList{PlanGUIDs: "plan-guid"}),
)
Expand Down
1 change: 1 addition & 0 deletions api/repositories/service_binding_repository_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -865,6 +865,7 @@ var _ = Describe("ServiceBindingRepo", func() {
Namespace: space2.Name,
Labels: map[string]string{
korifiv1alpha1.PlanGUIDLabelKey: "plan-4",
korifiv1alpha1.SpaceGUIDKey: space.Name,
},
},
Spec: korifiv1alpha1.CFServiceBindingSpec{
Expand Down
5 changes: 2 additions & 3 deletions controllers/api/v1alpha1/cfservicebinding_types.go
Original file line number Diff line number Diff line change
Expand Up @@ -34,9 +34,8 @@ const (
ServiceInstanceTypeAnnotationKey = "korifi.cloudfoundry.org/service-instance-type"
PlanGUIDLabelKey = "korifi.cloudfoundry.org/plan-guid"

ServiceBindingGUIDLabel = "korifi.cloudfoundry.org/service-binding-guid"
ServiceCredentialBindingTypeLabel = "korifi.cloudfoundry.org/service-credential-binding-type"
CFServiceBindingFinalizerName = "cfServiceBinding.korifi.cloudfoundry.org"
ServiceBindingGUIDLabel = "korifi.cloudfoundry.org/service-binding-guid"
CFServiceBindingFinalizerName = "cfServiceBinding.korifi.cloudfoundry.org"
)

// CFServiceBindingSpec defines the desired state of CFServiceBinding
Expand Down
17 changes: 17 additions & 0 deletions controllers/controllers/services/bindings/controller_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -750,6 +750,23 @@ var _ = Describe("CFServiceBinding", func() {
}).Should(Succeed())
})

When("binding is of type key", func() {
BeforeEach(func() {
Expect(k8s.Patch(ctx, adminClient, binding, func() {
binding.Spec.Type = korifiv1alpha1.CFServiceBindingTypeKey
})).To(Succeed())
})

It("does not create servicebinding.io", func() {
Consistently(func(g Gomega) {
sbList := &servicebindingv1beta1.ServiceBindingList{}
err := adminClient.List(ctx, sbList, client.InNamespace(testNamespace))
g.Expect(err).NotTo(HaveOccurred())
g.Expect(sbList.Items).To(BeEmpty())
}).Should(Succeed())
})
})

When("the credentials contain type key", func() {
BeforeEach(func() {
brokerClient.BindReturns(osbapi.BindResponse{
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -89,6 +89,10 @@ func (r *ManagedBindingsReconciler) ReconcileResource(ctx context.Context, cfSer
return ctrl.Result{}, err
}

if cfServiceBinding.Spec.Type == korifiv1alpha1.CFServiceBindingTypeKey {
return ctrl.Result{}, nil
}

sbServiceBinding, err := r.reconcileSBServiceBinding(ctx, cfServiceBinding)
if err != nil {
log.Info("error creating/updating servicebinding.io servicebinding", "reason", err)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,9 +16,9 @@ func ToSBServiceBinding(cfServiceBinding *korifiv1alpha1.CFServiceBinding, bindi
Name: fmt.Sprintf("cf-binding-%s", cfServiceBinding.Name),
Namespace: cfServiceBinding.Namespace,
Labels: map[string]string{
korifiv1alpha1.ServiceBindingGUIDLabel: cfServiceBinding.Name,
korifiv1alpha1.CFAppGUIDLabelKey: cfServiceBinding.Spec.AppRef.Name,
korifiv1alpha1.ServiceCredentialBindingTypeLabel: "app",
korifiv1alpha1.ServiceBindingGUIDLabel: cfServiceBinding.Name,
korifiv1alpha1.CFAppGUIDLabelKey: cfServiceBinding.Spec.AppRef.Name,
korifiv1alpha1.ServiceBindingTypeLabel: "app",
},
},
Spec: servicebindingv1beta1.ServiceBindingSpec{
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -62,9 +62,9 @@ var _ = Describe("SBIO", func() {
Name: "cf-binding-cf-binding",
Namespace: cfServiceBinding.Namespace,
Labels: map[string]string{
korifiv1alpha1.ServiceBindingGUIDLabel: bindingName,
korifiv1alpha1.CFAppGUIDLabelKey: cfServiceBinding.Spec.AppRef.Name,
korifiv1alpha1.ServiceCredentialBindingTypeLabel: "app",
korifiv1alpha1.ServiceBindingGUIDLabel: bindingName,
korifiv1alpha1.CFAppGUIDLabelKey: cfServiceBinding.Spec.AppRef.Name,
korifiv1alpha1.ServiceBindingTypeLabel: "app",
},
},
Spec: servicebindingv1beta1.ServiceBindingSpec{
Expand Down
3 changes: 3 additions & 0 deletions controllers/webhooks/relationships/webhook_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -83,6 +83,9 @@ var _ = Describe("Setting the space-guid label", func() {
Namespace: spaceNamespace,
Name: uuid.NewString(),
},
Spec: korifiv1alpha1.CFServiceBindingSpec{
Type: "app",
},
},
&korifiv1alpha1.CFServiceInstance{
ObjectMeta: metav1.ObjectMeta{
Expand Down

0 comments on commit f3da3cf

Please sign in to comment.