测试学习笔记1:@SpringbootTest测试注解详解

@SpringBootTest是一个用于在springboot应用程序中启动完整应用的测试环境注解。它主要用于集成测试,可以启动一个嵌入式的数据库,加载完整的spring上下文,并自动装配测试类的ApplicationContext。

以下是@SpringBootTest的关键特性:

  • 自动配置上下文环境:@SpringBootTest能够根据测试类所在的包扫描应用程序组件,并自动配置一个完整的Spring上下文;
  • 自动配置Mock服务:@SpringBootTest自动为应用程序中的服务提供mock实现,这使得能够不依赖真实服务的情况下进行测试;
  • 自动配置嵌入式数据库:@SpringBootTest自动配置一个嵌入式数据库,如:H2、HSQL或Derby,者能够使我们在不依赖外部数据库的情况下进行测试;
  • 自动配置切面或拦截器:@SpringBootTest自动应用一系列的切面或拦截器,以便在在测试期间记录或验证应用程序的行为。

下面的简单案例展示如何通过@SpringBootTest注解完成简单的单元测试:

定义一个service类:

@Service
public class MysqlServiceImpl implements MysqlService {@Autowiredprivate MysqlMapper mysqlMapper;@Overridepublic List<World> getMysql() {return mysqlMapper.getMysql("田晓霞", "123456");}
}

定义一个单元测试类:

@SpringBootTest
public class MysqlServiceTest {@Autowiredprivate MysqlServiceImpl mysqlService;@MockBeanprivate MysqlMapper mysqlMapper;@Testpublic void getMysql() {World world = new World();world.password = "123";when(mysqlMapper.getMysql("田晓霞", "123456")).thenReturn(Lists.newArrayList(world));List<World> list = mysqlService.getMysql();Assertions.assertEquals(list.get(0).password, "123");}
}

在此案例中,spring boot会启动一个完整的spring应用上下文,并自动装配MysqlServiceTest类中所有的@Autowired类,通过@MockBean注解模拟真实需要的MysqlMapper实例对象,通过when、thenReturn模拟返回数据,避免调用真实的数据库实现。

GitHub地址:https://github.com/mingyang66/spring-parent

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

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

相关文章

机器学习实验四:贝叶斯分类器

系列文章目录 机器学习实验一&#xff1a;线性回归机器学习实验二&#xff1a;决策树模型机器学习实验三&#xff1a;支持向量机模型机器学习实验四&#xff1a;贝叶斯分类器机器学习实验五&#xff1a;集成学习机器学习实验六&#xff1a;聚类 文章目录 系列文章目录一、实验…

47.0/超链接的使用(详细版)

目录 47.1 创建超链接的基本语法 47.2 路径 47.2.1 绝对路径 47.2.2 相对路径 47.2.3 相对路径和绝对路径举例 47.3 内部超链接的建立 47.4 外部超链接的建立 47.5 书签链接 47.6 target 属性 HTML 文件中最重要的应用之一就是超链接。正因为有了超链接,互联网 上的各种资源才…

自动抓取App数据

随着移动互联网的快速发展&#xff0c;App已经成为我们日常生活中必不可少的一部分。而App数据的抓取和分析对于开发者、运营者以及市场研究人员来说变得越来越重要。今天&#xff0c;我们要为大家介绍一种神奇的方法——自动抓取App数据&#xff0c;让你的数据分析更加高效&am…

实用案例 | 用 Binning Explorer 小程序创建评分卡题

这个案例展示如何运用 MATLAB 中自带的 Binning Explorer 小程序来创建信用评级中的评分卡。 用 Binning Explorer 对样本进行分箱操作, 创建图表来展示分箱信息&#xff0c;并将创建的对象”creditscorecard”导出。 然后利用 creditscorecard 对象&#xff0c;结合 Financi…

基于深度学习路径规划RRT*-训练图像预处理

基于深度学习路径规划RRT*-训练图像预处理 图像预处理说明 在基于采样的RRT算法对机器人进行路径规划时&#xff0c;由于采样点的随机性&#xff0c;会增加路径的搜索时间的路径的非最优性&#xff0c;所以基于神经网络的优势&#xff0c;利用深度学习进行RRT的随机采样&…

使用webstrom编写vue开启提示

1.语言服务器选择 2.文件类型–忽略的文件和文件夹&#xff0c;删去&#xff0c;node_modules&#xff0c;就可以点进去库了 3.禁用JSLint、TSLint 4.开启node辅助 5.如果是vite&#xff0c;开启自动读取&#xff0c;或手动指定 6.如果是Webpack&#xff0c;开启自动读取&#…

go-zero开发入门-API网关开发示例

开发一个 API 网关&#xff0c;代理 https://blog.csdn.net/Aquester/article/details/134856271 中的 RPC 服务。 网关完整源代码 // file: main.go package mainimport ("flag""fmt""github.com/zeromicro/go-zero/core/conf""github.c…

Git提交代码时出现: ‘LF will be replaced by CRLF the next time Git touches it‘

遇到的问题 windows平台进行 git add 时&#xff0c;控制台打印警告 问题分析 1. Dos/Windows平台默认换行符&#xff1a;回车&#xff08;CR&#xff09;换行&#xff08;LF&#xff09;&#xff0c;即’\r\n’ 2. Mac/Linux平台默认换行符&#xff1a;换行&#xff08;LF&…

小调查:你申请的流量卡,快递员派件时让你激活并充话费了吗?

说到这个问题&#xff0c;就要给大家普及一下流量卡的激活方式了&#xff0c;并不是所有的流量卡快递都需要快递激活并充话费&#xff0c;只有在套餐详情种明确标注快递激活的流量卡才会有这个要求&#xff0c;自主激活的流量卡则不需要的。 如图所示&#xff1a; 接下来&#…

网络规划的组成

网络规划是网络建设过程中非常重要的环节&#xff0c;同时也是一个系统性的过程。网络规划应该以需求为基础&#xff0c;同时考虑技术和工程的可行性。具体来说&#xff0c;网络规划包括网络需求分析、可行性分析和对现有网络的分析与描述。 1.网络需求分析在网络组建之前&…

已通过考试和认证注册以及后续计划表

已通过考试和认证注册以及后续计划表 软考 - 计算机技术与软件专业技术资格&#xff08;水平&#xff09;考试信息系统集成及服务项目管理人员工程类考试计划你关注的证书样子 软考 - 计算机技术与软件专业技术资格&#xff08;水平&#xff09;考试 高级 信息系统项目管理师&…

鸿蒙开发组件之Image

Image组件加载图片方式有三种&#xff1a; 1、网络地址加载 直接Image(xxxx),添加上图片的网络地址就可以了。注意&#xff1a;真机、模拟题调试需要申请"ohos.permission.INTERNET"权限 Image(https://xxxxxxx) 2、PixelMap格式加载像素图 Image(PixelMapObjec…

整数在内存中的存储

整数和浮点数在内存中的存储方式是不一样的&#xff0c;今天&#xff0c;我们来具体学习一下 文章目录 整数在内存中的存储浮点数在内存中的存储 整数在内存中的存储 我们在之前就已经了解过了整数有原码&#xff0c;反码&#xff0c;补码的形式&#xff0c;这三种方式都是二进…

php使用vue.js实现省市区三级联动

参考gpt 有问题问gpt 实现效果 现省市区三级联动的方法可以使用PHP结合AJAX异步请求来实现。下面是一个简单的示例代码&#xff1a; HTML部分&#xff1a; <!DOCTYPE html> <html> <head><meta charset"UTF-8"><title>省市区三级联动…

【vtkWidgetRepresentation】第七期 vtkImplicitPlaneRepresentation

很高兴在雪易的CSDN遇见你 前言 本文分享vtkImplicitPlaneRepresentation源码剖析&#xff0c;及相关的实例&#xff0c;该接口主要用于切割交互&#xff0c;希望对各位小伙伴有所帮助&#xff01; 感谢各位小伙伴的点赞关注&#xff0c;小易会继续努力分享&#xff0c;一起…

TCP Keepalive 和 HTTP Keep-Aliv

HTTP的Keep-Alive 在http1.0的版本中&#xff0c;它是基于请求-应答模型和TCP协议的&#xff0c;也就是在建立TCP连接后&#xff0c;客户端发送一次请求并且接收到响应后&#xff0c;就会立马断开TCP连接&#xff0c;称为HTTP短连接&#xff0c;这种方式比较耗费时间以及浪费资…

亚马逊运营推荐数仓项目实战

亚马逊运营推荐数仓项目实战 项目技术栈 HadoopSpark (Python)Scala SparkSQLSparkStreaming MongoDB Redis Kafka Flume ( SpringMVC vue) 1 项目介绍 1.1 项目系统架构 项目以推荐系统建设领域知名的经过修改过的中文亚马逊电商数据集作为依托&#xff0c;以某电商…

《ReactJS实践入门》:引领JavaScript前端开发的革新之旅

在当今的软件开发世界中&#xff0c;ReactJS无疑是最为引人注目的JavaScript库之一。对于初学者来说&#xff0c;如何深入理解并掌握这一强大的前端工具&#xff0c;进而应用到实际开发中&#xff0c;一直是他们所面临的问题。而《ReactJS实践入门》一书&#xff0c;正是为了解…

单片机双机通信控制跑马灯

实验要求 两个单片机各驱动8个LED灯&#xff0c;构成两个跑马灯&#xff0c;要求甲单片机LED的点亮方式是从上至下&#xff0c;首先是最上面第一个点亮、其次是前两个点亮、其次是前三个点亮……直至8个灯全部点亮&#xff0c;8个灯全部灭&#xff0c;重复这个过程&#xff0c…

Qt 鼠标左键推拽界面

代码实现&#xff1a; button 返回 哪个按钮造成了此事件&#xff0c;buttons 返回 发生此事件时哪些按钮还处于按下状态 对于ComboBox这种控件有bug&#xff0c;我也不知道咋修改 private:// 记录坐标差值QPoint diff;QPoint now_pos;bool m_MouseDrag;void Dialog::mousePr…