unittest单元测试框架原理--理解

2024-08-20 21:08

本文主要是介绍unittest单元测试框架原理--理解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  • 一、unittest 框架最核心的四个概念:TestCase、TestSuite、TestRunner、Testfixture
  1. TestCase:自定义的测试用例类,里面写入的是对具体的某个模块进行测试的方法;所有的方法名都必须以test开头。TestCase中的方法和属性:
    • setup() 方法:用于测试用例执行前的初始化工作,每个测试方法执行前都会执行一次;比如:登录web页,访问数据库;
    • tearDown() 方法:用于测试用例执行完成后的清理工作;每个测试方法执行后都会执行一次;比如:关闭网页,断开链接;
    • assert*():一些断言方法:在执行测试用例的过程中,最终用例是否执行通过,是通过判断测试得到的实际结果和预期结果是否相等决定的。
      • assertEqual (a,b,[msg='测试失败时打印的信息']):断言a和b是否相等,相等则测试用例通过。
        assertNotEqual (a,b,[msg='测试失败时打印的信息']):断言a和b是否相等,不相等则测试用例通过。
        assertTrue (x,[msg='测试失败时打印的信息']):断言x是否True,是True则测试用例通过。
        assertFalse (x,[msg='测试失败时打印的信息']):断言x是否False,是False则测试用例通过。
        assertIs (a,b,[msg='测试失败时打印的信息']):断言a是否是b,是则测试用例通过。
        assertNotIs (a,b,[msg='测试失败时打印的信息']):断言a是否是b,不是则测试用例通过。
        assertIsNone (x,[msg='测试失败时打印的信息']):断言x是否None,是None则测试用例通过。
        assertIsNotNone (x,[msg='测试失败时打印的信息']):断言x是否None,不是None则测试用例通过。
        assertIn (a,b,[msg='测试失败时打印的信息']):断言a是否在b中,在b中则测试用例通过。
        assertNotIn (a,b,[msg='测试失败时打印的信息']):断言a是否在b中,不在b中则测试用例通过。
        assertIsInstance (a,b,[msg='测试失败时打印的信息']):断言a是是b的一个实例,是则测试用例通过。
        assertNotIsInstance (a,b,[msg='测试失败时打印的信息']):断言a是是b的一个实例,不是则测试用例通过。
    • 通过dir(unittest),可以看到unittest全部的属性和方法
  2. TestSuite:测试套件,用于装测试用例;使用addTest()方法手动增加Test Case到测试套件中;
  3. TestRunner:运行测试用例的驱动类,使用TestRunner中的run()方法来运行测试套件中的测试用例;
  4. Testfixture:可以把fixture看做是资源,在测试用例执行之前需要去配置这些资源,执行完后需要去释放资源。一个测试类,通常有多个测试方法,都需要某些共用的“数据”,比如说都需要起浏览器, 比如说都要访问某个数据库的某张表;Fixture:包括setUp和tearDown方法,有下面两种:
    • setUpClass(), tearDownClass()的方式,分别在每个测试类执行前后执行, setUpClass()和tearDownClass()只会执行一次,即使这个测试类有多个测试函数。
    • setup(), teardown()的方式,分别在每个测试方法执行前后执行。
  • 二、unitest 其他属性:
    • unittest.skip():装饰器,当运行用例时,有些用例可能不想执行等,可用装饰器暂时屏蔽该条测试用例。一种常见的用法就是比如说想调试某一个测试用例,想先屏蔽其他用例就可以用装饰器屏蔽。
      • @unittest.skip(reason): skip(reason)装饰器:无条件跳过装饰的测试,并说明跳过测试的原因。
      • @unittest.skipIf(reason): skipIf(condition,reason)装饰器:条件为真时,跳过装饰的测试,并说明跳过测试的原因。
      • @unittest.skipUnless(reason): skipUnless(condition,reason)装饰器:条件为假时,跳过装饰的测试,并说明跳过测试的原因。
      • @unittest.expectedFailure(): expectedFailure()测试标记为失败。
  •  

 

这篇关于unittest单元测试框架原理--理解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1091174

相关文章

MySQL中的表连接原理分析

《MySQL中的表连接原理分析》:本文主要介绍MySQL中的表连接原理分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、环境3、表连接原理【1】驱动表和被驱动表【2】内连接【3】外连接【4编程】嵌套循环连接【5】join buffer4、总结1、背景

Spring 框架之Springfox使用详解

《Spring框架之Springfox使用详解》Springfox是Spring框架的API文档工具,集成Swagger规范,自动生成文档并支持多语言/版本,模块化设计便于扩展,但存在版本兼容性、性... 目录核心功能工作原理模块化设计使用示例注意事项优缺点优点缺点总结适用场景建议总结Springfox 是

深度解析Spring AOP @Aspect 原理、实战与最佳实践教程

《深度解析SpringAOP@Aspect原理、实战与最佳实践教程》文章系统讲解了SpringAOP核心概念、实现方式及原理,涵盖横切关注点分离、代理机制(JDK/CGLIB)、切入点类型、性能... 目录1. @ASPect 核心概念1.1 AOP 编程范式1.2 @Aspect 关键特性2. 完整代码实

Java Stream的distinct去重原理分析

《JavaStream的distinct去重原理分析》Javastream中的distinct方法用于去除流中的重复元素,它返回一个包含过滤后唯一元素的新流,该方法会根据元素的hashcode和eq... 目录一、distinct 的基础用法与核心特性二、distinct 的底层实现原理1. 顺序流中的去重

Python的端到端测试框架SeleniumBase使用解读

《Python的端到端测试框架SeleniumBase使用解读》:本文主要介绍Python的端到端测试框架SeleniumBase使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全... 目录SeleniumBase详细介绍及用法指南什么是 SeleniumBase?SeleniumBase

Spring @Scheduled注解及工作原理

《Spring@Scheduled注解及工作原理》Spring的@Scheduled注解用于标记定时任务,无需额外库,需配置@EnableScheduling,设置fixedRate、fixedDe... 目录1.@Scheduled注解定义2.配置 @Scheduled2.1 开启定时任务支持2.2 创建

Spring Boot 实现 IP 限流的原理、实践与利弊解析

《SpringBoot实现IP限流的原理、实践与利弊解析》在SpringBoot中实现IP限流是一种简单而有效的方式来保障系统的稳定性和可用性,本文给大家介绍SpringBoot实现IP限... 目录一、引言二、IP 限流原理2.1 令牌桶算法2.2 漏桶算法三、使用场景3.1 防止恶意攻击3.2 控制资源

Python中使用uv创建环境及原理举例详解

《Python中使用uv创建环境及原理举例详解》uv是Astral团队开发的高性能Python工具,整合包管理、虚拟环境、Python版本控制等功能,:本文主要介绍Python中使用uv创建环境及... 目录一、uv工具简介核心特点:二、安装uv1. 通过pip安装2. 通过脚本安装验证安装:配置镜像源(可

Mysql的主从同步/复制的原理分析

《Mysql的主从同步/复制的原理分析》:本文主要介绍Mysql的主从同步/复制的原理分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录为什么要主从同步?mysql主从同步架构有哪些?Mysql主从复制的原理/整体流程级联复制架构为什么好?Mysql主从复制注意

Nacos注册中心和配置中心的底层原理全面解读

《Nacos注册中心和配置中心的底层原理全面解读》:本文主要介绍Nacos注册中心和配置中心的底层原理的全面解读,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录临时实例和永久实例为什么 Nacos 要将服务实例分为临时实例和永久实例?1.x 版本和2.x版本的区别