python+unittest

1.unittest简介

unittest库包括:TestCase、TestSuite、TestLoder、TextRunner、TextTestResult、TestFixture

TestCase是测试的最小单元模块。它检查对特定输入集合的特定响应。unittest提供给一个基类Testcase,可以使用这个类创建一个新测试testTestCase 。

TestSuite是测试集,测试集是测试用例、测试集或者二者的一个集合。它被用于把测试整合在一起,批量运行测试。

TestLoder是用来加载 TestCase到TestSuite中,其中有几个loadTestsFrom_()方法,就是从各个地方寻找TestCase,创建他们的实例,然后add到TestSuite中,再返回一个TestSuite实例

TextRunner是运行测试器, 测试运行器是协调测试执行并向用户提供结果的组件。运行器可以使用图形界面、文本界面、或返回特定值来指示执行测试的结果。

TextTestResult测试结果会保存到TextTestResult实例中,包括运行了多少用例,成功与失败多少等信息

TestFixture表示执行一个或者多个测试前的准备工作,确保每个测试之间的独立性。这可能涉及到创建临时或者代理数据库、目录、服务器情动进程等相关准备工作

2.unittest的使用


# 步骤1、引入单元测试库

import unittest

# 步骤2:定义测试类,继承TestCase类。

class MyTestClass(unittest.TestCase):

 # 在测试类当中,所有用例运行之前,执行的前置工作。不管有几个用例,且只运行一次。
    # 有3个用例,在第一个用例运行之前,运行一次。
    @classmethod
    def setUpClass(cls):
        print("====我是测试类级别的前置工作===整个测试类,只运行1次!在用例执行之前!====")

    # 在测试类当中,所有用例运行之后,执行的后置工作。不管有几个用例,且只运行一次。
    @classmethod
    def tearDownClass(cls):
        print("====我是测试类级别的后置工作===整个测试类,只运行1次!在所有用例执行完成之后!====")
# 每一条用例运行之前,前置工作
    def setUp(self):
        print("=====开始运行  一条用例======")

    # 每一条用例运行之后,后置工作
    def tearDown(self):
        print("=====一条用例  运行结束======")
   # 其中函数名称以test_开头的,是一个测试用例。
    def test_upper(self):
        print("***************************")
        # 1、测试数据
        my_str = "iDo"
        # 2、步骤
        res = my_str.upper()
        # 3、断言 == 期望结果与实际结果比对。
        self.assertEqual(res, "IDO", " 不是大写")  # 如果期望与实际不符,那么AssertionError

    def test_upper_is_true(self):
        print("***************************")
        # 1、测试数据
        my_str = "iDo"
        # 2、步骤
        res = my_str.isupper()
        # 期望:True  实际的:res
        self.assertTrue(res)

    def test_who_bigger(self):
        print("***************************")
        # 1、测试数据
        a, b = 100, 244
        # 期望:小于
        self.assertLess(a, b)

 

posted @ 2020-11-05 11:46  越长大越孤单哦  阅读(289)  评论(0编辑  收藏  举报