Skip to content

Commit

Permalink
Merge pull request kubernetes#128682 from tallclair/ippr-beta
Browse files Browse the repository at this point in the history
[FG:InPlacePodVerticalScaling] Graduate to Beta
  • Loading branch information
k8s-ci-robot authored Nov 12, 2024
2 parents 8115bac + 2935b10 commit 79e5584
Show file tree
Hide file tree
Showing 8 changed files with 31 additions and 11 deletions.
17 changes: 17 additions & 0 deletions pkg/apis/core/fuzzer/fuzzer.go
Original file line number Diff line number Diff line change
Expand Up @@ -309,6 +309,23 @@ var Funcs = func(codecs runtimeserializer.CodecFactory) []interface{} {
c.FuzzNoCustom(ct) // fuzz self without calling this function again
ct.TerminationMessagePath = "/" + ct.TerminationMessagePath // Must be non-empty
ct.TerminationMessagePolicy = "File"
// Match defaulting in pkg/apis/core/v1/defaults.go.
_, hasCPUReq := ct.Resources.Requests[core.ResourceCPU]
_, hasCPULim := ct.Resources.Limits[core.ResourceCPU]
_, hasMemReq := ct.Resources.Requests[core.ResourceMemory]
_, hasMemLim := ct.Resources.Limits[core.ResourceMemory]
if hasCPUReq || hasCPULim {
ct.ResizePolicy = append(ct.ResizePolicy, core.ContainerResizePolicy{
ResourceName: core.ResourceCPU,
RestartPolicy: core.NotRequired,
})
}
if hasMemReq || hasMemLim {
ct.ResizePolicy = append(ct.ResizePolicy, core.ContainerResizePolicy{
ResourceName: core.ResourceMemory,
RestartPolicy: core.NotRequired,
})
}
},
func(ep *core.EphemeralContainer, c fuzz.Continue) {
c.FuzzNoCustom(ep) // fuzz self without calling this function again
Expand Down
1 change: 1 addition & 0 deletions pkg/features/versioned_kube_features.go
Original file line number Diff line number Diff line change
Expand Up @@ -404,6 +404,7 @@ var defaultVersionedKubernetesFeatureGates = map[featuregate.Feature]featuregate

InPlacePodVerticalScaling: {
{Version: version.MustParse("1.27"), Default: false, PreRelease: featuregate.Alpha},
{Version: version.MustParse("1.32"), Default: true, PreRelease: featuregate.Beta},
},

InPlacePodVerticalScalingAllocatedStatus: {
Expand Down
5 changes: 5 additions & 0 deletions pkg/kubelet/kuberuntime/kuberuntime_manager_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -1264,6 +1264,11 @@ func verifyActions(t *testing.T, expected, actual *podActions, desc string) {
actual.ContainersToKill[k] = info
}
}

if expected.ContainersToUpdate == nil && actual.ContainersToUpdate != nil {
// No need to distinguish empty and nil maps for the test.
expected.ContainersToUpdate = map[v1.ResourceName][]containerToUpdateInfo{}
}
assert.Equal(t, expected, actual, desc)
}

Expand Down
4 changes: 1 addition & 3 deletions pkg/kubelet/status/status_manager.go
Original file line number Diff line number Diff line change
Expand Up @@ -179,6 +179,7 @@ func NewManager(kubeClient clientset.Interface, podManager PodManager, podDeleti
podDeletionSafety: podDeletionSafety,
podStartupLatencyHelper: podStartupLatencyHelper,
stateFileDirectory: stateFileDirectory,
state: state.NewNoopStateCheckpoint(),
}
}

Expand All @@ -202,9 +203,6 @@ func isPodStatusByKubeletEqual(oldStatus, status *v1.PodStatus) bool {
}

func (m *manager) Start() {
// Initialize m.state to no-op state checkpoint manager
m.state = state.NewNoopStateCheckpoint()

// Create pod allocation checkpoint manager even if client is nil so as to allow local get/set of AllocatedResources & Resize
if utilfeature.DefaultFeatureGate.Enabled(features.InPlacePodVerticalScaling) {
stateImpl, err := state.NewStateCheckpoint(m.stateFileDirectory, podStatusManagerStateFile)
Expand Down
3 changes: 1 addition & 2 deletions test/e2e/common/node/pod_resize.go
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,6 @@ import (
"k8s.io/apimachinery/pkg/api/resource"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/types"
"k8s.io/kubernetes/test/e2e/feature"
"k8s.io/kubernetes/test/e2e/framework"
e2enode "k8s.io/kubernetes/test/e2e/framework/node"
e2epod "k8s.io/kubernetes/test/e2e/framework/pod"
Expand Down Expand Up @@ -1174,7 +1173,7 @@ func doPodResizeErrorTests(f *framework.Framework) {
// Above tests are performed by doSheduletTests() and doPodResizeResourceQuotaTests()
// in test/e2e/node/pod_resize.go

var _ = SIGDescribe("Pod InPlace Resize Container", framework.WithSerial(), feature.InPlacePodVerticalScaling, "[NodeAlphaFeature:InPlacePodVerticalScaling]", func() {
var _ = SIGDescribe("Pod InPlace Resize Container", framework.WithSerial(), func() {
f := framework.NewDefaultFramework("pod-resize-tests")

ginkgo.BeforeEach(func(ctx context.Context) {
Expand Down
3 changes: 0 additions & 3 deletions test/e2e/feature/feature.go
Original file line number Diff line number Diff line change
Expand Up @@ -186,9 +186,6 @@ var (
// Ingress.networking.k8s.io to be present.
Ingress = framework.WithFeature(framework.ValidFeatures.Add("Ingress"))

// TODO: document the feature (owning SIG, when to use this feature for a test)
InPlacePodVerticalScaling = framework.WithFeature(framework.ValidFeatures.Add("InPlacePodVerticalScaling"))

// Owner: sig-network
// Marks tests that require a cluster with dual-stack pod and service networks.
IPv6DualStack = framework.WithFeature(framework.ValidFeatures.Add("IPv6DualStack"))
Expand Down
5 changes: 2 additions & 3 deletions test/e2e/node/pod_resize.go
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,6 @@ import (
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/types"
resourceapi "k8s.io/kubernetes/pkg/api/v1/resource"
"k8s.io/kubernetes/test/e2e/feature"
"k8s.io/kubernetes/test/e2e/framework"
e2enode "k8s.io/kubernetes/test/e2e/framework/node"
e2epod "k8s.io/kubernetes/test/e2e/framework/pod"
Expand Down Expand Up @@ -356,7 +355,7 @@ func doPodResizeSchedulerTests(f *framework.Framework) {
})
}

var _ = SIGDescribe(framework.WithSerial(), "Pod InPlace Resize Container (scheduler-focused)", feature.InPlacePodVerticalScaling, func() {
var _ = SIGDescribe(framework.WithSerial(), "Pod InPlace Resize Container (scheduler-focused)", func() {
f := framework.NewDefaultFramework("pod-resize-scheduler-tests")
ginkgo.BeforeEach(func(ctx context.Context) {
node, err := e2enode.GetRandomReadySchedulableNode(ctx, f.ClientSet)
Expand All @@ -368,7 +367,7 @@ var _ = SIGDescribe(framework.WithSerial(), "Pod InPlace Resize Container (sched
doPodResizeSchedulerTests(f)
})

var _ = SIGDescribe("Pod InPlace Resize Container", feature.InPlacePodVerticalScaling, func() {
var _ = SIGDescribe("Pod InPlace Resize Container", func() {
f := framework.NewDefaultFramework("pod-resize-tests")

ginkgo.BeforeEach(func(ctx context.Context) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -540,6 +540,10 @@
lockToDefault: false
preRelease: Alpha
version: "1.27"
- default: true
lockToDefault: false
preRelease: Beta
version: "1.32"
- name: InPlacePodVerticalScalingAllocatedStatus
versionedSpecs:
- default: false
Expand Down

0 comments on commit 79e5584

Please sign in to comment.