diff --git a/lib/auth/auth_with_roles_test.go b/lib/auth/auth_with_roles_test.go index 4d45cf82cd5a5..60ab8b4fe0fd4 100644 --- a/lib/auth/auth_with_roles_test.go +++ b/lib/auth/auth_with_roles_test.go @@ -4457,6 +4457,14 @@ func TestListUnifiedResources_KindsFilter(t *testing.T) { r := resource.GetDatabaseServer() require.Equal(t, types.KindDatabaseServer, r.GetKind()) } + + // Check for invalid sort error message + _, err = clt.ListUnifiedResources(ctx, &proto.ListUnifiedResourcesRequest{ + Kinds: []string{types.KindDatabase}, + Limit: 5, + SortBy: types.SortBy{}, + }) + require.ErrorContains(t, err, "sort field is required") } func TestListUnifiedResources_WithPinnedResources(t *testing.T) { diff --git a/lib/services/unified_resource.go b/lib/services/unified_resource.go index 2d17948a6bb89..48885aecb9745 100644 --- a/lib/services/unified_resource.go +++ b/lib/services/unified_resource.go @@ -195,8 +195,10 @@ func (c *UnifiedResourceCache) getSortTree(sortField string) (*btree.BTreeG[*ite return c.nameTree, nil case sortByKind: return c.typeTree, nil + case "": + return nil, trace.BadParameter("sort field is required") default: - return nil, trace.NotImplemented("sorting by %v is not supporting in unified resources", sortField) + return nil, trace.NotImplemented("sorting by %v is not supported in unified resources", sortField) } }