unittest

一、unittest的组成:

1、TestCase(测试用例)
实际上是一个代码文件,TestCase书写真正的测试用例代码
2、TestSuite(测试套件)
用来管理测试用例,整合功能,将多个测试用例整合在一起
3、TestRunner(测试执行)
执行测试套件中的代码,执行测试用例
4、TestLoader(测试加载)
对TestSuite功能的补充,管理测试用例
5、Fixture(测试夹具)
书写在TestCase中,可以在每个方法执行前/后都会执行一次

二、TestCase的书写

1、导包

import unintest #导入unittest模块

2、自定义测试类

class TestDemo(unittest.TestCase): #创建一个测试类并集成unittest模块中的TestCase类

3、写测试用例

class TestDemo(unittest.TestCase):
    def test_method1(self):#测试方法1
        pass
    def test_method2(self):#测试方法2
        pass

4、执行测试用例

将鼠标光标放在测试类的后面则执行整个测试类中的用例,将鼠标放在测试方法后则只执行这个方法

注意事项
1、测试方法必须以test开头--def test_method(self):
2、如果代码文件以python方式运行之后需要新建代码文件复制写好的代码重新运行/或删除已有的运行方式
(修改之后右键运行有unittests for)
3、注意用例代码文件命名(不能以数字、字符开头,文件中不能包含中文、特殊字符)

三、TestSuite的书写

1、导包

import unintest #导入unittest模块

2、创建测试套件对象

suite = unittest.TestSuite()#定义一个测试套件suite

3、添加测试用例进入测试套件

#方式一:套件对象.addTest(测试类名('方法名'))-单个添加测试方法
suite.addTest(TestDemo('test_method1'))
#方式二:套件对象.addTest(unittest.makeSuite(测试类名))-将一个测试类中的所有方法都添加
suite.addTest(unittest.makeSuite(TestDemo))

四、TestRunner的书写

1、导包

import unintest #导入unittest模块

2、创建测试运行对象

runner = unittest.TextTestRunner()#定义一个测试运行对象runner

3、运行

语法:运行对象.run(套件对象)

runner.run(suite)

五、TestLoader的书写

1、导包

import unintest #导入unittest模块

2、创建测试加载对象并添加测试用例

语法:unittest.TestLoader().discover('用例所在路径','用例代码文件名')

suite = unittest.TestLoader().discover('文件所在路径','文件名')

注意:
1、一般建议使用相对路径
2、可以使用 * 通配符

3、执行

unittest.TextTestRunner().run(suite)

六、Fixture的书写

#方法级别
def setUp(self):
    pass#每个测试方法执行之前都会执行一遍
def tearDown(self):
    pass#每个测试方法执行之后都会执行一遍

#类级别
@classmethod
def setUpClass(self):
    pass#整个测试类执行之前执行一次
def tearDownClass(self):
    pass#整个测试类执行之后执行一次

#模块级别
#写在代码文件之前,直接定义函数
def setUpModule(self):
    pass
def tearDownModule(self):
    pass

七、断言

1、什么是断言:

让程序代替人工判断用例执行的结果是否符合预期

2、常见的断言方法

assertTrue(expr,msg=None)   #验证expr是true,如果为false,则fail
assertFalse(expr,msg=None)   #验证expr是false,如果为ture,则fail
assertEqual(expected,actual,msg=None)   #验证expected==actual,不相等则fail
assertNotEqual(first,second,msg=None)   #验证first!=second,相等则fail
assertIsNone(obj,msg=None)   #验证obj是None,不是则fail 
assertNotNone(obj,msg=None)   #验证obj不是None,是则fail 
assertIn(member,container,msg=None)   #验证member是否in container,不是则fail
assertNotIn(member,container,msg=None)   #验证member是否notin container,不是则fail

八、参数化与跳过

1、使用变量来代替具体的测试数据,使用传参的方式将具体的测试数据传递给变量

2、使用参数化需要先安装插件

命令行/terminal中执行以下命令

pip install parameterized

验证是否安装成功

pip list  #查看到parameterized则安装成功

3、如何使用参数化

测试场景:测试数据都会储存在json文件中
使用修饰器去调用json文件中的数据

import unittest
from parameterized import parameterized

data = [{"username":"szgadmin","password":"test123","expect":"登录失败"},
{"username":"szgadmin","password":"Test1234","expect":"登录成功"},
{"username":"szgadmin1","password":"Test1234","expect":"登录失败"}] #测试数据
def login():  #需要测试的函数
    pass

class Test_method1:
    #使用修饰器调用参数化函数
    @parameterized.expand(data)   
    def test_login(self,username,password,expect):#这里的形参需要与data中的参数一一对应
        self.assertEqual(expect,login()) #断言预期结果与login函数的返回结果是否一致

4、跳过

对于一些不满足测试条件的测试函数和测试类,可以使用跳过
用法:

#方式一:
@unittest.skip('跳过的原因')#没有任何判断条件,直接跳过
#方式二:
@unittest.skipif(判断条件,'跳过的原因')

九、测试报告

1、需要获取第三方的测试运行类模块,将其放在代码目录中然后再导包

2、使用第三方测试运行类去运行测试套件


runner=HTMLTestRunner(stream,verbosity,title,description)

#stream  必填 生成的测试报告文件对象,需要用'wb'方式去打开
#verbosity 非必填  测试报告详细程度 1简略 2详细
#title 非必填,测试报告标题
#description 非必填 描述信息




你可能感兴趣的:(unittest)