unittest详解(四) 自动化测试用例实例
uniittest不仅适用于单元测试,还可以使用unittest测试框架设计和开发自动化测试用例,并自动生成测试报告。
那么如何自动生成测试报告呢,需要使用到HTMLTestRunner模块,这个模块需要自行安装,下载HTMLTestRunner.py文件放置python安装目录\Lib目录下即可。
HTMLTestRunner模块下载地址:http://tungwaiyip.info/software/HTMLTestRunner.html。
接下来介绍一下unittest框架编写自动化测试用例实例:
测试用例目录如下:
case_1目录中的py文件为单元测试用例,report1目录下保存执行测试用例的结果报告。
task_all.py代码如下:
#coding=utf-8 import unittest import os,time import HTMLTestRunner from Atest.case_1 import task1,task2 #HTMLTestRunner模块生成测试报告 #用例路径 case_path=os.path.join(os.getcwd(),'case_1') #报告存放路径 report_path=os.path.join(os.getcwd(),'report_1') #报告文件 now=time.strftime('%Y%m%d_%H:%M',time.localtime(time.time())) filename=report_path+now+"_result.html" fp=file(filename,'wb') #方法一:使用defaultTestLoader加载case_1目录下的所有测试用例,优点是加载方便,缺点是不能保证执行顺序,并生成测试报告。 def all_case_a(): discover=unittest.defaultTestLoader.discover(case_path,'task*.py',top_level_dir=None) return discover if __name__=='__main__': # runner=unittest.TextTestRunner() # runner.run(all_case_a()) runner=HTMLTestRunner.HTMLTestRunner(stream=fp,title=u'Atest测试用例执行',description=u'测试结果:') runner.run(all_case_a()) fp.close() #方法二:使用unittest.TestSuite加载测试用例,可自定义顺序进行执行,并生成测试报告。 all_case_b=unittest.TestSuite() list=[task1.task_a,task2.task_b] for i in list: all_case_b.addTest(unittest.makeSuite(i)) if __name__=='__main__': runner=HTMLTestRunner.HTMLTestRunner(stream=fp,title=u'Atest测试用例执行',description=u'测试结果:') runner.run(all_case_b) fp.close()
HtmlTestRunner无法生成报告的几种情况:
1.若不是使用with做文件的上下文管理,记得要fp.close() 关闭打开的文件,才可以保存。
fp = open(filename, 'wb') fp.close()
2.脚本中文字符要转码,如:u'中文'。小u 是避免中文引起的乱码问题.
3.同一脚本文件中,鼠标光标放置test函数右击,选择“unittest test”执行则无法生成报告,因为Pycharm 自带测试框架,需要点击Edit Configurations→Python tests→选中要删除的项目,这样就不会自动执行unittest。然后光标放置 if __name__ == "__main__": 处,执行脚本,报告文件生成成功。