mocking a method that return generics with wildcard using mockito

前端 未结 2 1905
盖世英雄少女心
盖世英雄少女心 2020-12-08 06:18

I\'m using mockito 1.9.5. I have the following code:

public class ClassA  {

public List getMyInterfaces() {
    return null;
}         


        
相关标签:
2条回答
  • 2020-12-08 06:52

    Another solution (albeit less readable) is to qualify the static method call of when to bind the wildcard:

    Mockito.<List<? extends MyInterface>>when(classAMock.getMyInterfaces()).thenReturn(interfaces);
    
    0 讨论(0)
  • 2020-12-08 07:18

    EDIT : Starting from Mockito 1.10.x, generics types that are embedded in the class are now used by Mockito for deep stubs. ie.

    public interface A<T extends Observer & Comparable<? super T>>  {
      List<? extends B> bList();
      T observer();
    }
    
    B b = deep_stubbed.bList().iterator().next(); // returns a mock of B ; mockito remebers that A returns a List of B
    Observer o = deep_stubbed.observer(); // mockito can find that T super type is Observer
    Comparable<? super T> c = deep_stubbed.observer(); // or that T implements Comparable
    

    Mockito tries its best to get type information that the compiler embeds, but when erasure applies, mockito cannot do anything but return a mock of Object.


    Original : Well that's more of an issue with generics than with Mockito. For generics, you should read what Angelika Langer wrote on them. And for the current topic, i.e. wildcards, read this section.

    But for short, what you could use is the other syntax of Mockito to help with your current situation :

    doReturn(interfaces).when(classAMock).getMyInterfaces();
    

    Or with the BDD aliases :

    willReturn(interfaces).given(classAMock).getMyInterfaces();
    

    Nevertheless, you could write wrappers that are more generic friendly. That will help future developers working with same 3rd party API.


    As a side note: you shouldn't mocks type you don't own, it can lead to many errors and issues. Instead you should have some wrapper. DAO and repositories for example represent such idea, one will mock the DAO or repository interface, but not the JDBC / JPA / hibernate stuff. There are many blog posts about that:

    • http://davesquared.net/2011/04/dont-mock-types-you-dont-own.html
    • http://blog.8thlight.com/eric-smith/2011/10/27/thats-not-yours.html
    • https://web.archive.org/web/20140923101818/http://freshbrewedcode.com/derekgreer/2012/04/01/tdd-best-practices-dont-mock-others/
    • ...
    0 讨论(0)
提交回复
热议问题