Junit 整合-ApiHug准备-测试篇-013

    🤗 ApiHug × {Postman|Swagger|Api...} = 快↑ 准√ 省↓

  1. GitHub - apihug/apihug.com: All abou the Apihug   
  2. apihug.com: 有爱,有温度,有质量,有信任
  3. ApiHug - API design Copilot - IntelliJ IDEs Plugin | Marketplace

这里简单演示一个对 mockito 的通过扩展的整合,例子在 junit5>mockitoopen in new window

例子中我们将演示, 如果通过 mockito 实现对于 @Mock 对象自动用 mockito 扩展例子。

#依赖


testImplementation 'org.mockito:mockito-core:4.6.1'
testImplementation 'org.mockito:mockito-junit-jupiter:4.6.1'

#应用

基本的几个服务类:

└─mockito│  User.java│├─repository│      MailClient.java│      SettingRepository.java│      UserRepository.java│└─serviceDefaultUserService.javaErrors.javaUserService.java

测试类


@ExtendWith(MockitoExtension.class)
public class UserServiceUnitTest {UserService userService;SettingRepository settingRepository;@Mock UserRepository userRepository;@Mock MailClient mailClient;}`@Mock` 为我们测试注入 mock 对象, 在每个测试进行前,初始化 fixture:```java@BeforeEach
void init(@Mock SettingRepository settingRepository) {userService = new DefaultUserService(userRepository, settingRepository, mailClient);lenient().when(settingRepository.getUserMinAge()).thenReturn(10);when(settingRepository.getUserNameMinLength()).thenReturn(4);lenient().when(userRepository.isUsernameAlreadyExists(any(String.class))).thenReturn(false);this.settingRepository = settingRepository;
}

注意 Mockito.lenient Mockito 对处理未使用的 mock 对象会抛出 UnsupportedStubbingException 所以这里用 lenient 避免抛出这样的异常。

然后看具体测实测用例:


@Test
void givenValidUser_whenSaveUser_thenSucceed(@Mock MailClient mailClient) {// Givenuser = new User("Jerry", 12);when(userRepository.insert(any(User.class))).then(new Answer<User>() {int sequence = 1;@Overridepublic User answer(InvocationOnMock invocation) throws Throwable {User user = (User) invocation.getArgument(0);user.setId(sequence++);return user;}});userService = new DefaultUserService(userRepository, settingRepository, mailClient);// WhenUser insertedUser = userService.register(user);// Thenverify(userRepository).insert(user);Assertions.assertNotNull(user.getId());verify(mailClient).sendUserRegistrationMail(insertedUser);
}

我们

api-hug-contact

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

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

相关文章

第G8周:ACGAN任务

&#x1f368; 本文为&#x1f517;365天深度学习训练营 中的学习记录博客&#x1f356; 原作者&#xff1a;K同学啊 | 接辅导、项目定制&#x1f680; 文章来源&#xff1a;K同学的学习圈子 参考论文 这周主要任务就是根据之前GAN&#xff0c;CGAN&#xff0c;SGAN网络架构搭建…

在PostgreSQL中如何实现递归查询,例如使用WITH RECURSIVE构建层次结构数据?

文章目录 解决方案使用WITH RECURSIVE进行递归查询示例代码 总结 在PostgreSQL中&#xff0c;递归查询是一种非常强大的工具&#xff0c;它可以用来查询具有层次结构或树形结构的数据。例如&#xff0c;你可能会在员工-经理关系、目录结构或组织结构图中遇到这样的数据。为了处…

12.Hexo helpers类似函数和data folder数据文件夹

helper Hexo里的helper&#xff0c;或者说是函数 基本上就是小函数&#xff0c;可以在layout布局中使用&#xff0c;可以允许做一些事情 如字符串操作、检查true或false、检查是否在一个页面上、打印出某个页面中的日期或时间特定格式 打开index.ejs trim 可以通过 <%…

模拟电子技术实验(八)

多选题 1.本次实验的目的包括验证的工作原理&#xff1f; A. 反向加法器 B. 过零比较器 C. 滞回比较器 D. 反向比例放大器 答案&#xff1a;BC 评语&#xff1a;10分 单选题 2.该实验稳压管均为左右&#xff1f; A. 4V B. 5V C. 6V …

3.AlexNet--CNN经典网络模型详解(pytorch实现)

看博客AlexNet--CNN经典网络模型详解&#xff08;pytorch实现&#xff09;_alex的cnn-CSDN博客&#xff0c;该博客的作者写的很详细&#xff0c;是一个简单的目标分类的代码&#xff0c;可以通过该代码深入了解目标检测的简单框架。在这里不作详细的赘述&#xff0c;如果想更深…

SVN泄露(ctfhub)

目录 下载安装dvcs-ripper 使用SVN 一、什么是SVN&#xff1f; 使用SVN能做什么&#xff1f; 二、SVN泄露&#xff08;ctfhub&#xff09; SVN源代码漏洞的主要原因&#xff1a; 工具准备&#xff1a;dirsearch、dvcs-ripper 网络安全之渗透测试全套工具篇&#xff08;内…

车载电子电器架构 —— 功能安全开发(首篇)

车载电子电器架构 —— 功能安全开发 我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 屏蔽力是信息过载时代一个人的特殊竞争力,任何消耗你的人和事,多看一眼都是你的不对。非必要不费力证明自己…

ACE框架学习2

目录 ACE Service Configurator框架 ACE_Server_Object类 ACE_Server_Repository类 ACE_Server_Config类 ACE Task框架 ACE_Message_Queue类 ACE_TASK类 在开始之前&#xff0c;首先介绍一下模板类的实例化和使用。给出以下代码 //ACCEPTOR代表模板的方法 template <…

【数据结构项目】通讯录

个人主页点这里~ 原文件在gitee里~ 通讯录的实现 基于动态顺序表实现通讯录项目1、功能要求2、代码实现file.hfile.cList.hList.ctest.c 基于动态顺序表实现通讯录项目 准备&#xff1a;结构体、动态内存管理、顺序表、文件操作 1、功能要求 ①能够存储100个人的通讯信息 ②…

在PostgreSQL中如何实现分区表以提高查询效率和管理大型表?

文章目录 解决方案1. 确定分区键2. 创建分区表3. 数据插入与查询4. 维护与管理 示例代码1. 创建父表和子表2. 插入数据3. 查询数据 总结 随着数据量的增长&#xff0c;单一的大型表可能会遇到性能瓶颈和管理难题。PostgreSQL的分区表功能允许我们将一个大型表分割成多个较小的、…

一线实战,一次底层超融合故障导致的Oracle异常恢复

背景概述 某客户数据由于底层超融合故障导致数据库产生有大量的坏块&#xff0c;最终导致数据库宕机&#xff0c;通过数据抢救&#xff0c;恢复了全部的数据。下面是详细的故障分析诊断过程&#xff0c;以及详细的解决方案描述&#xff1a; 故障现象 数据库宕机之后&#xff0c…

Docker - 镜像、容器、仓库

原文地址&#xff0c;使用效果更佳&#xff01; Docker - 镜像、容器、仓库 | CoderMast编程桅杆Docker - 镜像、容器、仓库 提示 这个章节涉及到 Docker 最核心的知识&#xff0c;也是在使用过程中最常使用到的&#xff0c;需要重点学习。 什么是Docker镜像、容器、仓库&…