自动化测试执行的用例有很多,python额测试用例文件,都是以“test”开头的。
TestLoader(defaultTestLoader)是unittest的测试用例加载器,它包括多个加载测试用例的方法。它的结果是返回一个测试套件。本文介绍discover()用法与功能
结构:
discover(start_dir, pattern='test*.py', top_level_dir=None)
作用:找到指定目录下所有测试用例模块,并递归查询子目录下的测试模块,找到匹配的文件进行加载。
解释:
start_dir:需要测试的用例文件目录或是模块
pattern:用例匹配原则
top_level_dir:测试模块的顶层目录,没有就默认None。
例子:
#coding=utf-8 import unittest #定义测试用例的目录为当前目录 test_dir = './' discover = unittest.defaultTestLoader.discover(test_dir, pattern='test*.py') if __name__ == '__main__': runner = unittest.TextTestRunner() runner.run(discover)
注释:
1)discover = unittest.defaultTestLoader.discover(test_dir, pattern='test*.py') :匹配查找测试用例文件,以test*.py开头,并将查找到的测试用例组装到测试套件中
2)runner.run(discover) :通过run()函数执行discover
补充知识:unittest框架执行测试并发送邮件
我就废话不多说了,还是直接看代码吧!
#coding=utf8 import smtplib from email.mime.text import MIMEText from email.mime.multipart import MIMEMultipart from HTMLTestRunner import HTMLTestRunner from email.header import Header import unittest import time,os #==============定义发送邮件 =============== def send_mail(file_new): f = open(file_new,'rb') #读取测试报告正文 mail_body = f.read() f.close() #发送邮件的 smtpserver = 'smtp.exmail.qq.com' username = 'fengyanfang@innobuddy.com' passwd = 'Fyf136066' sender = 'fengyanfang@innobuddy.com' receiver = ['fengyanfang@innobuddy.com'] tname = time.strftime('%Y-%m-%d %H-%M-%S',time.localtime()) header = u'%s 接口自动化测试报告 ' % tname # 只发正文,不发附件 msg = MIMEText(mail_body, 'html', 'utf-8') msg['Subject'] = Header('自动化测试报告', 'utf-8') msg['Header'] = header msg['From'] = sender msg['To'] = ",".join(receiver) #连接发送邮件 # 发送邮件,端口用465, keyfile = 'vxkdfejinpifbeaj' smtp = smtplib.SMTP_SSL(smtpserver, 465) smtp.helo(smtpserver) smtp.ehlo(smtpserver) smtp.login(username, passwd) smtp.sendmail(sender, receiver, msg.as_string()) smtp.quit() #======================查找最新的测试报告========================== def new_report(testreport): #方式1: # lists = os.listdir(testreport) # lists.sort(key = lambda fn: os.path.getmtime(testreport + '\\' + fn)) # file_new = os.path.join(testreport,lists[-1]) # print(file_new) # return file_new #方式2: dirs = os.listdir(testreport) dirs.sort() newreportname = dirs[-1] print('The new report name: {0}'.format(newreportname)) file_new = os.path.join(testreport, newreportname) return file_new if __name__ == '__main__': #获取当前的项目目录UskidInterface testdir = os.path.dirname(os.path.dirname(__file__)) test_dir = os.path.join(testdir,'testcase') test_report = os.path.join(testdir, 'report') discover = unittest.defaultTestLoader.discover(test_dir,pattern='test*.py') now = time.strftime("%Y-%m-%d %H_%M_%S",time.localtime()) filename = test_report+'/result_'+now+'.html' fp = open(filename,'wb') #stream放生成报告的路径 runner = HTMLTestRunner(stream=fp,title="测试报告",description='用例执行情况:') runner.run(discover) fp.close() new_report = new_report(test_report) send_mail(new_report)
以上这篇Python unittest 自动识别并执行测试用例方式就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]