2019-03-14 15:56:06 +01:00
|
|
|
package ingress
|
2019-02-21 23:08:05 +01:00
|
|
|
|
|
|
|
import (
|
2019-03-14 15:56:06 +01:00
|
|
|
"fmt"
|
2021-03-04 20:08:03 +01:00
|
|
|
"os"
|
2019-03-14 15:56:06 +01:00
|
|
|
|
2020-07-21 15:32:04 +02:00
|
|
|
"github.com/hashicorp/go-version"
|
2023-02-03 15:24:05 +01:00
|
|
|
"github.com/traefik/traefik/v3/pkg/provider/kubernetes/k8s"
|
2019-02-21 23:08:05 +01:00
|
|
|
corev1 "k8s.io/api/core/v1"
|
2021-03-15 11:16:04 +01:00
|
|
|
networkingv1 "k8s.io/api/networking/v1"
|
2020-07-15 10:18:03 -07:00
|
|
|
networkingv1beta1 "k8s.io/api/networking/v1beta1"
|
2019-02-21 23:08:05 +01:00
|
|
|
)
|
|
|
|
|
2019-03-14 15:56:06 +01:00
|
|
|
var _ Client = (*clientMock)(nil)
|
|
|
|
|
2019-02-21 23:08:05 +01:00
|
|
|
type clientMock struct {
|
2021-03-15 11:16:04 +01:00
|
|
|
ingresses []*networkingv1.Ingress
|
2021-01-28 15:08:04 +01:00
|
|
|
services []*corev1.Service
|
|
|
|
secrets []*corev1.Secret
|
|
|
|
endpoints []*corev1.Endpoints
|
2021-05-17 16:50:09 +02:00
|
|
|
ingressClasses []*networkingv1.IngressClass
|
2020-07-15 10:18:03 -07:00
|
|
|
|
2020-07-21 15:32:04 +02:00
|
|
|
serverVersion *version.Version
|
2019-02-21 23:08:05 +01:00
|
|
|
|
|
|
|
apiServiceError error
|
|
|
|
apiSecretError error
|
|
|
|
apiEndpointsError error
|
|
|
|
apiIngressStatusError error
|
2019-03-14 15:56:06 +01:00
|
|
|
|
|
|
|
watchChan chan interface{}
|
|
|
|
}
|
|
|
|
|
2020-07-21 15:32:04 +02:00
|
|
|
func newClientMock(serverVersion string, paths ...string) clientMock {
|
|
|
|
c := clientMock{}
|
|
|
|
|
|
|
|
c.serverVersion = version.Must(version.NewVersion(serverVersion))
|
2019-03-14 15:56:06 +01:00
|
|
|
|
|
|
|
for _, path := range paths {
|
2021-03-04 20:08:03 +01:00
|
|
|
yamlContent, err := os.ReadFile(path)
|
2019-03-14 15:56:06 +01:00
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
k8sObjects := k8s.MustParseYaml(yamlContent)
|
|
|
|
for _, obj := range k8sObjects {
|
|
|
|
switch o := obj.(type) {
|
|
|
|
case *corev1.Service:
|
|
|
|
c.services = append(c.services, o)
|
|
|
|
case *corev1.Secret:
|
|
|
|
c.secrets = append(c.secrets, o)
|
|
|
|
case *corev1.Endpoints:
|
|
|
|
c.endpoints = append(c.endpoints, o)
|
2020-08-21 11:12:04 +02:00
|
|
|
case *networkingv1beta1.Ingress:
|
2021-03-15 11:16:04 +01:00
|
|
|
ing, err := toNetworkingV1(o)
|
2020-01-16 10:14:06 +01:00
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
2021-03-15 11:16:04 +01:00
|
|
|
addServiceFromV1Beta1(ing, *o)
|
2020-01-16 10:14:06 +01:00
|
|
|
c.ingresses = append(c.ingresses, ing)
|
2021-03-15 11:16:04 +01:00
|
|
|
case *networkingv1.Ingress:
|
|
|
|
c.ingresses = append(c.ingresses, o)
|
2020-07-15 10:18:03 -07:00
|
|
|
case *networkingv1beta1.IngressClass:
|
2021-05-17 16:50:09 +02:00
|
|
|
ic, err := toNetworkingV1IngressClass(o)
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
c.ingressClasses = append(c.ingressClasses, ic)
|
|
|
|
case *networkingv1.IngressClass:
|
2021-01-28 15:08:04 +01:00
|
|
|
c.ingressClasses = append(c.ingressClasses, o)
|
2019-03-14 15:56:06 +01:00
|
|
|
default:
|
|
|
|
panic(fmt.Sprintf("Unknown runtime object %+v %T", o, o))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return c
|
2019-02-21 23:08:05 +01:00
|
|
|
}
|
|
|
|
|
2021-03-15 11:16:04 +01:00
|
|
|
func (c clientMock) GetIngresses() []*networkingv1.Ingress {
|
2019-02-21 23:08:05 +01:00
|
|
|
return c.ingresses
|
|
|
|
}
|
|
|
|
|
2021-07-19 12:06:07 -06:00
|
|
|
func (c clientMock) GetServerVersion() *version.Version {
|
|
|
|
return c.serverVersion
|
2020-07-15 10:18:03 -07:00
|
|
|
}
|
|
|
|
|
2019-02-21 23:08:05 +01:00
|
|
|
func (c clientMock) GetService(namespace, name string) (*corev1.Service, bool, error) {
|
|
|
|
if c.apiServiceError != nil {
|
|
|
|
return nil, false, c.apiServiceError
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, service := range c.services {
|
|
|
|
if service.Namespace == namespace && service.Name == name {
|
|
|
|
return service, true, nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil, false, c.apiServiceError
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c clientMock) GetEndpoints(namespace, name string) (*corev1.Endpoints, bool, error) {
|
|
|
|
if c.apiEndpointsError != nil {
|
|
|
|
return nil, false, c.apiEndpointsError
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, endpoints := range c.endpoints {
|
|
|
|
if endpoints.Namespace == namespace && endpoints.Name == name {
|
|
|
|
return endpoints, true, nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return &corev1.Endpoints{}, false, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c clientMock) GetSecret(namespace, name string) (*corev1.Secret, bool, error) {
|
|
|
|
if c.apiSecretError != nil {
|
|
|
|
return nil, false, c.apiSecretError
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, secret := range c.secrets {
|
|
|
|
if secret.Namespace == namespace && secret.Name == name {
|
|
|
|
return secret, true, nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil, false, nil
|
|
|
|
}
|
|
|
|
|
2021-05-17 16:50:09 +02:00
|
|
|
func (c clientMock) GetIngressClasses() ([]*networkingv1.IngressClass, error) {
|
2021-01-28 15:08:04 +01:00
|
|
|
return c.ingressClasses, nil
|
2020-07-15 10:18:03 -07:00
|
|
|
}
|
|
|
|
|
2019-06-17 11:48:05 +02:00
|
|
|
func (c clientMock) WatchAll(namespaces []string, stopCh <-chan struct{}) (<-chan interface{}, error) {
|
2019-02-21 23:08:05 +01:00
|
|
|
return c.watchChan, nil
|
|
|
|
}
|
|
|
|
|
2021-03-15 11:16:04 +01:00
|
|
|
func (c clientMock) UpdateIngressStatus(_ *networkingv1.Ingress, _ []corev1.LoadBalancerIngress) error {
|
2019-02-21 23:08:05 +01:00
|
|
|
return c.apiIngressStatusError
|
|
|
|
}
|