2017-06-21 102 views
0

所以,我有一個問題嘲笑私人方法。從我所看到的一切應該起作用,但不是。嘲笑私人方法

讓我們從基礎開始 - 這是測試

public sealed class UnderTest 
{ 
    private bool MockPrivate(string name) 
    { 
     [snip] 
    } 

    private string MethodUnderTest(ParameterHolder parameters) 
    { 
     if (!this.MockPrivate(parameters.Parameter2)) 
     { 
      return null; 
     } 
     [Snip] 
    } 
    [Snip] 
} 

public sealed class ParameterHolder 
{ 
    public ParameterHolder (bool parameter1, string parameter2) 
    { 
     this.Parameter1 = parameter1; 
     this.Parameter2 = parameter2; 
    } 

    public bool Parameter1 
    { 
     get; 
     private set; 
    } 

    public string Parameter2 
{ 
     get; 
     private set; 
    } 
} 

下面的代碼是測試方法

public void Test_UnderTest_MethodUnderTest() 
{ 
    UnderTest testClass; 
    ParameterHolder parameters; 
    dynamic h; 

    testClass = new UnderTest(); 

    parameters = Isolate.Fake.Instance<ParameterHolder>(Members.CallOriginal); 
    Isolate.WhenCalled(() => parameters.Parameter1).WillReturn(true); 
    Isolate.WhenCalled(() => parameters.Parameter2).WillReturn("parameter2value"); 

    h = testClass.AsDynamic(); 

    Isolate.WhenCalled(() => h.MockPrivate((string)null)).WillReturn(true); 

    Assert.IsNotNull(h.MethodUnderTest(parameters)); 
} 

我也試圖在隔離調用更改爲:

Isolate.WhenCalled(() => h.MockPrivate("parameter2value").WillReturn(true); 

and

Isolate.WhenCalled(() => h.MockPrivate(parameters.Parameter2).WillReturn(true); 

在所有情況下,都會執行MockPrivate方法,而不是返回模擬的True值。

任何幫助,將不勝感激。

回答

3

好了,做了一些更多的檢查,這是正確的做法:

Isolate.NonPublic.WhenCalled(testClass, "MockPrivate").WillReturn(true);