From 487ed95f7842159f55727d510742ddcef9a900c9 Mon Sep 17 00:00:00 2001 From: Christian Schlotter Date: Mon, 11 Mar 2024 13:07:20 +0100 Subject: [PATCH] test/inmemory: use port only to identify the wcl to make port-forwarding work --- .../infrastructure/inmemory/pkg/server/mux.go | 38 ++++++++++++------- 1 file changed, 24 insertions(+), 14 deletions(-) diff --git a/test/infrastructure/inmemory/pkg/server/mux.go b/test/infrastructure/inmemory/pkg/server/mux.go index 91c11fe543e1..2fd178375cf1 100644 --- a/test/infrastructure/inmemory/pkg/server/mux.go +++ b/test/infrastructure/inmemory/pkg/server/mux.go @@ -108,8 +108,8 @@ type WorkloadClustersMux struct { debugServer http.Server muxServer http.Server workloadClusterListeners map[string]*WorkloadClusterListener - // workloadClusterNameByHost maps from Host to workload cluster name. - workloadClusterNameByHost map[string]string + // workloadClusterNameByPort maps from Port to workload cluster name. + workloadClusterNameByPort map[string]string lock sync.RWMutex log logr.Logger @@ -131,7 +131,7 @@ func NewWorkloadClustersMux(manager inmemoryruntime.Manager, host string, opts . portIndex: options.MinPort, manager: manager, workloadClusterListeners: map[string]*WorkloadClusterListener{}, - workloadClusterNameByHost: map[string]string{}, + workloadClusterNameByPort: map[string]string{}, log: log.Log, } @@ -169,7 +169,12 @@ func (m *WorkloadClustersMux) mixedHandler() http.Handler { resourceGroupResolver := func(host string) (string, error) { m.lock.RLock() defer m.lock.RUnlock() - wclName, ok := m.workloadClusterNameByHost[host] + + hostPort := strings.Split(host, ":") + if len(hostPort) != 2 { + return "", errors.Errorf("failed to extract port from host %s", host) + } + wclName, ok := m.workloadClusterNameByPort[hostPort[1]] if !ok { return "", errors.Errorf("failed to get workloadClusterListener for host %s", host) } @@ -211,10 +216,15 @@ func (m *WorkloadClustersMux) getCertificate(info *tls.ClientHelloInfo) (*tls.Ce defer m.lock.RUnlock() // Identify which workloadCluster/resourceGroup a request targets to. - hostPort := info.Conn.LocalAddr().String() - wclName, ok := m.workloadClusterNameByHost[hostPort] + hostPort := strings.Split(info.Conn.LocalAddr().String(), ":") + if len(hostPort) != 2 { + return nil, errors.Errorf("failed to extract port from LocalAddr %s", info.Conn.LocalAddr()) + } + port := hostPort[1] + + wclName, ok := m.workloadClusterNameByPort[port] if !ok { - err := errors.Errorf("failed to get listener name for workload cluster serving on %s", hostPort) + err := errors.Errorf("failed to get listener name for workload cluster serving on %s", port) m.log.Error(err, "Error resolving certificates") return nil, err } @@ -222,7 +232,7 @@ func (m *WorkloadClustersMux) getCertificate(info *tls.ClientHelloInfo) (*tls.Ce // Gets the listener config for the target workloadCluster. wcl, ok := m.workloadClusterListeners[wclName] if !ok { - err := errors.Errorf("failed to get listener with name %s for workload cluster serving on %s", wclName, hostPort) + err := errors.Errorf("failed to get listener with name %s for workload cluster serving on %s", wclName, port) m.log.Error(err, "Error resolving certificates") return nil, err } @@ -231,12 +241,12 @@ func (m *WorkloadClustersMux) getCertificate(info *tls.ClientHelloInfo) (*tls.Ce // NOTE: the port forward call to etcd sets the server name to the name of the targeted etcd pod, // which is also the name of the corresponding etcd member. if wcl.etcdMembers.Has(info.ServerName) { - m.log.V(4).Info("Using etcd serving certificate", "listenerName", wcl, "host", hostPort, "etcdPod", info.ServerName) + m.log.V(4).Info("Using etcd serving certificate", "listenerName", wcl, "host", port, "etcdPod", info.ServerName) return wcl.etcdServingCertificates[info.ServerName], nil } // Otherwise we assume the request targets the API server. - m.log.V(4).Info("Using API server serving certificate", "listenerName", wcl, "host", hostPort) + m.log.V(4).Info("Using API server serving certificate", "listenerName", wcl, "host", port) return wcl.apiServerServingCertificate, nil } @@ -320,7 +330,7 @@ func (m *WorkloadClustersMux) initWorkloadClusterListenerWithPortLocked(wclName // NOTE: it is required to add on both maps and keep them in sync // In order to get the resourceGroupResolver to work. m.workloadClusterListeners[wclName] = wcl - m.workloadClusterNameByHost[wcl.HostPort()] = wclName + m.workloadClusterNameByPort[fmt.Sprintf("%d", wcl.Port())] = wclName m.log.Info("Workload cluster listener created", "listenerName", wclName, "address", wcl.Address()) return wcl @@ -432,9 +442,9 @@ func (m *WorkloadClustersMux) AddAPIServer(wclName, podName string, caCert *x509 return nil } - l, err := net.Listen("tcp", wcl.HostPort()) + l, err := net.Listen("tcp", fmt.Sprintf(":%d", wcl.Port())) if err != nil { - return errors.Wrapf(err, "failed to start WorkloadClusterListener %s, %s", wclName, wcl.HostPort()) + return errors.Wrapf(err, "failed to start WorkloadClusterListener %s, %s", wclName, fmt.Sprintf(":%d", wcl.Port())) } wcl.listener = l @@ -603,7 +613,7 @@ func (m *WorkloadClustersMux) DeleteWorkloadClusterListener(wclName string) erro } delete(m.workloadClusterListeners, wclName) - delete(m.workloadClusterNameByHost, wcl.HostPort()) + delete(m.workloadClusterNameByPort, fmt.Sprintf("%d", wcl.Port())) m.log.Info("Workload cluster listener deleted", "listenerName", wclName, "address", wcl.Address()) return nil