Skip to content

Small library that extends and simplifies possibilities of testing code that is using FluentValidation package.

License

Notifications You must be signed in to change notification settings

MichalJankowskii/FluentValidation.Validators.UnitTestExtension

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

95 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

FluentValidation.Validators.UnitTestExtension

Build Status Downloads

Full documentation

Project description

Main purpose of this small library is to extend and simplify possibilities of testing code that is using FluentValidation package.

Installation - NuGet Packages

Install-Package FluentValidation.Validators.UnitTestExtension

Overview

This library allows you to focus on testing your implementation. You will be able to write test that will run faster, will be readable and will test only your implementation.

Please look at the following example of PersonValidator:

public class PersonValidator : AbstractValidator<Person>
{
  public PersonValidator()
  {
    RuleFor(person => person.Name).NotNull();
  }
}

By using this library you can write unit test like this:

public class PersonValidatorTests
{
  [Fact]
  public void When_PersonValidatorConstructing_Then_RulesAreConfiguredCorrectly()
  {
    var personValidator = new PersonValidator();

    personValidator.ShouldHaveRules(x => x.Name,
      BaseVerifiersSetComposer.Build()
        .AddPropertyValidatorVerifier<NotNullValidator<Person, string>>()
	.Create());
  }
}

According to FluentValidation wiki same code should be tested in the following way:

public class PersonValidatorTests
{
  private PersonValidator validator;

  public void PersonValidatorTester()
  {
    validator = new PersonValidator();
  }

  [Fact]
  public void Should_have_error_when_Name_is_null() 
  {
    var model = new Person { Name = null };
    var result = validator.TestValidate(model);
    result.ShouldHaveValidationErrorFor(person => person.Name); 
  }

  [Fact]
  public void Should_not_have_error_when_name_is_specified()
  {
    var model = new Person { Name = "Jeremy" };
    var result = validator.TestValidate(model);
    result.ShouldNotHaveValidationErrorFor(person => person.Name);
  }
}

As you can see you need to test each scenario that can fail validation with FluentValidation approach. With that approach you are writing rather integration test than real unit test. Your tests will be slower and you will need to write more code.

By using this framework you will be:

  • more effective in writing unit tests
  • you will be testing only your code
  • your test will be more robustness
  • moreover you will be able to check order of validators
  • and many more.

Please see documentation.

About

Small library that extends and simplifies possibilities of testing code that is using FluentValidation package.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages