github.com/IBM-Blockchain/fabric-operator@v1.0.4/pkg/offering/k8s/ca/override/ingress_test.go (about) 1 /* 2 * Copyright contributors to the Hyperledger Fabric Operator project 3 * 4 * SPDX-License-Identifier: Apache-2.0 5 * 6 * Licensed under the Apache License, Version 2.0 (the "License"); 7 * you may not use this file except in compliance with the License. 8 * You may obtain a copy of the License at: 9 * 10 * http://www.apache.org/licenses/LICENSE-2.0 11 * 12 * Unless required by applicable law or agreed to in writing, software 13 * distributed under the License is distributed on an "AS IS" BASIS, 14 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 15 * See the License for the specific language governing permissions and 16 * limitations under the License. 17 */ 18 19 package override_test 20 21 import ( 22 . "github.com/onsi/ginkgo/v2" 23 . "github.com/onsi/gomega" 24 networkingv1 "k8s.io/api/networking/v1" 25 26 current "github.com/IBM-Blockchain/fabric-operator/api/v1beta1" 27 "github.com/IBM-Blockchain/fabric-operator/pkg/manager/resources" 28 "github.com/IBM-Blockchain/fabric-operator/pkg/offering/k8s/ca/override" 29 "github.com/IBM-Blockchain/fabric-operator/pkg/util" 30 ) 31 32 var _ = Describe("K8s CA Ingress Overrides", func() { 33 var ( 34 err error 35 overrider *override.Override 36 instance *current.IBPCA 37 ingress *networkingv1.Ingress 38 cahost string 39 operhost string 40 ) 41 42 BeforeEach(func() { 43 overrider = &override.Override{} 44 instance = ¤t.IBPCA{ 45 Spec: current.IBPCASpec{ 46 Domain: "test.domain", 47 }, 48 } 49 ingress, err = util.GetIngressFromFile("../../../../../definitions/ca/ingress.yaml") 50 Expect(err).NotTo(HaveOccurred()) 51 52 cahost = instance.Namespace + "-" + instance.Name + "-ca" + "." + instance.Spec.Domain 53 operhost = instance.Namespace + "-" + instance.Name + "-operations" + "." + instance.Spec.Domain 54 }) 55 56 Context("create", func() { 57 It("appropriately overrides the respective values for ingress", func() { 58 err := overrider.Ingress(instance, ingress, resources.Create) 59 Expect(err).NotTo(HaveOccurred()) 60 61 By("setting rule", func() { 62 pathType := networkingv1.PathTypeImplementationSpecific 63 Expect(ingress.Spec.Rules).To(HaveLen(2)) 64 Expect(ingress.Spec.Rules[0]).To(Equal(networkingv1.IngressRule{ 65 Host: cahost, 66 IngressRuleValue: networkingv1.IngressRuleValue{ 67 HTTP: &networkingv1.HTTPIngressRuleValue{ 68 Paths: []networkingv1.HTTPIngressPath{ 69 networkingv1.HTTPIngressPath{ 70 Backend: networkingv1.IngressBackend{ 71 Service: &networkingv1.IngressServiceBackend{ 72 Name: instance.GetName(), 73 Port: networkingv1.ServiceBackendPort{ 74 Name: "http", 75 }, 76 }, 77 }, 78 Path: "/", 79 PathType: &pathType, 80 }, 81 }, 82 }, 83 }, 84 })) 85 Expect(ingress.Spec.Rules[1]).To(Equal(networkingv1.IngressRule{ 86 Host: operhost, 87 IngressRuleValue: networkingv1.IngressRuleValue{ 88 HTTP: &networkingv1.HTTPIngressRuleValue{ 89 Paths: []networkingv1.HTTPIngressPath{ 90 networkingv1.HTTPIngressPath{ 91 Backend: networkingv1.IngressBackend{ 92 Service: &networkingv1.IngressServiceBackend{ 93 Name: instance.GetName(), 94 Port: networkingv1.ServiceBackendPort{ 95 Name: "operations", 96 }, 97 }, 98 }, 99 Path: "/", 100 PathType: &pathType, 101 }, 102 }, 103 }, 104 }, 105 })) 106 }) 107 108 By("setting TLS hosts", func() { 109 Expect(ingress.Spec.TLS).To(HaveLen(2)) 110 Expect(ingress.Spec.TLS[0].Hosts).To(Equal([]string{cahost})) 111 Expect(ingress.Spec.TLS[1].Hosts).To(Equal([]string{operhost})) 112 }) 113 }) 114 }) 115 })