这是我用于端到端测试的模拟代码:
@RunWith(MockitoJUnitRunner.class)
public class testRest extends Jersey Test{
DAOFactory mockDAOfactory;
RPRestrictionReasonDAO fakeDao;
@Before
public void init() {
mockDAOfactory = mock(DAOFactory.class);
fakeDao = mock(RPRestrictionReasonDAO.class);
}
@Test
public void testServiceWorks() throws Exception {
//Assuming I hav already initialized restrictReasons with a dummy value
when(fakeDao.findAll()).thenReturn(restrictReasons);
when(mockDAOfactory.getRPRestrictionReasonDAO()).thenReturn(fakeDao);
String response = client().resource("http://localhost:9998/")
.path("EmployerDetails/PossibleRestrictions")
.get(String.class);
System.out.println("Response is " + response.toString());
}
}
每当我这样做时,我总是在我的数据库中得到实际结果,而不是 restrictReasons。我尝试了所有博客,但似乎无济于事。我如何解决这个问题?让我知道是否需要发布更多代码。
注意:我在使用 Grizzly 容器扩展 Jersey Test 时实现了这些方法。
最佳答案
据我从您的代码中可以看出,您正在创建模拟,但实际上并未在您的客户端/服务器实现中使用模拟。
要让 mock 起作用,它需要由底层实现使用,而不仅仅是在您的测试类中创建。在这种情况下,假设您的测试与您正在测试的服务器在同一 JVM 中运行,您需要将创建的模拟注入(inject)到依赖它们的类中。
@inkalimeva 的另一个回答是试图通过将模拟注入(inject)您的 DAO 工厂来为您解决这个问题。您可以通过将 DAOFactory 声明更改为使用的具体类而不是抽象类来修复您遇到的错误。
例如
@InjectMocks
DAOFactoryImpl mockFactory;
假设 DAOFactoryImpl 是您的具体工厂类。
关于java - 用于 REST + DAO 对象的 Mockito,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24874424/