我正在使用JUnit和Mockito为其他服务编写一个测试用例,使用jersey。我正在为响应类获得一个空对象,而不是一个模拟对象。
被测代码
Response response = builder
.put( Entity.entity( new ByteArrayInputStream( jsonObj.toString().getBytes() ), MediaType.APPLICATION_JSON ), Response.class );
测试用例:
private Invocation.Builder builder;
private Entity<ByteArrayInputStream> inputStream;
private Response response;
@Before
public void setUp() throws Exception {
builder = mock( Invocation.Builder.class );
inputStream = (Entity<ByteArrayInputStream>)mock( Entity.class );
response = mock( Response.class );
}
@Test
public void myTest() {
when( builder.put( inputStream, Response.class ) ).thenReturn( response );
}
因此,这一行代码给出了一个空响应。还有别的办法吗。
谢谢。
发布于 2017-04-18 15:38:33
我已经解决了这个问题,所以我想和大家分享我所做的事情。Mockito.when(builder.put(any(Entity.class), any(Class.class))).thenReturn(response);
上面的语句给了我被嘲弄的回应。现在,我可以使用模拟的Response对象做任何我想做的事情。我可以模拟getStatus方法并返回状态代码或其他任何东西。
希望这对Mockito和PowerMockito Api的人有帮助。
发布于 2017-04-14 18:54:45
那是因为你把各种事情搞混了。
您的生产代码是:
Entity.entity( new ByteArrayInputStream( ...
所以,你得到的是:
Entity.entity()
)new
这两个操作都不能用Mockito来模拟。事情就这么简单。
为了模拟静态方法调用,您必须查看诸如PowerMock(ito)或JMockit之类的框架。
但我推荐了一种不同的解决方案:考虑重新加工您的生产代码。相反,进行static+new调用;创建类似于
interface EntityProvider {
public Entity of(bytes[] data, MediaType type);
}
您可以很容易地创建一个使用当前代码的impl类--但是为了测试的目的,您可以依赖--注入该接口的模拟(通过Mockito.mock()创建);突然之间,整个代码再次使用Mockito进行测试。
而且不需要研究其他的模拟框架(而且是imho;至少PowerMockito有一定的成本--它并不像“切换到另一个框架”那么简单)。
https://stackoverflow.com/questions/43415733
复制相似问题