Unittest中测试用例的编写规范
1、定义一个测试用例类,必须继承unitest模块中TestCase
2、测试用例类中,一个test开头的方法就是一条测试用例
3、将测试用例执行的代码逻辑写到对应的测试方法中
第一步:准备用例数据
第二步:调用北侧的功能函数(发送请求调用接口)
第三步:断言
run.py
第一步:创建测试套件,加载测试用例到套件
1、创建套件
suite=unittest.Testsuite()
2、创建一个用例加载器
load=unittest.TestLoader()
3、加载测试用例到套件
suite.addTest(load.discover(r’C:\project\testcase’))
上面三行替换成一行:
suite=unittest.defaultTestLoader.discover(r’C:\project\testcase’)
第二部:创建一个测试用例运行程序
runner=unittest.TextTestRunner
第三步:运行用例(无测试报告)
runner.run(suite)
生成报告:
①生成报告模板HTMLTestRunner模块(比较丑且相对不好用)
注:
1.安装并导入HTMLTestRunner 模块,该模块是可以生成报告的模块。
2.运行代码时,要以Run xx.py方式运行,不能以unittest方式运行,否则不会生成报告。
import unittest #单元测试模块
import HTMLTestRunner #用来生成报告的模块
class TestCalc(unittest.TestCase):
def testcc(self): #函数名要以test开头,否则不会被执行
'''这是第一个测试用例''' #用例描述,在函数下,用三个单引号里面写用例描述
self.assertEqual(1,1)
print('第一个用例')
def testaa(self):
'''这个是第二个测试用例'''
self.assertEqual(1,2)
print('第二个用例')
def testdd(self):
'''用例描述3'''
print('第三个用例')
def testbb(self):
'''用例描述4'''
print('第四个用例')
suite = unittest.TestSuite() #定义一个测试集合
suite.addTest(unittest.makeSuite(TestCalc)) #把写的用例加进来(将TestCalc类)加进来
f = open('test.html','wb') #以二进制模式打开一个文件
runner = HTMLTestRunner.HTMLTestRunner(f,title='unittest用例标题',description='这是用例描述')
runner.run(suite) #运行用例(用例集合)
在浏览器打开生成的test.html文件,HTMLTestRunner报告如图:
②报告模板BeautifulReport(模板相对好用)
import unittest #单元测试模块
from BeautifulReport import BeautifulReport as bf #导入BeautifulReport模块,这个模块也是生成报告的模块,但是比HTMLTestRunner模板好看
class TestCalc(unittest.TestCase):
def setUp(self): #每个用例运行之前运行的
print('setup是啥时候运行的')
def tearDown(self): #每个用例运行之后运行的
print('teardown是啥时候运行的')
@classmethod
def setUpClass(cls): #在所有用例执行之前运行的
print('我是setUpclass,我位于所有用例的开始')
@classmethod
def tearDownClass(cls): #在所有用例都执行完之后运行的
print('我是tearDownClass,我位于多有用例运行的结束')
def testcc(self): #函数名要以test开头,否则不会被执行
'''这是第一个测试用例''' #用例描述,在函数下,用三个单引号里面写用例描述
self.assertEqual(1,1)
print('第一个用例')
def testaa(self):
'''这个是第二个测试用例'''
self.assertEqual(1,1)
print('第二个用例')
def testdd(self):
'''用例描述3'''
print('第三个用例')
def testbb(self):
'''用例描述4'''
print('第四个用例')
suite = unittest.TestSuite() #定义一个测试集合
suite.addTest(unittest.makeSuite(TestCalc)) #把写的用例加进来(将TestCalc类)加进来
run = bf(suite) #实例化BeautifulReport模块
run.report(filename='test',description='这个描述参数是必填的')
浏览器查看生成的报告页面:
框架如何解决自动化需求的4个问题:
问题1: 如何控制用例执行顺序
在unittest中,用例是以test开头的方法定义的,默认执行顺序是根据用例名称升序进行,如上面的用例,
实际执行顺序为:test_add–>test_divide–>test_is_prime,而不是用例定义的先后顺序。
在unittest中解决用例执行顺序的问题是使用TestSuite,代码如下:
问题2:如何让多个用例共用setup、teardown
unittest的setup、teardown会在每个用例执行前后执行一次,如上面测试用例类中有3个测试用例,
那么每个用例执行前会执行setup,执行后会执行teardown,即setup、teardown总共会调用三次,
但考虑实际自动化测试场景,多个用例只需执行一次setup,全部用例执行完成后,执行一次teardown,
针对该种场景,unittest的处理方法是使用setupclass、teardownclass,注意@classmethod的使用,
问题3:如何跳过用例
在自动化测试中,经常会遇到挑选用例的情况,在unittest中的解决方法是使用skip装饰器,
其中skip装饰器主要有3种:unittest.skip(reason)、unittest.skipIf(condition,reason)、
unittest.skipUnless(condition,reason),即在满足condition条件下跳过该用例,
问题4:如何生成html格式的测试报告
Unittest中默认生成的报告格式为txt,如果想生成html格式的报告,可以使用HtmlTestRunner模块,
安装后导入该模块,使用HTMLTestRunner代替默认的TextTestRunner()执行测试用例即可。实例代码如下: