1.unittest简介及入门案例
(1)什么是Unitest
Unittest是Python自带的单元测试框架,不仅适用于单元测试,还可用于Web、Appium、接口自动化测试用例的开发与执行。该测试框架可组织执行测试用例,并且提供丰富的断言方法,判断测试用例是否通过,并最终生成测试结果。
官网:https://docs.python.org/zh-cn/3.8/library/unittest.html
Unittest框架最核心的四个概念:
- test case: 测试用例
- test suite: 测试套件
- test runner: 用来执行测试用例和测试套件,并返回测试用例的执行结果
- TestLoader: 批量执行测试用例
(2)开发第一个Unitest程序
单元测试开发步骤:
- 用import语句引入unittest模块
- 测试的类都继承于TestCase类
- setUp() 测试前的初始化工作
- tearDown()测试后的清除工作
# -*- coding: UTF-8 -*-
import unittest
class UserTestCase(unittest.TestCase):
def setUp(self):
print("setUp 开始")
def tearDown(self):
print("tearDown 结束")
def testCase01(self):
print("testCase01")
def testCase02(self):
print("testCase02")
if __name__ == '__main__':
unittest.main()
2.TestCase之断言操作
TestCase
类提供了一些断言方法用于检查并报告失败。 下表列出了最常用的方法:
方法 | 检查对象 |
---|---|
assertEqual(a, b) | a == b |
assertNotEqual(a, b) | a != b |
assertTrue(x) | bool(x) is True |
assertFalse(x) | bool(x) is False |
assertIs(a, b) | a is b |
assertIsNot(a, b) | a is not b |
assertIsNone(x) | x is None |
assertIsNotNone(x) | x is not None |
assertIn(a, b) | a in b |
assertIsInstance(a, b) | isinstance(a, b) |
assertNotIsInstance(a, b) | not isinstance(a, b) |
(1)测试断言
上面代码增加断言配置运行
def testCase01(self):
print("testCase01")
self.assertEqual(1,2)
用例执行结果输出: verbosity 默认是1,为0的话最简洁,不输出每个用例执行结果,2 输出用例的详细执行结果。
(2)跳过某个用例的执行
# 在用例的方法上加上@unittest.skip注解
@unittest.skip("跳过当前用例执行")
def testCase02(self):
print("testCase02")
3.用例执行顺序TestSuite
(1)什么是TestSuite
- TestSuite用来确定测试用例的顺序,哪个先执行哪个后执行
- 如果一个class中有四个test开头的方法,则加载到suite中时则有四个测试用例,由TestLoder加载TestCase到TestSuite
- verbosity参数可以控制执行结果的输出,0 是简单报告、1 是一般报告、2 是详细报告 默认1 会在每个成功的用例前面有个“.” 每个失败的用例前面有个 “F”
# -*- coding: UTF-8 -*-
import unittest
class UserTestCase(unittest.TestCase):
def setUp(self):
print("setUp 开始")
def tearDown(self):
print("tearDown 结束")
def testCase01(self):
print("testCase01")
def testCase02(self):
print("testCase02")
def testCase03(self):
print("testCase03")
if __name__ == '__main__':
# 构造一个测试套件
suite = unittest.TestSuite()
# 单个添加:类名('方法名')的集合 ,addTest() 函数
suite.addTest(UserTestCase("testCase03"))
suite.addTest(UserTestCase("testCase02"))
suite.addTest(UserTestCase("testCase01"))
# 批量添加:addTests() 函数,传入一个数组
# suite.addTests([UserTestCase("testCase03"),UserTestCase("testCase02"),UserTestCase("testCase01")])
# 执行测试 TextTestRunner() 文本测试用例运行器,通过该类下面的run()方法来运行suite所组装的测试用例,入参为suite测试套件。
runner = unittest.TextTestRunner(verbosity=2)
# run()方法是运行测试套件的测试用例,入参为suite测试套件
runner.run(suite)
4.批量用例加载TestLoader
TestLoader() 用例加载器,我们可以通过把用例都存放在这里,然后再通过Suite进行批量执行,但无法对case进行排序。
if __name__ == '__main__':
# 构造一个测试套件
suite = unittest.TestSuite()
# 实例化loader
loader = unittest.TestLoader()
# 加载 UserTestCase 下的全部用例
suite.addTests(loader.loadTestsFromTestCase(UserTestCase))
runner = unittest.TextTestRunner(verbosity=2)
runner.run(suite)
5.多个文件用例加载Discover
discover 批量加载文件夹用例
- 参数:case_dir:待执行用例的目录。
- 参数:pattern:这个是匹配脚本名称的规则,test*.py意思是匹配test开头的所有脚本。
- 参数:top_level_dir:这个是顶层目录的名称,一般默认等于None就行了
if __name__ == '__main__':
# 获取用例路径
case_path = os.path.join(os.getcwd(),"case")
print(case_path)
discover = unittest.defaultTestLoader.discover(case_path, pattern="helloword.py", top_level_dir=None)
runner = unittest.TextTestRunner()
runner.run(discover)
OK,结束,记得三连哦!!!