Description
What happened?
A panic crash happens when running the following command, the revision 200 does not exists
Command:
$ kubectl -n x rollout history deployment x-api --revision 200 -o yaml
Panic output:
panic: reflect: call of reflect.Value.Type on zero Value
goroutine 1 [running]:
reflect.Value.typeSlow({0x0?, 0x0?, 0x1400057d2b8?})
reflect/value.go:2385 +0x134
reflect.Value.Type(...)
reflect/value.go:2380
k8s.io/cli-runtime/pkg/printers.(*YAMLPrinter).PrintObj(0x1400019c278, {0x0, 0x0}, {0x104d21b98, 0x140001ac028})
k8s.io/cli-runtime/pkg/printers/yaml.go:45 +0x104
k8s.io/cli-runtime/pkg/printers.(*OmitManagedFieldsPrinter).PrintObj(0x1400057d3e8?, {0x0?, 0x0?}, {0x104d21b98?, 0x140001ac028?})
k8s.io/cli-runtime/pkg/printers/managedfields.go:47 +0x110
k8s.io/cli-runtime/pkg/printers.(*TypeSetterPrinter).PrintObj(0x1049e2ea0?, {0x0?, 0x0?}, {0x104d21b98?, 0x140001ac028?})
k8s.io/cli-runtime/pkg/printers/typesetter.go:43 +0x19c
k8s.io/kubectl/pkg/cmd/rollout.(*RolloutHistoryOptions).Run.func1(0x140005f6a80, {0x0?, 0x0?})
k8s.io/kubectl/pkg/cmd/rollout/rollout_history.go:180 +0x14c
k8s.io/cli-runtime/pkg/resource.(*DecoratedVisitor).Visit.DecoratedVisitor.Visit.func1(0x140005f6a80, {0x0?, 0x0?})
k8s.io/cli-runtime/pkg/resource/visitor.go:368 +0xc4
k8s.io/cli-runtime/pkg/resource.ContinueOnErrorVisitor.Visit.func1(0x14000967778?, {0x0?, 0x0?})
k8s.io/cli-runtime/pkg/resource/visitor.go:392 +0xf4
k8s.io/cli-runtime/pkg/resource.(*FlattenListVisitor).Visit.FlattenListVisitor.Visit.func1(0x14000967838?, {0x0?, 0x0?})
k8s.io/cli-runtime/pkg/resource/visitor.go:429 +0xc4
k8s.io/cli-runtime/pkg/resource.(*Info).Visit(0x14000967868?, 0x103b29dd8?)
k8s.io/cli-runtime/pkg/resource/visitor.go:96 +0x2c
k8s.io/cli-runtime/pkg/resource.VisitorList.Visit(...)
k8s.io/cli-runtime/pkg/resource/visitor.go:198
k8s.io/cli-runtime/pkg/resource.FlattenListVisitor.Visit(...)
k8s.io/cli-runtime/pkg/resource/visitor.go:424
k8s.io/cli-runtime/pkg/resource.ContinueOnErrorVisitor.Visit({{0x104d23640?, 0x14000272ae0?}}, 0x14000698b40)
k8s.io/cli-runtime/pkg/resource/visitor.go:387 +0xa0
k8s.io/cli-runtime/pkg/resource.DecoratedVisitor.Visit(...)
k8s.io/cli-runtime/pkg/resource/visitor.go:359
k8s.io/cli-runtime/pkg/resource.(*Result).Visit(0x1400074cc00, 0x1?)
k8s.io/cli-runtime/pkg/resource/result.go:99 +0x48
k8s.io/kubectl/pkg/cmd/rollout.(*RolloutHistoryOptions).Run(0x14000526ee0)
k8s.io/kubectl/pkg/cmd/rollout/rollout_history.go:164 +0x344
k8s.io/kubectl/pkg/cmd/rollout.NewCmdRolloutHistory.func1(0x140007af808?, {0x140008af280?, 0x2?, 0x8?})
k8s.io/kubectl/pkg/cmd/rollout/rollout_history.go:93 +0x74
github.com/spf13/cobra.(*Command).execute(0x140007af808, {0x140008af200, 0x8, 0x8})
github.com/spf13/[email protected]/command.go:989 +0x818
github.com/spf13/cobra.(*Command).ExecuteC(0x140002d3508)
github.com/spf13/[email protected]/command.go:1117 +0x344
github.com/spf13/cobra.(*Command).Execute(...)
github.com/spf13/[email protected]/command.go:1041
k8s.io/component-base/cli.run(0x140002d3508)
k8s.io/component-base/cli/run.go:143 +0x20c
k8s.io/component-base/cli.RunNoErrOutput(...)
k8s.io/component-base/cli/run.go:82
main.main()
k8s.io/kubernetes/cmd/kubectl/kubectl.go:30 +0x20
What did you expect to happen?
I think the expected behaviour should be an error message indicating that the requested revision does not exist, similar to this error:
kubectl -n x rollout history deployment x-api --revision 200
# error: unable to find the specified revision
How can we reproduce it (as minimally and precisely as possible)?
Simply try to get a non-existing revision as yaml or json file. as previously mentioned:
Command:
$ kubectl -n x rollout history deployment x-api --revision 200 -o yaml
Anything else we need to know?
No response
Kubernetes version
$ kubectl version
Client Version: v1.32.2
Kustomize Version: v5.5.0
Server Version: v1.31.4
Cloud provider
NONE
OS version
MacOS 15.3.1 (24D70)
Install tools
No response
Container runtime (CRI) and version (if applicable)
No response
Related plugins (CNI, CSI, ...) and versions (if applicable)
No response
Metadata
Metadata
Assignees
Labels
Type
Projects
Status
Needs Triage