// // DISCLAIMER // // Copyright 2016-2024 ArangoDB GmbH, Cologne, Germany // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. // // Copyright holder is ArangoDB GmbH, Cologne, Germany // package deployment import ( "testing" core "k8s.io/api/core/v1" api "github.com/arangodb/kube-arangodb/pkg/apis/deployment/v1" shared "github.com/arangodb/kube-arangodb/pkg/apis/shared" "github.com/arangodb/kube-arangodb/pkg/util" "github.com/arangodb/kube-arangodb/pkg/util/k8sutil" ) func TestEnsurePod_Metrics(t *testing.T) { testCases := []testCaseStruct{ { Name: "DBserver Pod with metrics exporter and port override", ArangoDeployment: &api.ArangoDeployment{ Spec: api.DeploymentSpec{ Image: util.NewType[string](testImage), Authentication: noAuthentication, TLS: noTLS, Metrics: func() api.MetricsSpec { m := metricsSpec.DeepCopy() m.Port = util.NewType[uint16](9999) return *m }(), }, }, Helper: func(t *testing.T, deployment *Deployment, testCase *testCaseStruct) { deployment.currentObjectStatus = &api.DeploymentStatus{ Members: api.DeploymentStatusMembers{ DBServers: api.MemberStatusList{ firstDBServerStatus, }, }, Images: createTestImages(false), } testCase.createTestPodData(deployment, api.ServerGroupDBServers, firstDBServerStatus) testCase.ExpectedPod.ObjectMeta.Labels[k8sutil.LabelKeyArangoExporter] = testYes }, ExpectedEvent: "member dbserver is created", ExpectedPod: core.Pod{ Spec: core.PodSpec{ Volumes: []core.Volume{ k8sutil.CreateVolumeEmptyDir(shared.ArangodVolumeName), }, Containers: []core.Container{ { Name: shared.ServerContainerName, Image: testImage, Command: createTestCommandForDBServer(firstDBServerStatus.ID, false, false, false), Ports: createTestPorts(api.ServerGroupAgents), VolumeMounts: []core.VolumeMount{ k8sutil.ArangodVolumeMount(), }, Resources: emptyResources, LivenessProbe: createTestLivenessProbe(httpProbe, false, "", shared.ServerPortName), ImagePullPolicy: core.PullIfNotPresent, SecurityContext: securityContext.NewSecurityContext(), }, testArangodbInternalExporterContainer(false, false, emptyResources, 9999), }, RestartPolicy: core.RestartPolicyNever, TerminationGracePeriodSeconds: &defaultDBServerTerminationTimeout, Hostname: testDeploymentName + "-" + api.ServerGroupDBServersString + "-" + firstDBServerStatus.ID, Subdomain: testDeploymentName + "-int", Affinity: k8sutil.CreateAffinity(testDeploymentName, api.ServerGroupDBServersString, false, ""), }, }, }, { Name: "DBserver Pod with metrics exporter with mode", ArangoDeployment: &api.ArangoDeployment{ Spec: api.DeploymentSpec{ Image: util.NewType[string](testImage), Authentication: noAuthentication, TLS: noTLS, Metrics: func() api.MetricsSpec { m := metricsSpec.DeepCopy() //nolint:staticcheck m.Mode = api.MetricsModeExporter.New() return *m }(), }, }, Helper: func(t *testing.T, deployment *Deployment, testCase *testCaseStruct) { deployment.currentObjectStatus = &api.DeploymentStatus{ Members: api.DeploymentStatusMembers{ DBServers: api.MemberStatusList{ firstDBServerStatus, }, }, Images: createTestImages(false), } testCase.createTestPodData(deployment, api.ServerGroupDBServers, firstDBServerStatus) testCase.ExpectedPod.ObjectMeta.Labels[k8sutil.LabelKeyArangoExporter] = testYes }, ExpectedEvent: "member dbserver is created", ExpectedPod: core.Pod{ Spec: core.PodSpec{ Volumes: []core.Volume{ k8sutil.CreateVolumeEmptyDir(shared.ArangodVolumeName), }, Containers: []core.Container{ { Name: shared.ServerContainerName, Image: testImage, Command: createTestCommandForDBServer(firstDBServerStatus.ID, false, false, false), Ports: createTestPorts(api.ServerGroupAgents), VolumeMounts: []core.VolumeMount{ k8sutil.ArangodVolumeMount(), }, Resources: emptyResources, LivenessProbe: createTestLivenessProbe(httpProbe, false, "", shared.ServerPortName), ImagePullPolicy: core.PullIfNotPresent, SecurityContext: securityContext.NewSecurityContext(), }, testArangodbInternalExporterContainer(false, false, emptyResources), }, RestartPolicy: core.RestartPolicyNever, TerminationGracePeriodSeconds: &defaultDBServerTerminationTimeout, Hostname: testDeploymentName + "-" + api.ServerGroupDBServersString + "-" + firstDBServerStatus.ID, Subdomain: testDeploymentName + "-int", Affinity: k8sutil.CreateAffinity(testDeploymentName, api.ServerGroupDBServersString, false, ""), }, }, }, { Name: "DBserver Pod with metrics exporter with internal mode", ArangoDeployment: &api.ArangoDeployment{ Spec: api.DeploymentSpec{ Image: util.NewType[string](testImage), Authentication: noAuthentication, TLS: noTLS, Metrics: func() api.MetricsSpec { m := metricsSpec.DeepCopy() //nolint:staticcheck m.Mode = api.MetricsModeInternal.New() return *m }(), }, }, Helper: func(t *testing.T, deployment *Deployment, testCase *testCaseStruct) { deployment.currentObjectStatus = &api.DeploymentStatus{ Members: api.DeploymentStatusMembers{ DBServers: api.MemberStatusList{ firstDBServerStatus, }, }, Images: createTestImages(false), } testCase.createTestPodData(deployment, api.ServerGroupDBServers, firstDBServerStatus) }, ExpectedEvent: "member dbserver is created", ExpectedPod: core.Pod{ Spec: core.PodSpec{ Volumes: []core.Volume{ k8sutil.CreateVolumeEmptyDir(shared.ArangodVolumeName), }, Containers: []core.Container{ { Name: shared.ServerContainerName, Image: testImage, Command: createTestCommandForDBServer(firstDBServerStatus.ID, false, false, false), Ports: func() []core.ContainerPort { ports := createTestPorts(api.ServerGroupAgents) ports = append(ports, core.ContainerPort{ Name: "exporter", Protocol: core.ProtocolTCP, ContainerPort: shared.ArangoPort, }) return ports }(), VolumeMounts: []core.VolumeMount{ k8sutil.ArangodVolumeMount(), }, Resources: emptyResources, LivenessProbe: createTestLivenessProbe(httpProbe, false, "", shared.ServerPortName), ImagePullPolicy: core.PullIfNotPresent, SecurityContext: securityContext.NewSecurityContext(), }, }, RestartPolicy: core.RestartPolicyNever, TerminationGracePeriodSeconds: &defaultDBServerTerminationTimeout, Hostname: testDeploymentName + "-" + api.ServerGroupDBServersString + "-" + firstDBServerStatus.ID, Subdomain: testDeploymentName + "-int", Affinity: k8sutil.CreateAffinity(testDeploymentName, api.ServerGroupDBServersString, false, ""), }, }, }, { Name: "Agent Pod with metrics exporter with internal mode", ArangoDeployment: &api.ArangoDeployment{ Spec: api.DeploymentSpec{ Image: util.NewType[string](testImage), Authentication: noAuthentication, TLS: noTLS, Metrics: func() api.MetricsSpec { m := metricsSpec.DeepCopy() //nolint:staticcheck m.Mode = api.MetricsModeInternal.New() return *m }(), }, }, Helper: func(t *testing.T, deployment *Deployment, testCase *testCaseStruct) { deployment.currentObjectStatus = &api.DeploymentStatus{ Members: api.DeploymentStatusMembers{ Agents: api.MemberStatusList{ firstAgentStatus, }, }, Images: createTestImages(false), } testCase.createTestPodData(deployment, api.ServerGroupAgents, firstAgentStatus) }, ExpectedEvent: "member agent is created", ExpectedPod: core.Pod{ Spec: core.PodSpec{ Volumes: []core.Volume{ k8sutil.CreateVolumeEmptyDir(shared.ArangodVolumeName), }, Containers: []core.Container{ { Name: shared.ServerContainerName, Image: testImage, Command: createTestCommandForAgent(firstAgentStatus.ID, false, false, false), Ports: func() []core.ContainerPort { ports := createTestPorts(api.ServerGroupAgents) ports = append(ports, core.ContainerPort{ Name: "exporter", Protocol: core.ProtocolTCP, ContainerPort: shared.ArangoPort, }) return ports }(), VolumeMounts: []core.VolumeMount{ k8sutil.ArangodVolumeMount(), }, Resources: emptyResources, LivenessProbe: createTestLivenessProbe(httpProbe, false, "", shared.ServerPortName), ImagePullPolicy: core.PullIfNotPresent, SecurityContext: securityContext.NewSecurityContext(), }, }, RestartPolicy: core.RestartPolicyNever, TerminationGracePeriodSeconds: &defaultAgentTerminationTimeout, Hostname: testDeploymentName + "-" + api.ServerGroupAgentsString + "-" + firstAgentStatus.ID, Subdomain: testDeploymentName + "-int", Affinity: k8sutil.CreateAffinity(testDeploymentName, api.ServerGroupAgentsString, false, ""), }, }, }, } runTestCases(t, testCases...) }