繁体   English   中英

spring JpaRepository方法的存根

[英]Stub of the spring JpaRepository method

我有下一个JPQL查询:

@Query(value = "select t.ts as ts, t.ko.eolink.guid as guid from ObjPar t "
        + "where t.tuser.cd = ?1 and t.lst.cd=?2 and t.ts between ?3 and ?4")
List<MeterData> findTimestampByUser(String userCd, String lstCd, Date dtFrom, Date dtTo);

其中MeterData-只是投影接口:

public interface MeterData {
    Date getTs();
    String getGuid();
}

现在,我需要编写类似存根的内容。 我不需要执行查询,但需要将其返回到MeterData列表。

我该怎么做? 我应该创建并实现Class的MeterData吗? 也许有人可以暗示我更简单的方法?

我的解决方案:

List<MeterData> findTimestampByUser(String userCd, String lstCd, Date dtFrom, Date dtTo) {

        class LocalMeterData implements MeterData {
            public Date getTs() {
                return new Date();
            }
            public String getGuid() {
                return "2312-1316-4564-4654-4463";
            }
        }

        List<MeterData> lst = new ArrayList<>(5);
        MeterData elem = new LocalMeterData();
        lst.add(elem);
        lst.add(elem);
        lst.add(elem);
        lst.add(elem);

return lst;

}

如果您需要对存储库进行存根以进行单元测试,请使用Mockito。 像已经在测试中一样,将您的类实现声明为私有内部类,并指导Mockito使用它:

MeterData elem = new LocalMeterData();
Mockito.when(yourRepository.findTimestampByUser(anyString(), any(Date.class), any(Date.class)))
        .thenReturn(Arrays.asList(elem, elem, elem, elem));

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM