2017-09-04 9 views
1

Je viens de rencontrer une exception que je ne peux pas m'expliquer lors de l'écriture du test unitaire.Test d'unité avec Moq d'Excel Interop + Type.Missing

(simplifié) code que je veux tester est:

public object GetSecondColumn(Microsoft.Office.Interop.Excel.Range theRange) 
{ 
    return theRange.Columns[2, Type.Missing]; 
} 

J'ai essayé d'écrire ce test, mais je continue à avoir une exception:

//Arrange 
var usedRange = new Mock<Range>(); 
var result = new Mock<Range>(); 
usedRange .Setup(m => m[It.IsAny<object>(), It.IsAny<object>()]).Returns(
    (object r, object c) => 
    { 
     return result.Object; 
    }); 

//Assert 
GetSecondColumn(usedRange); 

appel de méthode lance:

System.ArgumentException 
Message=Missing parameter does not have a default value. 
Parameter name: parameters 
    StackTrace: 
     at System.Reflection.MethodBase.CheckArguments(Object[] parameters, Binder binder, BindingFlags invokeAttr, CultureInfo culture, Signature sig) 
     at System.Reflection.RuntimeMethodInfo.InvokeArgumentsCheck(Object obj, BindingFlags invokeAttr, Binder binder, Object[] parameters, CultureInfo culture) 
     at System.Delegate.DynamicInvokeImpl(Object[] args) 
     at System.Delegate.DynamicInvoke(Object[] args) 
     at Moq.Extensions.InvokePreserveStack(Delegate del, Object[] args) 
     at Moq.MethodCallReturn`2.Execute(ICallContext call) 
     at Moq.ExecuteCall.HandleIntercept(ICallContext invocation, InterceptorContext ctx, CurrentInterceptContext localctx) 
     at Moq.Interceptor.Intercept(ICallContext invocation) 
     at Moq.Proxy.CastleProxyFactory.Interceptor.Intercept(IInvocation invocation) 
     at Castle.DynamicProxy.AbstractInvocation.Proceed() 
     at Castle.Proxies.ObjectProxy_3.get__Default(Object RowIndex, Object ColumnIndex) 
     at **** 

Impossible de gérer Type.Missing/Missing.Value avec It.IsAny()?

Répondre

1

IMO il vous manque le Setup de la méthode Columns. Cette méthode doit être configurée car elle est appelée dans la fonction GetSecondColumn. Sans configuration Columns est null:

enter image description here

Ainsi la configuration Columns par exemple comme ça. Ici, le Columns renvoie expected pour tous les arguments de type object. HTH

[TestMethod] 
public void GetSecondColumn_WhenCalled_ReturnsSomeExpectedResult() 
{ 
    // Arrange 
    const string expected = "Expectd Value To Return"; 
    var rangeMock = new Mock<Range>(); 
    var fakeResultRange = new Mock<Range>(); 
    fakeResultRange.Setup(range => range[It.IsAny<object>(), It.IsAny<object>()]).Returns(expected); 
    rangeMock.Setup(range => range.Columns).Returns(() => fakeResultRange.Object); 
    ClassToUnitTest cut = new ClassToUnitTest(); 

    // Act 
    var actual = cut.GetSecondColumn(rangeMock.Object); 

    // Assert 
    Assert.AreEqual(expected, actual); 
}