Java:使用Mockito模拟ResultSet

这篇文章展示了如何使用Mockito模拟java.sql.ResultSet 。 它可用于帮助单元测试代码对ResultSet (例如ResultSetExtractor )执行操作,而无需依赖外部数据源。

您可以通过提供列名列表和2D数据数组来创建MockResultSet 。 例如:

var rs = MockResultSet.create(new String[] { "name", "age" }, //columnsnew Object[][] { // data{ "Alice", 20 },{ "Bob", 35 },{ "Charles", 50 }});

MockResultSet的代码如下所示(也可以在我的GitHub Repository中找到 )。 请注意,我仅模拟了诸如nextgetStringgetObject类的一些方法,但是通过遵循相同的模式来模拟其余方法非常容易。

public class MockResultSet {private final Map<String, Integer> columnIndices;private final Object[][] data;private int rowIndex;private MockResultSet(final String[] columnNames,final Object[][] data) {// create a map of column name to column indexthis.columnIndices = IntStream.range(0, columnNames.length).boxed().collect(Collectors.toMap(k -> columnNames[k],Function.identity(),(a, b) ->{ throw new RuntimeException("Duplicate column " + a); },LinkedHashMap::new));this.data = data;this.rowIndex = -1;}private ResultSet buildMock() throws SQLException {final var rs = mock(ResultSet.class);// mock rs.next()doAnswer(invocation -> {rowIndex++;return rowIndex < data.length;}).when(rs).next();// mock rs.getString(columnName)doAnswer(invocation -> {final var columnName = invocation.getArgumentAt(0, String.class);final var columnIndex = columnIndices.get(columnName);return (String) data[rowIndex][columnIndex];}).when(rs).getString(anyString());// mock rs.getObject(columnIndex)doAnswer(invocation -> {final var index = invocation.getArgumentAt(0, Integer.class);return data[rowIndex][index - 1];}).when(rs).getObject(anyInt());final var rsmd = mock(ResultSetMetaData.class);// mock rsmd.getColumnCount()doReturn(columnIndices.size()).when(rsmd).getColumnCount();// mock rs.getMetaData()doReturn(rsmd).when(rs).getMetaData();return rs;}/*** Creates the mock ResultSet.** @param columnNames the names of the columns* @param data* @return a mocked ResultSet* @throws SQLException*/public static ResultSet create(final String[] columnNames,final Object[][] data)throws SQLException {return new MockResultSet(columnNames, data).buildMock();}
}

翻译自: https://www.javacodegeeks.com/2018/09/java-mocking-resultset-using-mockito.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/346221.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

c语言如何随机获取1kb,基于VS2010+C语言实现播放器的顺序播放、随机播放

1.[文件] music.h ~ 920B 下载(38)/** File: music.h* Time: 2014/10/11*/#ifndef __MUSIC_H__#define __MUSIC_H__typedef enum { UNPLAYED, PLAYED } BOOL; // 自定义一个bool类型typedef enum { ORDER, RANDOM } PLAY_MODEL; // 自定义一个播放类型typedef char *MUSIC_…

rmi远程代码执行漏洞_fastjson远程代码执行漏洞复现

漏洞原理fastjson提供了autotype功能&#xff0c;在请求过程中&#xff0c;我们可以在请求包中通过修改type的值&#xff0c;来反序列化为指定的类型&#xff0c;而fastjson在反序列化过程中会设置和获取类中的属性&#xff0c;如果类中存在恶意方法&#xff0c;就会导致代码执…

c语言编简单博弈小游戏,[2018年最新整理]实验二:利用α-β搜索过程的博弈树搜索算法编写一字棋游戏.doc...

[2018年最新整理]实验二&#xff1a;利用α-β搜索过程的博弈树搜索算法编写一字棋游戏实验二&#xff1a;利用α-β搜索过程的博弈树搜索算法编写一字棋游戏一、实验目的与要求(1)了解极大极小算法的原理和使用方法&#xff0c;并学会用α-β剪枝来提高算法的效率。(2)使用C语…

java中重载 参数顺序_Java方法中的参数太多,第4部分:重载

java中重载 参数顺序期望将过多的参数传递给Java方法的问题之一是&#xff0c;该方法的客户端很难确定它们是否以适当的顺序传递了适当的值。 在以前的文章中&#xff0c;我描述了如何使用自定义类型 &#xff0c; 参数对象和构建器来解决此问题。 解决此问题的另一种方法&…

c语言金箍棒答案,《西游记》阅读测试题(带答案)

《西游记》测试题(后附答案)姓名得分1.《如来佛辨识假猴王》故事中,那只假孙悟空是什么猴子变的&#xff1f;()A&#xff0e;金丝猴 B&#xff0e;石猴 C.六耳猕猴2.金角大王和银角大王原来是()的弟子。A&#xff0e;太上老君 B&#xff0e;孙悟空 C&#xff0e;观音菩萨3.蜘蛛…

五个金念什么_四个“金”字读什么?

展开全部读音为&#xff1a;jīn &#xff0c;是金字的异体字写法&#xff0c;读音和意思与金字完全相同&#xff0c;打不62616964757a686964616fe58685e5aeb931333431353265出来&#xff0c;如下图&#xff1a;金拼音&#xff1a;jīn释义&#xff1a;1.俗称金子。金属元素&am…

Istio的零停机滚动更新

本系列文章的第一部分介绍了如何在Kubernetes集群中实现真正的零停机时间更新。 我们专门解决了将流量从旧实例切换到新实例时出现的请求失败。 本文将展示如何使用Istio群集实现相同的目标。 服务网格技术&#xff08;例如Istio&#xff09;通常与容器编排结合使用。 Istio以…

聚类dbi指数_一种基于DBI-PD聚类算法的异常检测机制

一种基于DBI-PD聚类算法的异常检测机制丁姝郁【期刊名称】《电脑开发与应用》【年(卷),期】2015(000)002【摘要】分析了网络数据维数和检测准确度之间的关系&#xff0c;介绍了常用于入侵检测的聚类分析方法及其优缺点。在此基础上&#xff0c;提出一种以戴维森堡丁指数(DBI)为…

单片机红外通信c语言,基于C语言的计算机与多单片机红外无线串口通信的实现.doc...

基于C语言的计算机与多单片机红外无线串口通信的实现基于C语言的计算机与多单片机红外无线串口通信的实现黄文亮 信息学院 电子信息工程专业指导教师 刘传菊摘要&#xff1a;计算机与一台或多台单片机的通信系统中的数据通讯一般采用的是串行通信方式。串行通信可采用有线与无线…

android 设置资源,Android 资源

Android 资源Android Resources02/01/2018本文内容本文介绍了 Xamarin 中 Android 资源的概念&#xff0c;并介绍了如何使用这些资源。其中介绍了如何使用 Android 应用程序中的资源来支持应用程序本地化和多个设备&#xff0c;包括不同的屏幕大小和密度。This article introdu…

zbrush常用笔刷_ZBrush中常用笔刷综合简介

单击左托盘的笔刷图标&#xff0c;弹出一个笔刷库&#xff0c;其中有许多常用笔刷&#xff0c;这也是许多初学者所头疼的问题&#xff0c;ZBrush的笔刷非常多&#xff0c;而且功能很强大&#xff0c;好多朋友不知道该选择哪一个笔刷进行雕刻。其实&#xff0c;在ZBrush的学习中…

spring java配置_Spring:使基于Java的配置更加优雅

spring java配置大家好&#xff0c;我很久没有写新文章了。 积累了很多资料&#xff0c;需要在不久的将来在我的博客中发布。 但是现在我想谈谈Spring MVC应用程序配置。 确切地说&#xff0c;我想谈谈基于Java的Spring配置。 尽管在3.0版本中引入了基于Spring java的配置&…

android封装oauth2,Android AccountAuthenticator和OAuth2

这肯定是可行的。来自Android AccountManager文档&#xff1a;Many servers support some notion of an authentication token, which canbe used to authenticate a request to the server without sending theusers actual password. (Auth tokens are normally created with…

php redis 队列抢红包_php+redis实现消息队列

消息队列&#xff1a;是在消息的传输过程中保存消息的容器。消息队列管理器在将消息从它的源中继到它的目标时充当中间人。队列的主要目的是提供路由并保证消息的传递&#xff1b;如果发送消息时接收者不可用&#xff0c;消息队列会保留消息&#xff0c;直到可以成功地传递它应…

使用Spring Security在Spring Boot中进行缓存

在这篇文章中&#xff0c;我想分享一下O&#xff06;B的一个团队的经验教训。 他们正在使用带有Spring Security的Spring Boot。 默认情况下&#xff0c;Spring Security保护的所有内容都将通过以下HTTP标头发送到浏览器&#xff1a; Cache-Control: no-cache, no-store, max…

wifi定位算法android,WIFI定位算法

网络定位指通过周边wifi列表、基站列表、IP地址等信息确定用户位置的过程。 我们采集的训练数据是每个GPS坐标位置和对应的Wifi和基站列表。 其中每个Wifi和基站有唯一的Mac地址作为ID和信号强度。有三种定位方法&#xff1a;均值法首先估计一个wifi的中心点位置&#xff0c;可…

仿小黄车android定位,小黄车ofo是怎么实现自行车定位功能的?

摩拜单车通过车身携带的GPS而实现单车定位&#xff0c;但是我们知道ofo是没有安装GPS&#xff0c;它又是如何实现单车定位的呢&#xff1f;我居住的地方距离地铁站步行大约15分钟左右&#xff0c;距离最近的商场步行将近30分钟&#xff0c;距离周边的便利店,水果店,饭店等步行1…

python苹果下载软件助手哪个好_Mac上有什么实用的必备软件?

Mac上的一些软件真的超好用&#xff0c;比如...每天依据时间变化的壁纸&#xff0c;看清晨、看夕阳我是 Super叔 ,关注了就是好朋友,这里说明下还是,软件只是工具,初衷是为了方便自己提高效率,别为了去模仿所谓某某软件可以怎么怎么复杂的,用得多么炫酷好用,而去花非常多精力为…

hibernate 刷新_Hibernate事实:了解刷新操作顺序很重要

hibernate 刷新Hibernate将开发人员的思维方式从思考SQL转变为思考对象状态转换。 根据Hibernate Docs&#xff0c;实体可能处于以下状态之一&#xff1a; new / transient&#xff1a;实体不与持久性上下文相关联&#xff0c;因为它是数据库不知道的新创建的对象。 持久性&a…

android变量要不要附空值,android-如何在使用Parcelable时序列化空值

我见过的大多数序列化代码都使用两个标志来指示值的存在/不存在&#xff0c;或者在值前加上一个计数字段(例如&#xff0c;在编写数组时)&#xff0c;如果该值不等于&#xff0c;则计数字段仅设置为零。 根本不存在。检查Android核心类的源代码会发现以下代码(来自Message类)&a…