Skip to content

Commit

Permalink
Add tests for Pods owner that doesn't implement /scale
Browse files Browse the repository at this point in the history
  • Loading branch information
voelzmo committed Apr 17, 2024
1 parent 08b30b8 commit 5a12cc9
Show file tree
Hide file tree
Showing 2 changed files with 25 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -389,6 +389,16 @@ func TestControllerFetcher(t *testing.T) {
expectedKey: nil,
expectedError: fmt.Errorf("Unhandled targetRef v1 / Node / node, last error node is not a valid owner"),
},
{
name: "custom resource with no scale subresource",
key: &ControllerKeyWithAPIVersion{
ApiVersion: "Foo/Foo", ControllerKey: ControllerKey{
Name: "bah", Kind: "Foo", Namespace: testNamespace},
},
objects: []runtime.Object{},
expectedKey: nil, // Pod owner does not support scale subresource so should return nil"
expectedError: nil,
},
} {
t.Run(tc.name, func(t *testing.T) {
f := simpleControllerFetcher()
Expand Down
15 changes: 15 additions & 0 deletions vertical-pod-autoscaler/pkg/utils/vpa/api_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -139,6 +139,15 @@ func TestPodMatchesVPA(t *testing.T) {
}
}

type NilControllerFetcher struct{}

// FindTopMostWellKnownOrScalable returns the same key for that fake implementation
func (f NilControllerFetcher) FindTopMostWellKnownOrScalable(_ *controllerfetcher.ControllerKeyWithAPIVersion) (*controllerfetcher.ControllerKeyWithAPIVersion, error) {
return nil, nil
}

var _ controllerfetcher.ControllerFetcher = &NilControllerFetcher{}

func TestGetControllingVPAForPod(t *testing.T) {
isController := true
pod := test.Pod().WithName("test-pod").AddContainer(test.Container().WithName(containerName).WithCPURequest(resource.MustParse("1")).WithMemRequest(resource.MustParse("100M")).Get()).Get()
Expand Down Expand Up @@ -171,6 +180,12 @@ func TestGetControllingVPAForPod(t *testing.T) {
{nonMatchingVPA, parseLabelSelector("app = other")},
}, &controllerfetcher.FakeControllerFetcher{})
assert.Equal(t, vpaA, chosen.Vpa)

// For some Pods (which are *not* under VPA), controllerFetcher.FindTopMostWellKnownOrScalable will return `nil`, e.g. when the Pod owner is a custom resource, which doesn't implement the /scale subresource
// See pkg/target/controller_fetcher/controller_fetcher_test.go:393 for testing this behavior
// This test case makes sure that GetControllingVPAForPod will just return `nil` in that case as well
chosen = GetControllingVPAForPod(pod, []*VpaWithSelector{{vpaA, parseLabelSelector("app = testingApp")}}, &NilControllerFetcher{})
assert.Nil(t, chosen)
}

func TestGetContainerResourcePolicy(t *testing.T) {
Expand Down

0 comments on commit 5a12cc9

Please sign in to comment.