unittest 和 request使用(断言,生成HTML测试报告),2024年最新已获万赞

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新软件测试全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上软件测试知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024b (备注软件测试)
img

正文

为什么要做单元测试?

  • 📕 单元测试之后,才是集成测试,单个单个的功能模块测试通过之后,才能把单个功能模块集成起来做集成测试,为了从底层发现bug,单元测试时可以减少合成后出现的问题。
  • 📒 越早发现bug越好,这样可以早点发现问题,不然问题累计到后面,很可能会因为一个做错了而导致整个模块甚至更大范围的推倒重来,对于时间和经费来说,是非常浪费的!
  • 📘 对于测试来说,单元测试就是为了执行用例,输入测试数据–》输出测试结果

Unittest介绍

1.Unittest组成部分

UnitTest是python的自动化测试框架,Unittest框架主要包含以下部分:

  • TestCase(测试用例)
  • TestSuite(测试套件,把多个TestCase集成到一个测试TestSuite)
  • TestRunner(执行测试用例)
  • TestLoader(自动从代码中加载多个测试用例TestCase)
  • Fixture(UnitTest特性)

(2)为什么使用Unitttest框架

  • 能够组织多个用例去执行
  • 提供丰富的断言方法
  • 能够生成测试报告(由于生成的测试报告简陋,我们选择其他插件实现)

现在我也找了很多测试的朋友,做了一个分享技术的交流群,共享了很多我们收集的技术文档和视频教程。
如果你不想再体验自学时找不到资源,没人解答问题,坚持几天便放弃的感受
可以加入我们一起交流。而且还有很多在自动化,性能,安全,测试开发等等方面有一定建树的技术大牛
分享他们的经验,还会分享很多直播讲座和技术沙龙
可以免费学习!划重点!开源的!!!
qq群号:110685036【暗号:csdn999】

TestCase

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24实现步骤: -   导包:``import unittest -   定义测试类: 新建测试类必须继承unittest.TestCase -   定义测试方法: 测试方法名称必须以test开头 -   调用unittest.main()执行测试用例   import unittest def my_sum(a,b): return a``+``b class MyTest(unittest.TestCase): #测试用例01 def test_01(``self``): print``(my_sum(``3``,``2``)) #测试用例02 def test_02(``self``): print``(my_sum(``1``,``6``)) #测试用例03 def test_03(``self``): print``(my_sum(``'abc'``,``9``)) #测试用例04 def test_04(``self``): print``(my_sum(``0``,``4``))

TestSuite

TestSuite可以把多个测试用例整合成一个测试套件

1 2 3 4(``1``).导包:``import unittest (``2``).导入测试用例文件: 用例文件命名应符合变量命名规则 (``3``).实例化TestSuite对象: suite``= unittest.TestSuite() (``4``).调用对象addTest方法: suite.addTest(用例文件名.类名(``"方法名"``))
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43# 预置条件: - 创建demo1.py, 内部编写测试用例 - 创建demo2.py, 内部使用测试套件, 加载多个测试用例     #demo1.py import unittest def my_sum(a,b): return a``+``b class MyTest(unittest.TestCase): #测试用例01 def test_01(``self``): print``(my_sum(``3``,``2``))     #测试用例02 def test_02(``self``): print``(my_sum(``1``,``6``))     #测试用例03 def test_03(``self``): print``(my_sum(``"abc"``,``9``))   #测试用例04 def test_04(``self``): print``(my_sum(``0``,``4``))   #demo02.py improt unittest import demo1 #实例化TestSuite对象 suite``=``unittest.TestSuite() suite.addTest(demo01.MyTest(``"test_01"``)) suite.addTest(demo01.MyTest(``'test_03'``))``# 注意: 此操作只是加载测试用例, 并未执行

makeSuite

1 2 3 4 5 6 7 8#makeSuite使用示例<br>import unittest from request_test.yun_test``import Yun_test # 加载到case套件里,实例化TestSuite对象 suite``= unittest.TestSuite() suite.addTest(unittest.makeSuite(Yun_test))

TestRunner

1 2 3 4 5 6 7 8 9#makeSuite使用示例 import unittest from request_test.yun_test``import Yun_test # 加载到case套件里,#实例化TestSuite对象 suite``= unittest.TestSuite() suite.addTest(unittest.makeSuite(Yun_test))<br><br>runner``=``unittest.TextTestRunner()<br>runner.run(suite)

TestLoader

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15import unittest # 将测试用例添加到套件里 # 生成套件对象 suite``= unittest.TestSuite() # <br>#实例化TestLoader对象,调用discover方法加载test04.py中全部的用例 suite``= unittest.TestLoader().discover(``'./'``,``'test04.py'``) # 执行suite对象中的用例 runner``= unittest.TextTestRunner() runner.run(suite)
1 2 3TestSuite 与 TestLoader 区别 TestSuite 需要手动添加测试用例(可以添加测试类,也可以添加测试类中某 个测试方法) TestLoader 搜索指定目录下指定开头.py 文件,并添加测试类中的所有的测试 方法,不能指定添加测试方法
Fixture
1 2 3 4 5 6 7 8 9# 了解Fixture: #Fixture 是一个概述,对一个测试用例环境的初始化和销毁就是一个Fixture。 #以开发的视角去理解, Fixture就像是Flask框架中的钩子. #特定的方法, 在测试用例执行前后进行执行. # Fixture存在控制级别: #不同的级别决定了执行的作用范围和时机 #    - 方法级别; #    - 类级别; #    - 模块级别;

方法级

1 2 3初始化(前置处理):``def setUp(``self``)``-``-``> 首先自动执行;``- 销毁(后置处理):``def tearDown(``self``)``-``-``> 最后自动执行;运行于测试方法的始末,即:运行一次测试方法就会运行一次setUp和tearDown
1 2 3 4 5 6 7 8 9 10 11 12import unittest class my_test01(unittest.TestCase): def setUp(``self``): print``(``"setUP 执行"``) def tearDown(``self``): print``(``"teardown 执行"``) def test_01(``self``): print``(``"my_test01 的 test01"``) def test_02(``self``): print``(``"my_test01 的 test02"``)

1 2 3- 初始化(前置处理): @``classmethod def setUpClass(``cls``):``-``-``> - 首先自动执行``- 销毁(后置处理): @``classmethod def tearDownClass(``cls``):``-``-``> - 最后自动执行运行于测试类的始末,即:每个测试类只会运行一次setUpClass和tearDownClass
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17import unittest class my_test01(unittest.TestCase): @classmethod    def setUpClass(``cls``): print``(``"setUPClass 执行"``) @classmethod    def tearDownClass(``cls``): print``(``"tearDownClass 执行"``) def setUp(``self``): print``(``"setUP 执行"``) def tearDown(``self``): print``(``"teardown 执行"``) def test_01(``self``): print``(``"my_test01 的 test01"``) def test_02(``self``): print``(``"my_test01 的 test02"``)

模块级

1 2 3- 初始化(前置处理):``def setUpModule()``-``-``> - 首先自动执行``- 销毁(后置处理):``def tearDownModule()``-``-``> - 最后自动执行运行于整个模块的始末,即:整个模块只会运行一次setUpModule和tearDownModule
1 2 3 4 5 6 7总结 -   必须继承 unittest.TestCase 类,setUp、tearDown 才是一个 Fixture; -   setUp,tearDown:如果一个类中有多个测试用例,每执行一个测试用例之 前会调用一次 setUp,之后会调用一次 tearDown; -   setUpClass,tearDownClass:如果一个类中有多个测试用例,执行所有测试用例之前只会     调用一次 setUpClass,之后只会调用一次 tearDownClass; -   setUpModule,tearDownModule:只在``import 导入这个模块时会调用一次 setUpModule,模块使用完成之后会调用一次 tearDownModule; -   setUpXXX:一般做初始化工作; -   tearDownXXX:一般做结束工作;

unittest 断言

序号断言方法断言描述
1assertTrue(expr, msg=None)验证 expr 是 true,如果为 false,则 fail
2assertFalse(expr, msg=None)验证 expr 是 false,如果为 true,则 fail
3assertEqual(expected, actual, msg=None)验证 expected==actual,不等则 fail
4assertNotEqual(first, second, msg=None)验证 first != second, 相等则 fail
5assertIsNone(obj, msg=None)验证 obj 是 None,不是则 fail
6assertIsNotNone(obj, msg=None)验证 obj 不是 None,是则 fail
7assertIn(member, container, msg=None)验证是否 member in container
8assertNotIn(member, container, msg=None)验证是否 member not in container

参数化

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注软件测试)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

参数化

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注软件测试)
[外链图片转存中…(img-XfvwxcjR-1713166067574)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值