Changed min/max parameter order in StringLengthAttributeAdapter (#4899)
Changed min/max parameter order in StringLengthAttributeAdapter. This fixes #4864.
This commit is contained in:
parent
72dbda8804
commit
c319ae51a5
|
|
@ -54,8 +54,8 @@ namespace Microsoft.AspNetCore.Mvc.DataAnnotations.Internal
|
|||
return GetErrorMessage(
|
||||
validationContext.ModelMetadata,
|
||||
validationContext.ModelMetadata.GetDisplayName(),
|
||||
Attribute.MinimumLength,
|
||||
Attribute.MaximumLength);
|
||||
Attribute.MaximumLength,
|
||||
Attribute.MinimumLength);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -417,7 +417,7 @@ namespace Microsoft.AspNetCore.Mvc.DataAnnotations.Internal
|
|||
{
|
||||
new StringLengthAttribute(length) { ErrorMessage = LocalizationKey, MinimumLength = 1},
|
||||
string.Empty,
|
||||
new object[] { nameof(SampleModel), 1, length }
|
||||
new object[] { nameof(SampleModel), length, 1 }
|
||||
},
|
||||
{
|
||||
new RangeAttribute(0, length) { ErrorMessage = LocalizationKey },
|
||||
|
|
|
|||
|
|
@ -16,19 +16,19 @@ namespace Microsoft.AspNetCore.Mvc.DataAnnotations.Internal
|
|||
{
|
||||
[Fact]
|
||||
[ReplaceCulture]
|
||||
public void AddValidation_WithMaxLength_AddsAttributes_Localize()
|
||||
public void AddValidation_WithMaxLengthAndMinLength_AddsAttributes_Localize()
|
||||
{
|
||||
// Arrange
|
||||
var provider = TestModelMetadataProvider.CreateDefaultProvider();
|
||||
var metadata = provider.GetMetadataForProperty(typeof(string), "Length");
|
||||
|
||||
var attribute = new StringLengthAttribute(8);
|
||||
attribute.ErrorMessage = "Property must not be longer than '{1}' characters.";
|
||||
attribute.ErrorMessage = "Property must not be longer than '{1}' characters and not shorter than '{2}' characters.";
|
||||
|
||||
var expectedMessage = "Property must not be longer than '8' characters.";
|
||||
var expectedMessage = "Property must not be longer than '8' characters and not shorter than '0' characters.";
|
||||
|
||||
var stringLocalizer = new Mock<IStringLocalizer>();
|
||||
var expectedProperties = new object[] { "Length", 0, 8 };
|
||||
var expectedProperties = new object[] { "Length", 8, 0 };
|
||||
|
||||
stringLocalizer.Setup(s => s[attribute.ErrorMessage, expectedProperties])
|
||||
.Returns(new LocalizedString(attribute.ErrorMessage, expectedMessage));
|
||||
|
|
|
|||
Loading…
Reference in New Issue