Skip to content

Commit

Permalink
apiserver: add tests to verify login via various methods
Browse files Browse the repository at this point in the history
Add tests which check that kube-apiserver is reachable via service
network, external and internal api endpoints
  • Loading branch information
vrutkovs committed Dec 5, 2024
1 parent cef11fd commit e1fd7a8
Show file tree
Hide file tree
Showing 2 changed files with 85 additions and 0 deletions.
79 changes: 79 additions & 0 deletions test/extended/apiserver/access.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,79 @@
package apiserver

import (
"context"
"fmt"
"net/url"
"regexp"
"time"

g "github.com/onsi/ginkgo/v2"
o "github.com/onsi/gomega"

metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/util/wait"
"k8s.io/client-go/util/retry"
admissionapi "k8s.io/pod-security-admission/api"

configv1 "github.com/openshift/api/config/v1"

exutil "github.com/openshift/origin/test/extended/util"
"github.com/openshift/origin/test/extended/util/image"
)

var _ = g.Describe("[Conformance][sig-api-machinery][Feature:APIServer] kube-apiserver should be accessible via", func() {
defer g.GinkgoRecover()
oc := exutil.NewCLIWithPodSecurityLevel("apiserver", admissionapi.LevelPrivileged)

for description, apiPath := range map[string]string{
"service network": "$KUBERNETES_SERVICE_HOST:$KUBERNETES_SERVICE_PORT",
"api-int": "api-int",
"api-ext": "api-ext",
} {
g.It(fmt.Sprintf("%s endpoint", description), func() {
// external controlplane topology doesn't have master nodes
controlPlaneTopology, err := exutil.GetControlPlaneTopology(oc)
o.Expect(err).NotTo(o.HaveOccurred())
if *controlPlaneTopology == configv1.ExternalTopologyMode {
g.Skip("ExternalControlPlaneTopology doesn't have master node kubeconfigs")
}
// get external/internal URLs
infra, err := oc.AdminConfigClient().ConfigV1().Infrastructures().Get(context.Background(), "cluster", metav1.GetOptions{})
o.Expect(err).NotTo(o.HaveOccurred())

if apiPath == "api-ext" {
externalAPIUrl, err := url.Parse(infra.Status.APIServerURL)
o.Expect(err).NotTo(o.HaveOccurred())
apiPath = externalAPIUrl.Host
}
if apiPath == "api-int" {
internalAPIUrl, err := url.Parse(infra.Status.APIServerInternalURL)
o.Expect(err).NotTo(o.HaveOccurred())
apiPath = internalAPIUrl.Host
}
err = retry.OnError(
wait.Backoff{
Duration: 2 * time.Second,
Steps: 3,
Factor: 5.0,
Jitter: 0.1,
},
func(err error) bool {
// retry error when kube-apiserver was temporarily unavailable, this matches oc error coming from:
// https://github.com/kubernetes/kubernetes/blob/cbb5ea8210596ada1efce7e7a271ca4217ae598e/staging/src/k8s.io/kubectl/pkg/cmd/util/helpers.go#L237-L243
matched, _ := regexp.MatchString("The connection to the server .+ was refused - did you specify the right host or port", err.Error())
return !matched
},
func() error {
pod, err := exutil.NewPodExecutor(oc, "kube-apiserver-access", image.ShellImage())
o.Expect(err).NotTo(o.HaveOccurred())
cmd := fmt.Sprintf("curl -kLs https://%s/readyz", apiPath)
out, err := pod.Exec(cmd)
o.Expect(err).NotTo(o.HaveOccurred())
o.Expect(out).To(o.ContainSubstring("ok"))
return nil
})
o.Expect(err).NotTo(o.HaveOccurred())
})
}
})

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

0 comments on commit e1fd7a8

Please sign in to comment.