@Override public FareRules getFareRules(final int fareId, final String languageCode) { FareRules f= this.fareRulesDataProvider.getFareRules(fareId, languageCode);//fareRulesDataProvider被mock dataProvider.getFFMarketList("CX", "REV");//dataProvider没有被mock List<Fare> fares = fareDateProvider.getFareListByPromotionCode("aaa");//被mock fareRulesDataProvider.hashCode(); return f; }
也就是说该方法里面所有被mock的外部调用,它都访回thenReturn中设置的值。
去调用handler.getFareRules, 才会返回我们设置的new FareRules.
补充一下:
1. 如果用a = Mockito.spy(a);然后通过PowerMockito来使用a的话,有些情景下会报错。
2. 前面说PowerMockito.doReturn(null).when(handler, "getFareRules", Integer.valueOf(requestDTO.getFareId()), "GB"); 这样调用
getFareRules方法不会被调用,前提是getFareRules是一个public的方法,如果是private的方法,getFareRules仍然会被调用。
3. 如果mock的方法是void的,可以使用Mockito.doNothing().when(a).aaa(); 但是在测试时发一个问题,如果像下面这样的话,会报错
PowerMockito.doReturn(null).when(a, "aaa");//aaa是一个私有方法
PowerMockito.doNothing().when(a, "bbb");//bbb是一个void的方法
也就是说如果先mock了一个私有方法,那么再mock一个void方法的时候会报错说这个bbb的mock方法没有设置返回值。
但是如果不mock那个私有方法的话,就正常。我猜是在mock私有方法的时候,mockito框架做了一些特殊的处理,但还不知道确切的原因是什么。
4. 关于mock的时候mock的方法是否会被调用,我发现如果是spy的对象,结果和我上面的结论是一样的,如果是纯mock的对象,使用
Mockito.when(handler.getFareRules(Integer.valueOf(requestDTO.getFareId()), "GB")).thenReturn(new FareRules());
这样的mock方式,被Mock的方法是不会被调用的。