Signed-off-by: Shiming Zhang <wzshiming@foxmail.com>

Kubernetes-commit: 2c9f02c3290ce7e8bcdc94bea7d96edf92834cd7
This commit is contained in:
Shiming Zhang 2021-04-09 13:07:46 +08:00 committed by Kubernetes Publisher
parent 7801ce34b4
commit ce9fcb2fe0

View File

@ -322,3 +322,90 @@ func TestGetWithExactMatch(t *testing.T) {
errNotFound = errors.NewNotFound(gvr.GroupResource(), "pod")
assert.EqualError(t, err, errNotFound.Error())
}
func Test_resourceCovers(t *testing.T) {
type args struct {
resource string
action Action
}
tests := []struct {
name string
args args
want bool
}{
{
args: args{
resource: "*",
action: ActionImpl{},
},
want: true,
},
{
args: args{
resource: "serviceaccounts",
action: ActionImpl{},
},
want: false,
},
{
args: args{
resource: "serviceaccounts",
action: ActionImpl{
Resource: schema.GroupVersionResource{
Resource: "serviceaccounts",
},
},
},
want: true,
},
{
args: args{
resource: "serviceaccounts/token",
action: ActionImpl{
Resource: schema.GroupVersionResource{},
},
},
want: false,
},
{
args: args{
resource: "serviceaccounts/token",
action: ActionImpl{
Resource: schema.GroupVersionResource{
Resource: "serviceaccounts",
},
},
},
want: false,
},
{
args: args{
resource: "serviceaccounts/token",
action: ActionImpl{
Resource: schema.GroupVersionResource{},
Subresource: "token",
},
},
want: false,
},
{
args: args{
resource: "serviceaccounts/token",
action: ActionImpl{
Resource: schema.GroupVersionResource{
Resource: "serviceaccounts",
},
Subresource: "token",
},
},
want: true,
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if got := resourceCovers(tt.args.resource, tt.args.action); got != tt.want {
t.Errorf("resourceCovers() = %v, want %v", got, tt.want)
}
})
}
}