// // DISCLAIMER // // Copyright 2016-2023 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 ( "fmt" "testing" core "k8s.io/api/core/v1" api "github.com/arangodb/kube-arangodb/pkg/apis/deployment/v1" "github.com/arangodb/kube-arangodb/pkg/apis/shared" "github.com/arangodb/kube-arangodb/pkg/util" "github.com/arangodb/kube-arangodb/pkg/util/k8sutil" ) func createExampleVolume(name string) api.ServerGroupSpecVolume { return api.ServerGroupSpecVolume{ Name: name, ConfigMap: &api.ServerGroupSpecVolumeConfigMap{ LocalObjectReference: core.LocalObjectReference{ Name: name, }, }, } } func createExampleVolumeMount(name string) api.ServerGroupSpecVolumeMount { return api.ServerGroupSpecVolumeMount{ Name: name, MountPath: fmt.Sprintf("/mount/%s", name), } } func TestEnsurePod_ArangoDB_Volumes(t *testing.T) { testCases := []testCaseStruct{ { Name: "DBserver POD with Volume", ArangoDeployment: &api.ArangoDeployment{ Spec: api.DeploymentSpec{ Image: util.NewType[string](testImage), Authentication: noAuthentication, TLS: noTLS, DBServers: api.ServerGroupSpec{ Volumes: []api.ServerGroupSpecVolume{ createExampleVolume("volume"), }, }, }, }, Helper: func(t *testing.T, deployment *Deployment, testCase *testCaseStruct) { deployment.currentObjectStatus = &api.DeploymentStatus{ Members: api.DeploymentStatusMembers{ DBServers: api.MemberStatusList{ firstDBServerStatus, }, }, Images: createTestImages(false), } deployment.currentObjectStatus.Members.DBServers[0].IsInitialized = true testCase.createTestPodData(deployment, api.ServerGroupDBServers, firstDBServerStatus) }, ExpectedEvent: "member dbserver is created", ExpectedPod: core.Pod{ Spec: core.PodSpec{ Volumes: []core.Volume{ k8sutil.CreateVolumeEmptyDir(shared.ArangodVolumeName), createExampleVolume("volume").Volume(), }, Containers: []core.Container{ { Name: shared.ServerContainerName, Image: testImage, Command: createTestCommandForDBServer(firstDBServerStatus.ID, false, false, false), Ports: createTestPorts(api.ServerGroupAgents), Resources: emptyResources, VolumeMounts: []core.VolumeMount{ k8sutil.ArangodVolumeMount(), }, 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: "DBserver POD with Volumes", ArangoDeployment: &api.ArangoDeployment{ Spec: api.DeploymentSpec{ Image: util.NewType[string](testImage), Authentication: noAuthentication, TLS: noTLS, DBServers: api.ServerGroupSpec{ Volumes: []api.ServerGroupSpecVolume{ createExampleVolume("volume"), createExampleVolume("volume2"), }, }, }, }, Helper: func(t *testing.T, deployment *Deployment, testCase *testCaseStruct) { deployment.currentObjectStatus = &api.DeploymentStatus{ Members: api.DeploymentStatusMembers{ DBServers: api.MemberStatusList{ firstDBServerStatus, }, }, Images: createTestImages(false), } deployment.currentObjectStatus.Members.DBServers[0].IsInitialized = true testCase.createTestPodData(deployment, api.ServerGroupDBServers, firstDBServerStatus) }, ExpectedEvent: "member dbserver is created", ExpectedPod: core.Pod{ Spec: core.PodSpec{ Volumes: []core.Volume{ k8sutil.CreateVolumeEmptyDir(shared.ArangodVolumeName), createExampleVolume("volume").Volume(), createExampleVolume("volume2").Volume(), }, Containers: []core.Container{ { Name: shared.ServerContainerName, Image: testImage, Command: createTestCommandForDBServer(firstDBServerStatus.ID, false, false, false), Ports: createTestPorts(api.ServerGroupAgents), Resources: emptyResources, VolumeMounts: []core.VolumeMount{ k8sutil.ArangodVolumeMount(), }, 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: "DBserver POD with Volume Mount", ArangoDeployment: &api.ArangoDeployment{ Spec: api.DeploymentSpec{ Image: util.NewType[string](testImage), Authentication: noAuthentication, TLS: noTLS, DBServers: api.ServerGroupSpec{ Volumes: []api.ServerGroupSpecVolume{ createExampleVolume("volume"), }, VolumeMounts: []api.ServerGroupSpecVolumeMount{ createExampleVolumeMount("volume"), }, }, }, }, Helper: func(t *testing.T, deployment *Deployment, testCase *testCaseStruct) { deployment.currentObjectStatus = &api.DeploymentStatus{ Members: api.DeploymentStatusMembers{ DBServers: api.MemberStatusList{ firstDBServerStatus, }, }, Images: createTestImages(false), } deployment.currentObjectStatus.Members.DBServers[0].IsInitialized = true testCase.createTestPodData(deployment, api.ServerGroupDBServers, firstDBServerStatus) }, ExpectedEvent: "member dbserver is created", ExpectedPod: core.Pod{ Spec: core.PodSpec{ Volumes: []core.Volume{ k8sutil.CreateVolumeEmptyDir(shared.ArangodVolumeName), createExampleVolume("volume").Volume(), }, Containers: []core.Container{ { Name: shared.ServerContainerName, Image: testImage, Command: createTestCommandForDBServer(firstDBServerStatus.ID, false, false, false), Ports: createTestPorts(api.ServerGroupAgents), Resources: emptyResources, VolumeMounts: []core.VolumeMount{ k8sutil.ArangodVolumeMount(), createExampleVolumeMount("volume").VolumeMount(), }, 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, ""), }, }, }, } runTestCases(t, testCases...) }