用Mockito模拟两个相同类型的物体

tam*_*ren 10 mockito

我正在使用Mockito编写单元测试,我在模拟注入的类时遇到了问题.问题是两个注入的类是相同的类型,只能通过它们的@Qualifier注释区分.如果我试图简单地模拟SomeClass.class,那个模拟不会被注入,那个对象就null在我的测试中.我该如何模仿这些物体?

public class ProfileDAL {

    @Inject
    @Qualifier("qualifierA")
    private SomeClass someClassA ;

    @Inject
    @Qualifier("qualifierB")
    private SomeClass someClassB ;

    //...various code, not important
}

@RunWith(MockitoJUnitRunner.class)
public class ProfileDALLOMImplTest {

    @InjectMocks
    private ProfileDALLOMImpl profileDALLOMImpl = new ProfileDALLOMImpl();

    @Mock
    private SomeClass someClassA;
    @Mock
    private SomeClass someClassB;

    private SomeResult mockSomeResult = mock(SomeResult.class);

    @Test
    public void testSomeMethod() {
        when(someClassA .getSomething(any(SomeArgment.class)).thenReturn(mockSomeResult);
        Int result = profileDALLOMImpl.someTest(This isn't relevant);
    }

 }
Run Code Online (Sandbox Code Playgroud)

spl*_*onk 10

我尝试使用JUnit使用Mockito 1.9.5模拟两个具有相同类型的对象并且它可以工作.

请参阅:http://static.javadoc.io/org.mockito/mockito-core/1.9.5/org/mockito/InjectMocks.html

来自doc的相关类型信息:

"字段注入;模拟首先按类型解析,然后,如果有多个相同类型的属性,则通过字段名称和模拟名称的匹配来解析."

这个似乎说你应该使模拟名称与你所有模拟的字段名称相匹配,当你有两个相同的类型时:

"注1:如果你有相同类型(或相同的擦除)的@Mock字段,最好用匹配的字段命名所有带注释的字段,否则Mockito可能会感到困惑,注入也不会发生."

也许后者会咬你?


rco*_*len 0

如果你不使用注释,你会得到类似的东西

public class MyClass {
    private MyDependency myDependency;

    public void setMyDependency(MyDependency myDependency){
        this.myDependency = myDependency;
    }
}
Run Code Online (Sandbox Code Playgroud)

import org.junit.Before;
import org.junit.Test;

import static org.mockito.Mockito.*;

public class MyTest {

    private MyClass myClass;
    private MyDependency myDependency;

    @Before
    public void setUp(){
        myClass = new MyClass();
        myDependency = mock(MyDependency.class);
        myClass.setMyDependency(myDependency);
    }

    @Test
    public void test(){
        // Given

        // When

        // Then
    }
}
Run Code Online (Sandbox Code Playgroud)

如果您的对象通过构造函数而不是通过 setter 指定其依赖项,您也可以执行相同的操作。我猜你的依赖注入框架可以像注释私有字段一样注释设置器,但现在你的测试不依赖于任何依赖注入框架。