Unittest测试框架基本使用[通俗易懂]

Unittest测试框架基本使用[通俗易懂]unittest单元测试

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

Unittest测试框架

1、UintTest是python内置的单元测试框架,具备编写用例、组织用例、执行用例、输出报告等自动化框架的条件

2、UintTest单元测试框架不仅适用于单元测试,还可以适用WEB自动化测试、接口自动化测试的开发与执行。用处还是比较广的

四大组件

testcase testfixture textsuite testrunner
在这里插入图片描述

测试套件:TestSuite

常用的方法如下:
⑴unittest.TestSuite()
①addTest():添加单个测试用例方法
②addTests([…]):添加多个测试用例方法,方法名存在一个列表
⑵unittest.TestLoader()
①loadTestsFromTestCase(测试类名):添加一个测试类
②loadTestsFromModule(模块名):添加一个模块
③discover(测试用例的所在目录):指定目录去加载,会自动寻找这个目录下所有符合命名规则的测试用例

import unittest
class Test(unittest.TestCase):
    def test_1(self):
        print(1)
    def test_3(self):
        print(3)
    def test_2(self):
        print(2)
    def test_4(self):
        print(4)
    def test_5(self):
        print(5)
    def add(self):
        print("这条样例不会被执行")

if __name__ =='__main__':
    #执行全部用例
    # unittest.main()
    # 创建套件
    suit = unittest.TestSuite()
    # 添加用例
    # suit.addTest(Test("test_3"))
    suit.addTests([Test("test_3"),Test("test_2")])
    # 执行用例
    run = unittest.TextTestRunner()
    run.run(suit)

测试固件:TestFixture

1、用于测试用例环境的搭建和销毁。即用例执行前的环境搭建,用例执行后环境的还原。通过覆盖TestCase的setUP()和tearDown()方法来实现

2、setUP()方法:
⑴初始化。在执行测试之前执行,用于准备本次测试所需环境
⑵比如测试前需要登录获取token等就是测试用例需要的环境
⑶比如在测试用例中需要访问数据库,那么可以在setUp()中建立数据库连接来进行初始化
⑷setUP()方法中还可以用来定义一些公共的变量(数据)、代码等。这样在整个测试类中都可以调用这些公共的变量、数据

3、tearDown()方法:
⑴在执行测试之后执行,用于在下一次执行测试前还原环境(跟setUP方法差不多)
⑵tearDown()方法的过程很重要,要为下一次测试留下一个干净的环境,以免影响下一次测试
⑶比如在tearDown()中清除数据库产生的数据,然后关闭连接

4、UintTest框架中的测试固件有两种使用方式
⑴一种是以测试方法(类方法)为维度的setUp()和tearDown():在执行每个测试方法的前后都会执行一次
⑵一种是以测试类(TestCase)为维度的setUpClass()和tearDownClass():在执行每个测试类的前后执行一次(测试方法前后就不会执行了)

第一种使用方式:

import unittest
class Test(unittest.TestCase):
    def setUp(self) -> None:
        print("打开浏览器")
    def test_1(self):
        print(1)
    def test_3(self):
        print(3)
    def test_2(self):
        print(2)
    def tearDown(self) -> None:
        print("关闭浏览器")

if __name__ =='__main__':
    # 执行全部用例
    unittest.main()

在这里插入图片描述
第二种使用方式:

import unittest
class Test(unittest.TestCase):

    @classmethod  # 指明这是个类方法以类为维度去执行的
    def setUpClass(cls):
        print("===开始执行测试===")

    def test_1(self):
        print(1)
    def test_3(self):
        print(3)
    def test_2(self):
        print(2)

    @classmethod  # 指明这是个类方法以类为维度去执行的
    def tearDownClass(cls):
        print("===结束执行测试===")
if __name__ =='__main__':
    # 执行全部用例
    unittest.main()

在这里插入图片描述

断言

import unittest
from selenium import webdriver


class Test(unittest.TestCase):

    def setUp(self) -> None:
        self.driver = webdriver.Firefox()
        self.driver.get("https://www/baidu.com")
        self.title = self.driver.title
        print(self.title)
        return self.title

    def test1(self):
        self.assertEqual(self.setUp(),"百度一下,你就知道")


if __name__ == '__main__':
    unittest.main()

跳过测试

unittest 提供了几个装饰器用于跳过测试:

import unittest

class MyTestCase(unittest.TestCase):
    # 跳过测试,参数为测试被跳过的原因
    @unittest.skip("demonstrating skipping")
    def test_nothing(self):
        self.fail("shouldn't happen")

    # 条件为真时,跳过测试
    @unittest.skipIf(1>3,"if true")
    def test_format(self):
        print("test_format")
        pass

    # 除非条件为真,否则跳过测试
    @unittest.skipUnless(1>3, "if not true")
    def test_windows_support(self):
        print("test_windows_support")
        pass

if __name__ == "__main__":
    unittest.main()

子测试

在一个测试中,传入不同的参数测试同一个方法,subTest 子测试可以满足这个需求,而且单个子测试的失败不影响后续子测试的执行。

import unittest

class NumbersTest(unittest.TestCase):

    def test_even(self):
        """ Test that numbers between 0 and 5 are all even. """
        for i in range(0, 6):
            with self.subTest(i==i):
                self.assertEqual(i % 2, 0)

if __name__ == "__main__":
    unittest.main()

在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/182048.html原文链接:https://javaforall.net

(0)
上一篇 2022年10月14日 下午3:46
下一篇 2022年10月14日 下午4:00


相关推荐

  • BP神经网络的Matlab实现——人工智能算法

    BP神经网络的Matlab实现——人工智能算法这几天在各大媒体上接触到了人工智能机器学习,觉得很有意思,于是开始入门最简单的机器算法——神经网络训练算法(NeuralNetworkTraining);以前一直觉得机器学习很高深,到处是超高等数学、线性代数、数理统计。入坑发现确实是这样!但是呢由项目实例驱动的学习比起为考试不挂科为目的的学习更为高效、实用!在遗传算法、神经网络算法的学习入门之后觉得数学只要用心看没问题的(即使是蒙特卡洛和马尔

    2022年6月10日
    51
  • log4j学习笔记–ConversionPattern参数详解– RollingFileAppender选项

    log4j学习笔记–ConversionPattern参数详解– RollingFileAppender选项1、rootLogger与rootCategory的区别rootLogger是新的使用名称,对应Logger类rootCategory是旧的使用名称,对应原来的Category类Logger类是Category类的子类,所以,rootCategory是旧的用法,不推荐使用2、格式参数a)例句:log4j.appender.stdout.layout.Conver

    2022年8月22日
    13
  • 打造自己的Android源码学习环境之一:序[通俗易懂]

    打造自己的Android源码学习环境之一:序[通俗易懂]打造自己的Android源码学习环境之一:序为什么要打造自己的Android源码学习环境有一个可以编译的Android源码环境,可以在任何自己想了解的源码中加上log信息,验证自己的理解是否准确,有助于理解Android的运行细节。做Android开发,了解Android的运行机制和原理是很有帮助的,尤其是想对Androidframework进行深度定制。面向的读者如果在手机厂商或者Android

    2022年5月5日
    45
  • 设备树中ranges属性理解[通俗易懂]

    设备树中ranges属性理解[通俗易懂]作者彭东林pengdonglin137@163.com文章来源http://www.cnblogs.com/pengdonglin137/p/7401049.html正文一、设备树下面是我们将要实验的设备树的例子:/{#address-cells=<1>;#size-cells=<1&g…

    2022年6月19日
    126
  • Nano-Banana AI:免费3D建筑模型生成器教程

    Nano-Banana AI:免费3D建筑模型生成器教程

    2026年3月15日
    1
  • IOS开发的基础知识建议收藏

    1.为什么对一个变量release后还要设为nil对一个变量release后,这个变量指向的内存释放了,但这个变量本身没变,仍指向原来的内存地址。若这个变量在释放后被访问,或者被重复release,

    2021年12月21日
    43

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号