From 15549aa5d9322b5cea0ccf6e8782874e7f1cf6d6 Mon Sep 17 00:00:00 2001 From: Jordan Dubrick Date: Wed, 6 Mar 2024 11:50:11 -0500 Subject: [PATCH] Update Ingress and Hostname (#80) * update ingress hostname Signed-off-by: Jordan Dubrick * update known issues Signed-off-by: Jordan Dubrick --------- Signed-off-by: Jordan Dubrick Signed-off-by: Jordan Dubrick Signed-off-by: thepetk --- README.md | 5 +++ pkg/registry/ingress.go | 8 +++- pkg/registry/ingress_test.go | 85 ++++++++++++++++++++++++++++++++++++ 3 files changed, 97 insertions(+), 1 deletion(-) create mode 100644 pkg/registry/ingress_test.go diff --git a/README.md b/README.md index 900620e..2264479 100644 --- a/README.md +++ b/README.md @@ -174,3 +174,8 @@ make run ENABLE_WEBHOOKS=false ## Contributing Please see our [contributing.md](./CONTRIBUTING.md). + +## Known Issues +- [`make test-integration` times out when running in Minikube](https://github.com/devfile/api/issues/1313) +- [Headless mode field does not update devfile registry state during reconcile](https://github.com/devfile/api/issues/1258) +- [`make bundle` removes `alm-examples` for `DevfileRegistriesList` and `ClusterDevfileRegistriesList` CRDs due to bug with Kustomize](https://github.com/kubernetes-sigs/kustomize/issues/5042) \ No newline at end of file diff --git a/pkg/registry/ingress.go b/pkg/registry/ingress.go index e50b98b..4fab98e 100644 --- a/pkg/registry/ingress.go +++ b/pkg/registry/ingress.go @@ -17,6 +17,8 @@ package registry import ( + "fmt" + registryv1alpha1 "github.com/devfile/registry-operator/api/v1alpha1" networkingv1 "k8s.io/api/networking/v1" "k8s.io/apimachinery/pkg/runtime" @@ -70,5 +72,9 @@ func GenerateIngress(cr *registryv1alpha1.DevfileRegistry, host string, scheme * } func GetDevfileRegistryIngress(cr *registryv1alpha1.DevfileRegistry) string { - return cr.Name + "." + cr.Spec.K8s.IngressDomain + return GetHostname(cr) + "." + cr.Spec.K8s.IngressDomain +} + +func GetHostname(cr *registryv1alpha1.DevfileRegistry) string { + return fmt.Sprintf("%s-%s", cr.Name, cr.Namespace) } diff --git a/pkg/registry/ingress_test.go b/pkg/registry/ingress_test.go new file mode 100644 index 0000000..6b51449 --- /dev/null +++ b/pkg/registry/ingress_test.go @@ -0,0 +1,85 @@ +// +// +// Copyright Red Hat +// +// 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. + +package registry + +import ( + "testing" + + registryv1alpha1 "github.com/devfile/registry-operator/api/v1alpha1" +) + +func TestGetDevfileRegistryIngress(t *testing.T) { + + tests := []struct { + name string + cr registryv1alpha1.DevfileRegistry + want string + }{ + { + name: "Case 1: Correct Conjunction", + cr: registryv1alpha1.DevfileRegistry{ + Spec: registryv1alpha1.DevfileRegistrySpec{ + K8s: registryv1alpha1.DevfileRegistrySpecK8sOnly{ + IngressDomain: "my-domain", + }, + }}, + want: "test-name-test-namespace.my-domain", + }, + } + for _, tt := range tests { + t.Run(tt.name, func(t *testing.T) { + tt.cr.Name = "test-name" + tt.cr.Namespace = "test-namespace" + ingress := GetDevfileRegistryIngress(&tt.cr) + if ingress != tt.want { + t.Errorf("expected: %v got: %v", tt.want, ingress) + } + }) + } + +} + +func TestGetHostname(t *testing.T) { + + tests := []struct { + name string + cr registryv1alpha1.DevfileRegistry + want string + }{ + { + name: "Case 1: Correct Hostname", + cr: registryv1alpha1.DevfileRegistry{ + Spec: registryv1alpha1.DevfileRegistrySpec{ + K8s: registryv1alpha1.DevfileRegistrySpecK8sOnly{ + IngressDomain: "my-domain", + }, + }}, + want: "test-name-test-namespace", + }, + } + for _, tt := range tests { + t.Run(tt.name, func(t *testing.T) { + tt.cr.Name = "test-name" + tt.cr.Namespace = "test-namespace" + hostname := GetHostname(&tt.cr) + if hostname != tt.want { + t.Errorf("expected: %v got: %v", tt.want, hostname) + } + }) + } + +}