Skip to content

Trim warnings for MinLengthAttribute #112111

Open
@sbomer

Description

@sbomer

The following produces warnings on the MinLength attribute instance:

using Microsoft.Extensions.Options;
using System.ComponentModel.DataAnnotations;

var model = new Model { Name = "abcd" };
var result = model.Validate(null, model);
Console.WriteLine(result.Succeeded);

[OptionsValidator]
partial class Model : IValidateOptions<Model> {
    [MinLength(4)]
    public required string Name { get; set; }
}

Program.cs(10,6): warning IL2026: Using member 'System.ComponentModel.DataAnnotations.MinLengthAttribute.MinLengthAttribute(Int32)' which has 'RequiresUnreferencedCodeAttribute' can break functionality when trimming application code. Uses reflection to get the 'Count' property on types that don't implement ICollection. This 'Count' property may be trimmed. Ensure it is preserved

(This is true even when using the options validation source generator - even though the generator generates its own attribute types, the original attribute still exists in user code.)

It seems like the best pattern we can recommend at the moment is to add UnconditionalSuppressMessage to the property, but it seems like there should be a built-in way to do length validation that doesn't require suppressing warnings.

The MinLengthAttribute ctor is ruc because its IsValid implementation reflects over the instance type to get the Count property. Maybe that could be represented using generics, for example:

class MinLengthAttribute<T> : MinLengthAttribute
    where T : ICollection
{
    public MinLengthAttribute(int length) {}
    public override bool IsValid(object? value)
    {
        if (value is ICollection collection)
        {
            return collection.Count >= Length;
        }
        throw ...;
    }
}

Somewhat related to #82526.

@eerhardt @tarekgh @eiriktsarpalis

Metadata

Metadata

Assignees

No one assigned

    Type

    No type

    Projects

    No projects

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions