Skip to content

Commit

Permalink
Add tests for exposing WatcherAPI service
Browse files Browse the repository at this point in the history
  • Loading branch information
cescgina committed Jan 17, 2025
1 parent defbe96 commit 6bab6da
Show file tree
Hide file tree
Showing 6 changed files with 132 additions and 46 deletions.
6 changes: 6 additions & 0 deletions tests/functional/suite_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@ import (

metricsserver "sigs.k8s.io/controller-runtime/pkg/metrics/server"

routev1 "github.com/openshift/api/route/v1"
memcachedv1 "github.com/openstack-k8s-operators/infra-operator/apis/memcached/v1beta1"
rabbitmqv1 "github.com/openstack-k8s-operators/infra-operator/apis/rabbitmq/v1beta1"
keystonev1 "github.com/openstack-k8s-operators/keystone-operator/api/v1beta1"
Expand Down Expand Up @@ -97,6 +98,8 @@ var _ = BeforeSuite(func() {
keystoneCRDs, err := test.GetCRDDirFromModule(
"github.com/openstack-k8s-operators/keystone-operator/api", "../../go.mod", "bases")
Expect(err).ShouldNot(HaveOccurred())
routev1CRDs, err := test.GetOpenShiftCRDDir("route/v1", "../../go.mod")
Expect(err).ShouldNot(HaveOccurred())

By("bootstrapping test environment")
testEnv = &envtest.Environment{
Expand All @@ -105,6 +108,7 @@ var _ = BeforeSuite(func() {
mariaDBCRDs,
rabbitmqCRDs,
keystoneCRDs,
routev1CRDs,
},

ErrorIfCRDPathMissing: true,
Expand Down Expand Up @@ -136,6 +140,8 @@ var _ = BeforeSuite(func() {
Expect(err).NotTo(HaveOccurred())
err = memcachedv1.AddToScheme(scheme.Scheme)
Expect(err).NotTo(HaveOccurred())
err = routev1.AddToScheme(scheme.Scheme)
Expect(err).NotTo(HaveOccurred())

logger = ctrl.Log.WithName("---Test---")
//+kubebuilder:scaffold:scheme
Expand Down
10 changes: 10 additions & 0 deletions tests/functional/watcher_test_data.go
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,8 @@ type WatcherTestData struct {
WatcherAPIDeployment types.NamespacedName
WatcherPublicServiceName types.NamespacedName
WatcherInternalServiceName types.NamespacedName
WatcherRouteName types.NamespacedName
WatcherInternalRouteName types.NamespacedName
}

// GetWatcherTestData is a function that initialize the WatcherTestData
Expand Down Expand Up @@ -125,5 +127,13 @@ func GetWatcherTestData(watcherName types.NamespacedName) WatcherTestData {
Namespace: watcherName.Namespace,
Name: "watcher-internal",
},
WatcherRouteName: types.NamespacedName{
Namespace: watcherName.Namespace,
Name: "watcher-public",
},
WatcherInternalRouteName: types.NamespacedName{
Namespace: watcherName.Namespace,
Name: "watcher-internal",
},
}
}
101 changes: 66 additions & 35 deletions tests/functional/watcherapi_controller_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,6 @@ import (
memcachedv1 "github.com/openstack-k8s-operators/infra-operator/apis/memcached/v1beta1"
condition "github.com/openstack-k8s-operators/lib-common/modules/common/condition"
. "github.com/openstack-k8s-operators/lib-common/modules/common/test/helpers"
mariadbv1 "github.com/openstack-k8s-operators/mariadb-operator/api/v1beta1"
watcherv1beta1 "github.com/openstack-k8s-operators/watcher-operator/api/v1beta1"
corev1 "k8s.io/api/core/v1"
"k8s.io/utils/ptr"
Expand Down Expand Up @@ -114,14 +113,6 @@ var _ = Describe("WatcherAPI controller", func() {
},
)
DeferCleanup(k8sClient.Delete, ctx, secret)
mariadb.CreateMariaDBDatabase(watcherTest.WatcherDatabaseName.Namespace, watcherTest.WatcherDatabaseName.Name, mariadbv1.MariaDBDatabaseSpec{})
DeferCleanup(k8sClient.Delete, ctx, mariadb.GetMariaDBDatabase(watcherTest.WatcherDatabaseName))

mariadb.SimulateMariaDBTLSDatabaseCompleted(watcherTest.WatcherDatabaseName)
apiMariaDBAccount, apiMariaDBSecret := mariadb.CreateMariaDBAccountAndSecret(
watcherTest.WatcherDatabaseAccount, mariadbv1.MariaDBAccountSpec{})
DeferCleanup(k8sClient.Delete, ctx, apiMariaDBAccount)
DeferCleanup(k8sClient.Delete, ctx, apiMariaDBSecret)
DeferCleanup(th.DeleteInstance, CreateWatcherAPI(watcherTest.WatcherAPI, GetDefaultWatcherAPISpec()))
DeferCleanup(keystone.DeleteKeystoneAPI, keystone.CreateKeystoneAPI(watcherTest.WatcherAPI.Namespace))
memcachedSpec := memcachedv1.MemcachedSpec{
Expand Down Expand Up @@ -183,18 +174,18 @@ var _ = Describe("WatcherAPI controller", func() {
Expect(container.LivenessProbe.HTTPGet.Port.IntVal).To(Equal(int32(9322)))
Expect(container.ReadinessProbe.HTTPGet.Port.IntVal).To(Equal(int32(9322)))
})
It("creates the public and internal services for the watcher-api service", func() {
It("exposes the watcher-api service", func() {
th.ExpectCondition(
watcherTest.WatcherAPI,
ConditionGetterFunc(WatcherAPIConditionGetter),
condition.CreateServiceReadyCondition,
condition.ExposeServiceReadyCondition,
corev1.ConditionTrue,
)
public := th.GetService(watcherTest.WatcherPublicServiceName)
Expect(public.Labels["service"]).To(Equal("watcher-api"))
internal := th.GetService(watcherTest.WatcherInternalServiceName)
Expect(internal.Labels["service"]).To(Equal("watcher-api"))

th.AssertRouteExists(watcherTest.WatcherRouteName)
})
})
When("the secret is created but missing fields", func() {
Expand All @@ -204,14 +195,6 @@ var _ = Describe("WatcherAPI controller", func() {
map[string][]byte{},
)
DeferCleanup(k8sClient.Delete, ctx, secret)
mariadb.CreateMariaDBDatabase(watcherTest.WatcherDatabaseName.Namespace, watcherTest.WatcherDatabaseName.Name, mariadbv1.MariaDBDatabaseSpec{})
DeferCleanup(k8sClient.Delete, ctx, mariadb.GetMariaDBDatabase(watcherTest.WatcherDatabaseName))

mariadb.SimulateMariaDBTLSDatabaseCompleted(watcherTest.WatcherDatabaseName)
apiMariaDBAccount, apiMariaDBSecret := mariadb.CreateMariaDBAccountAndSecret(
watcherTest.WatcherDatabaseAccount, mariadbv1.MariaDBAccountSpec{})
DeferCleanup(k8sClient.Delete, ctx, apiMariaDBAccount)
DeferCleanup(k8sClient.Delete, ctx, apiMariaDBSecret)
DeferCleanup(th.DeleteInstance, CreateWatcherAPI(watcherTest.WatcherAPI, GetDefaultWatcherAPISpec()))
})
It("should have input false", func() {
Expand Down Expand Up @@ -265,14 +248,7 @@ var _ = Describe("WatcherAPI controller", func() {
},
)
DeferCleanup(k8sClient.Delete, ctx, secret)
mariadb.CreateMariaDBDatabase(watcherTest.WatcherDatabaseName.Namespace, watcherTest.WatcherDatabaseName.Name, mariadbv1.MariaDBDatabaseSpec{})
DeferCleanup(k8sClient.Delete, ctx, mariadb.GetMariaDBDatabase(watcherTest.WatcherDatabaseName))

mariadb.SimulateMariaDBTLSDatabaseCompleted(watcherTest.WatcherDatabaseName)
apiMariaDBAccount, apiMariaDBSecret := mariadb.CreateMariaDBAccountAndSecret(
watcherTest.WatcherDatabaseAccount, mariadbv1.MariaDBAccountSpec{})
DeferCleanup(k8sClient.Delete, ctx, apiMariaDBAccount)
DeferCleanup(k8sClient.Delete, ctx, apiMariaDBSecret)
DeferCleanup(th.DeleteInstance, CreateWatcherAPI(watcherTest.WatcherAPI, GetDefaultWatcherAPISpec()))
})
It("should have input ready true", func() {
Expand Down Expand Up @@ -307,14 +283,6 @@ var _ = Describe("WatcherAPI controller", func() {
},
)
DeferCleanup(k8sClient.Delete, ctx, secret)
mariadb.CreateMariaDBDatabase(watcherTest.WatcherDatabaseName.Namespace, watcherTest.WatcherDatabaseName.Name, mariadbv1.MariaDBDatabaseSpec{})
DeferCleanup(k8sClient.Delete, ctx, mariadb.GetMariaDBDatabase(watcherTest.WatcherDatabaseName))

mariadb.SimulateMariaDBTLSDatabaseCompleted(watcherTest.WatcherDatabaseName)
apiMariaDBAccount, apiMariaDBSecret := mariadb.CreateMariaDBAccountAndSecret(
watcherTest.WatcherDatabaseAccount, mariadbv1.MariaDBAccountSpec{})
DeferCleanup(k8sClient.Delete, ctx, apiMariaDBAccount)
DeferCleanup(k8sClient.Delete, ctx, apiMariaDBSecret)
memcachedSpec := memcachedv1.MemcachedSpec{
MemcachedSpecCore: memcachedv1.MemcachedSpecCore{
Replicas: ptr.To(int32(1)),
Expand Down Expand Up @@ -356,4 +324,67 @@ var _ = Describe("WatcherAPI controller", func() {
)
})
})
When("WatcherAPI is created with extrenalEndpoints", func() {
BeforeEach(func() {
secret := th.CreateSecret(
watcherTest.InternalTopLevelSecretName,
map[string][]byte{
"WatcherPassword": []byte("service-password"),
"transport_url": []byte("url"),
},
)
DeferCleanup(k8sClient.Delete, ctx, secret)
spec := GetDefaultWatcherAPISpec()
var externalEndpoints []interface{}
externalEndpoints = append(
externalEndpoints, map[string]interface{}{
"endpoint": "internal",
"ipAddressPool": "osp-internalapi",
"loadBalancerIPs": []string{"internal-lb-ip-1", "internal-lb-ip-2"},
},
)
spec["externalEndpoints"] = externalEndpoints
DeferCleanup(th.DeleteInstance, CreateWatcherAPI(watcherTest.WatcherAPI, spec))
DeferCleanup(keystone.DeleteKeystoneAPI, keystone.CreateKeystoneAPI(watcherTest.WatcherAPI.Namespace))
memcachedSpec := memcachedv1.MemcachedSpec{
MemcachedSpecCore: memcachedv1.MemcachedSpecCore{
Replicas: ptr.To(int32(1)),
},
}
DeferCleanup(infra.DeleteMemcached, infra.CreateMemcached(watcherTest.WatcherAPI.Namespace, MemcachedInstance, memcachedSpec))
infra.SimulateMemcachedReady(watcherTest.MemcachedNamespace)

})
It("creates MetalLB service", func() {
th.SimulateDeploymentReplicaReady(watcherTest.WatcherAPIDeployment)

// As the public endpoint is not mentioned in the ExternalEndpoints
// a generic Service and a Route is created
public := th.GetService(watcherTest.WatcherPublicServiceName)
Expect(public.Annotations).NotTo(HaveKey("metallb.universe.tf/address-pool"))
Expect(public.Annotations).NotTo(HaveKey("metallb.universe.tf/allow-shared-ip"))
Expect(public.Annotations).NotTo(HaveKey("metallb.universe.tf/loadBalancerIPs"))
th.AssertRouteExists(watcherTest.WatcherRouteName)

// As the internal endpoint is configure in ExternalEndpoints it
// does not get a Route but a Service with MetalLB annotations
// instead
internal := th.GetService(watcherTest.WatcherInternalServiceName)
Expect(internal.Annotations).To(HaveKeyWithValue("metallb.universe.tf/address-pool", "osp-internalapi"))
Expect(internal.Annotations).To(HaveKeyWithValue("metallb.universe.tf/allow-shared-ip", "osp-internalapi"))
Expect(internal.Annotations).To(HaveKeyWithValue("metallb.universe.tf/loadBalancerIPs", "internal-lb-ip-1,internal-lb-ip-2"))
th.AssertRouteNotExists(watcherTest.WatcherInternalRouteName)

// simulate that the internal service got a LoadBalancerIP
// assigned
th.SimulateLoadBalancerServiceIP(watcherTest.WatcherInternalServiceName)

th.ExpectCondition(
watcherTest.WatcherAPI,
ConditionGetterFunc(WatcherAPIConditionGetter),
condition.ReadyCondition,
corev1.ConditionTrue,
)
})
})
})
41 changes: 36 additions & 5 deletions tests/kuttl/test-suites/default/watcher/01-assert.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -204,14 +204,14 @@ status:
reason: Ready
status: "True"
type: Ready
- message: Create service completed
reason: Ready
status: "True"
type: CreateServiceReady
- message: Deployment completed
reason: Ready
status: "True"
type: DeploymentReady
- message: Exposing service completed
reason: Ready
status: "True"
type: ExposeServiceReady
- message: Input data complete
reason: Ready
status: "True"
Expand Down Expand Up @@ -258,7 +258,24 @@ apiVersion: v1
kind: Service
metadata:
labels:
endpoint: internal
public: "true"
service: watcher-api
name: watcher-public
spec:
ports:
- name: watcher-public
port: 9322
protocol: TCP
targetPort: 9322
selector:
service: watcher-api
type: ClusterIP
---
apiVersion: v1
kind: Service
metadata:
labels:
internal: "true"
service: watcher-api
name: watcher-internal
spec:
Expand All @@ -271,6 +288,20 @@ spec:
service: watcher-api
type: ClusterIP
---
apiVersion: route.openshift.io/v1
kind: Route
metadata:
labels:
public: "true"
service: watcher-api
name: watcher-public
spec:
port:
targetPort: watcher-public
to:
kind: Service
name: watcher-public
---
apiVersion: kuttl.dev/v1beta1
kind: TestAssert
namespaced: true
Expand Down
8 changes: 4 additions & 4 deletions tests/kuttl/test-suites/default/watcher/04-assert.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -185,14 +185,14 @@ status:
reason: Ready
status: "True"
type: Ready
- message: Create service completed
reason: Ready
status: "True"
type: CreateServiceReady
- message: Deployment completed
reason: Ready
status: "True"
type: DeploymentReady
- message: Exposing service completed
reason: Ready
status: "True"
type: ExposeServiceReady
- message: Input data complete
reason: Ready
status: "True"
Expand Down
12 changes: 10 additions & 2 deletions tests/kuttl/test-suites/default/watcher/05-errors.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -72,14 +72,22 @@ apiVersion: v1
kind: Service
metadata:
labels:
endpoint: internal
internal: "true"
service: watcher-api
name: watcher-internal
---
apiVersion: v1
kind: Service
metadata:
labels:
endpoint: public
public: "true"
service: watcher-api
name: watcher-public
---
apiVersion: route.openshift.io/v1
kind: Route
metadata:
labels:
public: "true"
service: watcher-api
name: watcher-public

0 comments on commit 6bab6da

Please sign in to comment.