Модульное тестирование с использованием Moq для проверки сообщения об исключении - PullRequest
0 голосов
/ 29 августа 2018

Итак, у меня есть этот тест, который я настроил. Это выглядит так:

[Test]
public async Task LogErrorAndReturnSuccessIfNoLines()
{
    // Assemble
    const string orderNumber = "00000000";
    const string lineNumber = "001";
    var model = new OCS { Request = new strOCS { OrderLineID = $"{orderNumber}/{lineNumber}" } }; // NB: 12 characters means carpet
    var services = WmsContext.GivenServices();

    services.MockConfig.Setup(x => x.Live).Returns(false);
    services.MockOrderProvider.Setup(x => x.GetAsync(orderNumber, null, "Lines.Delivery")).Returns(Task.FromResult(services.WhenGetOrder()));

    var wmsProvider = services.WhenCreateWmsProvider();

    // Act
    var response = await wmsProvider.ReceiveOrderCompletedAsync(model);

    // Assert
    response.Should().Be("success");
    services.MockLogProvider.Verify(x => x.LogExceptionAsync(new Exception("Order doesn't exist on ERP"), It.IsAny<string>(), It.IsAny<string>(), It.IsAny<Dictionary<string, string>>(), It.IsAny<string>(), It.IsAny<string>(), It.IsAny<int>()));
}

Сбой из-за этой строки:

services.MockLogProvider.Verify(x => x.LogExceptionAsync(new Exception("Order doesn't exist on ERP"), It.IsAny<string>(), It.IsAny<string>(), It.IsAny<Dictionary<string, string>>(), It.IsAny<string>(), It.IsAny<string>(), It.IsAny<int>()));

Если я изменю это на:

services.MockLogProvider.Verify(x => x.LogExceptionAsync(It.IsAny<Exception>(), It.IsAny<string>(), It.IsAny<string>(), It.IsAny<Dictionary<string, string>>(), It.IsAny<string>(), It.IsAny<string>(), It.IsAny<int>()));

Проходит. Но я хочу убедиться, что отправленное сообщение точно Заказ не существует в ERP . Когда это терпит неудачу, это говорит это:

Сообщение: Moq.MockException: Ожидаемый вызов для макета хотя бы один раз, но он никогда не выполнялся: x => x.LogExceptionAsync (System.Exception: порядок не существует в ERP, It.IsAny (), It.IsAny (), It.IsAny> ( ), It.IsAny (), It.IsAny (), It.IsAny ()) Настройки не настроены.

В нем также говорится, что выполненные вызовы:

ILogProvider.LogTrace ("Получено OCS", ...

и

ILogProvider.LogExceptionAsync (System.Exception: заказ не существует в ERP, ...

Как видите, второй - тот, за которым я. Кто-нибудь может увидеть, что я делаю не так?


Вот мой WmsContext , чтобы вы могли видеть, как создаются макеты:

public class WmsContext
{
    public readonly Mock<ICormarConfig> MockConfig;
    public readonly Mock<IComplaintsProvider> MockComplaintsProvider;
    public readonly Mock<IDistributionProvider> MockDistributionProvider;
    public readonly Mock<IListItemProvider> MockListItemProvider;
    public readonly Mock<ILogProvider> MockLogProvider;
    public readonly Mock<IMessageProvider> MockMessageProvider;
    public readonly Mock<IOrderLineProvider> MockOrderLineProvider;
    public readonly Mock<IOrderProvider> MockOrderProvider;
    public readonly Mock<IStockProvider> MockStockProvider;
    public readonly Mock<IProofOfDeliveryService> MockProofOfDeliveryService;

    private readonly Lazy<IComplaintsProvider> _lazyComplaintsProvider;
    private readonly Lazy<IDistributionProvider> _lazyDistributionProvider;
    private readonly Lazy<IListItemProvider> _lazyListItemProvider;
    private readonly Lazy<ILogProvider> _lazyLogProvider;
    private readonly Lazy<IMessageProvider> _lazyMessageProvider;
    private readonly Lazy<IOrderLineProvider> _lazyOrderLineProvider;
    private readonly Lazy<IOrderProvider> _lazyOrderProvider;
    private readonly Lazy<IStockProvider> _lazyStockProvider;
    private readonly Lazy<IProofOfDeliveryService> _lazyProofOfDeliveryService;

    private WmsContext()
    {
        MockConfig = new Mock<ICormarConfig>();
        MockComplaintsProvider = new Mock<IComplaintsProvider>();
        MockDistributionProvider = new Mock<IDistributionProvider>();
        MockListItemProvider = new Mock<IListItemProvider>();
        MockLogProvider = new Mock<ILogProvider>();
        MockMessageProvider = new Mock<IMessageProvider>();
        MockOrderLineProvider = new Mock<IOrderLineProvider>();
        MockOrderProvider = new Mock<IOrderProvider>();
        MockStockProvider = new Mock<IStockProvider>();
        MockProofOfDeliveryService = new Mock<IProofOfDeliveryService>();

        _lazyComplaintsProvider = new Lazy<IComplaintsProvider>(() => MockComplaintsProvider.Object);
        _lazyDistributionProvider = new Lazy<IDistributionProvider>(() => MockDistributionProvider.Object);
        _lazyListItemProvider = new Lazy<IListItemProvider>(() => MockListItemProvider.Object);
        _lazyLogProvider = new Lazy<ILogProvider>(() => MockLogProvider.Object);
        _lazyMessageProvider = new Lazy<IMessageProvider>(() => MockMessageProvider.Object);
        _lazyOrderLineProvider = new Lazy<IOrderLineProvider>(() => MockOrderLineProvider.Object);
        _lazyOrderProvider = new Lazy<IOrderProvider>(() => MockOrderProvider.Object);
        _lazyStockProvider = new Lazy<IStockProvider>(() => MockStockProvider.Object);
        _lazyProofOfDeliveryService = new Lazy<IProofOfDeliveryService>(() => MockProofOfDeliveryService.Object);
    }

    public static WmsContext GivenServices() => new WmsContext();

    public IWmsProvider WhenCreateWmsProvider() =>
        new WmsProvider(
            MockConfig.Object, 
            _lazyDistributionProvider, 
            _lazyLogProvider, 
            _lazyComplaintsProvider, 
            _lazyStockProvider, 
            _lazyProofOfDeliveryService, 
            _lazyMessageProvider, 
            _lazyOrderProvider, 
            _lazyOrderLineProvider, 
            _lazyListItemProvider
            );

    public OrderViewModel WhenGetOrder(params string[] lineNumbers)
    {
        var lines = lineNumbers.Select(lineNumber => new OrderLineViewModel {Id = lineNumber}).ToList();

        return new OrderViewModel
        {
            Lines = lines
        };
    }
}

1 Ответ

0 голосов
/ 29 августа 2018

Это не совпадает, потому что два сравниваемых исключения не являются одним и тем же экземпляром исключения.

Вы можете проверить, является ли часть сообщения Исключения тем, что вы хотите, передав лямбда-выражение, подобное этому

services.MockLogProvider.Verify(x => x.LogExceptionAsync(
   It.Is<Exception>(e => e.Message == "Order doesn't exist on ERP"), 
   It.IsAny<string>(), 
   It.IsAny<string>(), 
   It.IsAny<Dictionary<string, string>>(), 
   It.IsAny<string>(), 
   It.IsAny<string>(), 
   It.IsAny<int>()));
...