Como testar a unidade com o ILogger no ASP.NET Core

Este é o meu controlador:

public class BlogController : Controller
{
    private IDAO<Blog> _blogDAO;
    private readonly ILogger<BlogController> _logger;

    public BlogController(ILogger<BlogController> logger, IDAO<Blog> blogDAO)
    {
        this._blogDAO = blogDAO;
        this._logger = logger;
    }
    public IActionResult Index()
    {
        var blogs = this._blogDAO.GetMany();
        this._logger.LogInformation("Index page say hello", new object[0]);
        return View(blogs);
    }
}

Como você pode ver, eu tenho 2 dependências, umaIDAO e umILogger

E esta é a minha classe de teste, eu uso o xUnit para testar e o Moq para criar simulação e esboço, posso simularDAO fácil, mas com oILogger Não sei o que fazer, apenas passo nulo e comento a chamada para efetuar login no controlador ao executar o teste. Existe uma maneira de testar, mas ainda manter o logger de alguma forma?

public class BlogControllerTest
{
    [Fact]
    public void Index_ReturnAViewResult_WithAListOfBlog()
    {
        var mockRepo = new Mock<IDAO<Blog>>();
        mockRepo.Setup(repo => repo.GetMany(null)).Returns(GetListBlog());
        var controller = new BlogController(null,mockRepo.Object);

        var result = controller.Index();

        var viewResult = Assert.IsType<ViewResult>(result);
        var model = Assert.IsAssignableFrom<IEnumerable<Blog>>(viewResult.ViewData.Model);
        Assert.Equal(2, model.Count());
    }
}

questionAnswers(6)

yourAnswerToTheQuestion