繁体   English   中英

具有子/子类的类的单元测试 FluentValidation 规则

[英]Unit testing FluentValidation rules for classes with sub/child classes

当我们正在验证的对象具有也正在验证的子类时,是否可以为 fluentvalidation 类编写单元测试。

例如:我的班级看起来像这样

public class TestModel
{

    public class SubData
    {
        public int SubDataVal { get; set; }
    }

    public int ParentVal { get; set; }
    public SubData Sub { get; set; }

}

我的验证逻辑如下所示:

public class TestModelValidator : AbstractValidator<TestModel>
{
    public TestModelValidator()
    {
        RuleFor(o => o.ParentVal).GreaterThan(0);
        RuleFor(o => o.Sub.SubDataVal).GreaterThan(0);
    }
}

当我编写以下单元测试时

    [Test]
    public void Should_have_error_when_val_is_zero()
    {
        validator = new TestModelValidator();
        validator.ShouldHaveValidationErrorFor(model => model.ParentVal, 0);
    }

我收到“System.NullReferenceException : Object reference not set to an instance of an object”。 FluentValidation.TestHelper.ValidatorTester`2.ValidateError(T instanceToValidate) 中的异常

(如果我删除RuleFor(o => o.Sub.SubDataVal).GreaterThan(0);行,那么它就起作用了!)

同样,如果我尝试对实际的子类进行单元测试:

    [Test]
    public void Should_have_error_when_sub_dataVal_is_zero()
    {
        validator = new TestModelValidator();
        validator.ShouldHaveValidationErrorFor(model => model.Sub.SubDataVal, 0);
    }

我收到“System.Reflection.TargetException:对象与目标类型不匹配”。 来自FluentValidation.TestHelper.ValidatorTester`2.ValidateError(T instanceToValidate)

您可以对模型和子模型进行单元测试,但您需要更改验证类以使用单独的验证器类来验证子模型:

public class TestModelValidator : AbstractValidator<TestModel>
{
    public TestModelValidator()
    {
        RuleFor(o => o.ParentVal).GreaterThan(0);
        RuleFor(o => o.Sub).SetValidator(new SubDataValidator());
    }
}

public class SubDataValidator : AbstractValidator<SubData>
{
    public SubDataValidator()
    {
        RuleFor(o => o.SubDataVal).GreaterThan(0);
    }
}

然后,您可以编写单元测试来测试每个验证器或同时测试两者。

我得出的结论是,对于这个 ShouldHaveValidationErrorFor 无法处理子类,所以不得不手动进行。 IE

    [Test]
    public void Should_have_error_when_val_is_zero()
    {
        validator = new TestModelValidator();
        TestModel testRequest = new TestModel();
        //populate with dummy data
        var result = validator.Validate(testRequest);
        Assert.That(result.Errors.Any(o => o.PropertyName== "ParentVal"));
    }

使用 MSTest 和 FluentAssertions,您可以编写

[TestMethod]
public void Should_have_error_when_val_is_zero()
{
    // Given
    var validator = new TestModelValidator();
    var testModel = TestModel
    {
        ParentVal = 0
    }; // You should create a invalid TestModel object here

    // When
    validator.Validate(testModel).IsValid.Should().BeFalse();
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM