如何解决如何模拟CriteriaQuery.whereEntityRoot.getID.inList <Integer>
我正在尝试模拟功能块
@Mock
private EntityManager entityManager;
@Mock
private CriteriaBuilder criteriaBuilder;
@Mock
CriteriaQuery<Entity> criteriaQuery;
@Mock
TypedQuery<Entity> typedQuery;
@Mock
Predicate predicate;
@Mock
Root<Entity> EntityRoot;
criteriaQuery.where(criteriaBuilder.and(
EntityRoot.get(ID).in(request.getIdList()),criteriaBuilder.greaterThanOrEqualTo(EntityRoot.get(columnName),Request.getTimeRangeFilter().getStartDate())));
ID-静态字符串
我尝试使用以下代码进行模拟
when(criteriaQuery.where(criteriaBuilder.and(predicate,predicate))).thenReturn(criteriaQuery);
但对于行EntityRoot.get(ID).in(request.getIdList())
我收到以下错误
https://www.apache.org/dyn/closer.lua/zookeeper/zookeeper-3.6.1/apache-zookeeper-3.6.1-bin.tar.gz
我在这里做什么错
解决方法
@Mock
Path<Object> path;
when(EntityRoot.get(anyString())).thenReturn(path);
when(path.in(Mockito.anyList())).thenReturn(predicate);
此解决方案终于奏效了。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。