Python unittest 自动识别并执行测试用例方式
作者:释梦燃 时间:2023-08-14 07:09:39
自动化测试执行的用例有很多,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)
来源:https://blog.csdn.net/ShiMengRan107/article/details/80169644
标签:Python,unittest,识别,用例
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
Golang远程调用框架RPC的具体使用
2024-02-16 01:50:02
在PyCharm下打包*.py程序成.exe的方法
2021-05-02 07:00:15
对python 多线程中的守护线程与join的用法详解
2021-08-11 10:56:51
python能在浏览器能运行吗
2023-05-11 14:32:07
python3的url编码和解码,自定义gbk、utf-8的例子
2022-08-02 10:07:39
Python实现扩展内置类型的方法分析
2021-10-18 02:05:06
利用python在excel里面直接使用sql函数的方法
2023-10-15 00:34:57
![](https://img.aspxhome.com/file/2023/1/81781_0s.jpg)
Mysql使用存储过程快速添加百万数据的示例代码
2024-01-19 21:51:26
非原型 不设计
2010-01-21 12:51:00
![](https://img.aspxhome.com/file/UploadPic/20101/21/prototype_01_banner1-27s.jpg)
golang 语言中错误处理机制
2024-04-25 13:21:39
Python实现滑动平均(Moving Average)的例子
2023-02-10 22:36:58
django 扩展user用户字段inlines方式
2022-02-28 00:50:14
MySQL 两张表数据合并的实现
2024-01-28 07:25:49
![](https://img.aspxhome.com/file/2023/4/128054_0s.png)
python logging 日志轮转文件不删除问题的解决方法
2023-07-06 20:04:30
教你如何使Python爬取酷我在线音乐
2021-02-18 14:13:01
![](https://img.aspxhome.com/file/2023/6/134716_0s.jpg)
python元组的概念知识点
2022-01-03 19:29:19
在Python函数中输入任意数量参数的实例
2022-07-09 04:58:08
ASP.NET Core基础之Startup类
2024-05-09 09:05:07
![](https://img.aspxhome.com/file/2023/2/129802_0s.jpg)
数据库Sql实现截取时间段和日期实例(SQL时间截取)
2024-01-27 01:38:29
![](https://img.aspxhome.com/file/2023/9/110319_0s.png)
使用Kubernetes集群环境部署MySQL数据库的实战记录
2024-01-14 15:30:16