问题描述
如果我在模型类中使用MinLen和Range,则测试不会引发我期望的异常。
MaxLength可以按预期工作。
使用其他数据库作为sqlite,sqlserver时,我也有相同的行为。
[TestFixture]
public class PostgresqlRangeFixture
{
[Test]
public void TestRange_MustThrow()
{
using (var ctx = new LocalDbContext()) {
ctx.Database.EnsureCreated();
User user = new User() { FirstName = "12",LastName = "too short",Age = -100 };
ctx.Users.Add(user);
ctx.SaveChanges();
}
}
}
public class LocalDbContext : DbContext
{
public DbSet<User> Users { get; set; }
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
base.OnConfiguring(optionsBuilder);
const string psw = "marcos";
string dbname = "test_" + DateTime.Now.ToString("yyyy.MM.dd-HH.mm.ss.fff");
var cs = $"Host=192.168.99.100;Username=postgres;Password={psw};Database={dbname}";
optionsBuilder.UseNpgsql(cs);
}
}
public class User
{
public int Id { get; set; }
[required]
[MaxLength(2)]
public string FirstName { get; set; }
[required]
[MinLength(20)]
public string LastName { get; set; }
[required]
[Range(0,150)]
public int Age { get; set; }
}
解决方法
EF Core仅使用这些命名空间提供的部分属性:
System.ComponentModel.DataAnnotations.Schema System.ComponentModel.DataAnnotations
在您的情况下,似乎只有 Required 和 MaxLength 应该起作用。选中此-> EF Core Annotations
其余属性可以在ASP.NET Core API的-> Click
中用于模型验证