Skip to content

Unhandled panic crash on rollout_history printer.PrintObj #1724

Open
kubernetes/kubernetes
#130503
@tahacodes

Description

@tahacodes

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

No one assigned

    Labels

    kind/bugCategorizes issue or PR as related to a bug.sig/cliCategorizes an issue or PR as relevant to SIG CLI.triage/acceptedIndicates an issue or PR is ready to be actively worked on.

    Type

    No type

    Projects

    • Status

      Needs Triage

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions