diff --git a/testing/fixture_test.go b/testing/fixture_test.go index 6e026756..5aab05aa 100644 --- a/testing/fixture_test.go +++ b/testing/fixture_test.go @@ -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) + } + }) + } +}