You've already forked kubernetes-operator
mirror of
https://github.com/netbirdio/kubernetes-operator.git
synced 2026-05-22 17:11:40 -07:00
69afe3aade
This change adds SPDX license headers to all files and eforces it with the linter. Signed-off-by: Philip Laine <philip.laine@gmail.com>
151 lines
4.4 KiB
Go
151 lines
4.4 KiB
Go
// SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
package controller
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
|
|
. "github.com/onsi/ginkgo/v2"
|
|
. "github.com/onsi/gomega"
|
|
appsv1 "k8s.io/api/apps/v1"
|
|
corev1 "k8s.io/api/core/v1"
|
|
kerrors "k8s.io/apimachinery/pkg/api/errors"
|
|
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
|
"sigs.k8s.io/controller-runtime/pkg/client"
|
|
"sigs.k8s.io/controller-runtime/pkg/reconcile"
|
|
|
|
"github.com/netbirdio/netbird/shared/management/http/api"
|
|
|
|
nbv1alpha1 "github.com/netbirdio/kubernetes-operator/api/v1alpha1"
|
|
"github.com/netbirdio/kubernetes-operator/internal/netbirdmock"
|
|
)
|
|
|
|
var _ = Describe("NetworkRouter Controller", func() {
|
|
Context("When reconciling a resource", func() {
|
|
ctx := context.Background()
|
|
|
|
var netRouterRec *NetworkRouterReconciler
|
|
var setupKeyRec *SetupKeyReconciler
|
|
var groupRec *GroupReconciler
|
|
|
|
nn := client.ObjectKey{
|
|
Name: "test-resource",
|
|
Namespace: "network-router",
|
|
}
|
|
|
|
BeforeEach(func() {
|
|
nbClient := netbirdmock.Client()
|
|
netRouterRec = &NetworkRouterReconciler{
|
|
Client: k8sClient,
|
|
Netbird: nbClient,
|
|
ClientImage: "docker.io/netbirdio/netbird:latest",
|
|
ManagementURL: "https://netbird.io",
|
|
}
|
|
setupKeyRec = &SetupKeyReconciler{
|
|
Client: k8sClient,
|
|
Netbird: nbClient,
|
|
}
|
|
groupRec = &GroupReconciler{
|
|
Client: k8sClient,
|
|
Netbird: nbClient,
|
|
}
|
|
|
|
ns := &corev1.Namespace{
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
Name: nn.Namespace,
|
|
},
|
|
}
|
|
Expect(k8sClient.Create(ctx, ns)).To(Succeed())
|
|
})
|
|
|
|
AfterEach(func() {
|
|
ns := &corev1.Namespace{
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
Name: nn.Namespace,
|
|
},
|
|
}
|
|
err := k8sClient.Get(ctx, client.ObjectKeyFromObject(ns), ns)
|
|
if kerrors.IsNotFound(err) {
|
|
return
|
|
}
|
|
Expect(err).ToNot(HaveOccurred())
|
|
Expect(k8sClient.Delete(ctx, ns)).To(Succeed())
|
|
})
|
|
|
|
It("creates a routing peer along with a deployment", func() {
|
|
zoneReq := api.ZoneRequest{
|
|
Name: "cluster.local",
|
|
Domain: "cluster.local",
|
|
}
|
|
_, err := netRouterRec.Netbird.DNSZones.CreateZone(ctx, zoneReq)
|
|
Expect(err).ToNot(HaveOccurred())
|
|
|
|
netRouter := &nbv1alpha1.NetworkRouter{
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
Name: nn.Name,
|
|
Namespace: nn.Namespace,
|
|
},
|
|
Spec: nbv1alpha1.NetworkRouterSpec{
|
|
DNSZoneRef: nbv1alpha1.DNSZoneReference{
|
|
Name: "cluster.local",
|
|
},
|
|
},
|
|
}
|
|
Expect(k8sClient.Create(ctx, netRouter)).To(Succeed())
|
|
|
|
group := &nbv1alpha1.Group{
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
Name: fmt.Sprintf("networkrouter-%s", netRouter.Name),
|
|
Namespace: nn.Namespace,
|
|
},
|
|
}
|
|
setupKey := &nbv1alpha1.SetupKey{
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
Name: fmt.Sprintf("networkrouter-%s", netRouter.Name),
|
|
Namespace: nn.Namespace,
|
|
},
|
|
}
|
|
dep := &appsv1.Deployment{
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
Name: fmt.Sprintf("networkrouter-%s", netRouter.Name),
|
|
Namespace: nn.Namespace,
|
|
},
|
|
}
|
|
|
|
for range 3 {
|
|
_, err := netRouterRec.Reconcile(ctx, reconcile.Request{NamespacedName: nn})
|
|
Expect(err).NotTo(HaveOccurred())
|
|
|
|
_, err = groupRec.Reconcile(ctx, reconcile.Request{NamespacedName: client.ObjectKeyFromObject(group)})
|
|
Expect(err).NotTo(HaveOccurred())
|
|
|
|
_, err = setupKeyRec.Reconcile(ctx, reconcile.Request{NamespacedName: client.ObjectKeyFromObject(setupKey)})
|
|
Expect(err).NotTo(HaveOccurred())
|
|
}
|
|
|
|
err = k8sClient.Get(ctx, nn, netRouter)
|
|
Expect(err).NotTo(HaveOccurred())
|
|
Expect(netRouter.Status.NetworkID).ToNot(BeEmpty())
|
|
_, err = netRouterRec.Netbird.Networks.Routers(netRouter.Status.NetworkID).Get(ctx, netRouter.Status.RoutingPeerID)
|
|
Expect(err).NotTo(HaveOccurred())
|
|
|
|
err = k8sClient.Get(ctx, client.ObjectKeyFromObject(group), group)
|
|
Expect(err).NotTo(HaveOccurred())
|
|
Expect(group.OwnerReferences[0].UID).To(Equal(netRouter.UID))
|
|
|
|
err = k8sClient.Get(ctx, client.ObjectKeyFromObject(setupKey), setupKey)
|
|
Expect(err).NotTo(HaveOccurred())
|
|
Expect(setupKey.OwnerReferences[0].UID).To(Equal(netRouter.UID))
|
|
|
|
err = k8sClient.Get(ctx, client.ObjectKeyFromObject(dep), dep)
|
|
Expect(err).NotTo(HaveOccurred())
|
|
Expect(dep.OwnerReferences[0].UID).To(Equal(netRouter.UID))
|
|
|
|
routingPeerResp, err := netRouterRec.Netbird.Networks.Routers(netRouter.Status.NetworkID).Get(ctx, netRouter.Status.RoutingPeerID)
|
|
Expect(err).NotTo(HaveOccurred())
|
|
Expect((*routingPeerResp.PeerGroups)[0]).To(Equal(group.Status.GroupID))
|
|
})
|
|
})
|
|
})
|