通过之前的学习,了解到了如何利用excel进行读取数据,如何采用DDT数据驱动,如何使用unittest。下面是将之前所学进行结合,并发送邮件-->leader,废话不多说,上代码:

email_report.py

 # -*- coding: utf-8 -*-
# @Time : 2019/3/29/029 20:55
# @Author : bing
# @File : email_report.py
# @Software: PyCharm import smtplib
import time
from email.mime.text import MIMEText
from email.mime.multipart import MIMEMultipart
from email.mime.application import MIMEApplication
from email.header import Header
class email_Smtp:
'''smtp-email sendemail'''
def __init__(self,email_User,email_Pwd,to_Email_user):
self.email_User = email_User
self.to_Email_user = to_Email_user
self.server = smtplib.SMTP_SSL("smtp.qq.com", 465)
self.server.login(email_User, email_Pwd) def send_email_msg(self,file_path):
test_Time = str(time.strftime("%Y_%m_%d", time.localtime()))
test_file_name = test_Time + "_testCase_request_Report.html"
msg_total = MIMEMultipart() # multipart类型主要有三种子类型:mixed、alternative、related 默认mixed
msg_total['From'] = Header("Test-Mine", 'utf-8')
msg_total['To'] = Header("leader", 'utf-8')
msg_total['Subject'] = '测试报告'
# 正文模块
msg_raw = open(file_path,"r",encoding='utf-8').read()
msg = MIMEText(msg_raw, 'html')
msg_total.attach(msg)
# 附件模块
mfile = MIMEApplication(open(file_path,"rb").read())
# 添加附件的头信息
mfile.add_header('Content-Disposition', 'attachment', filename=test_file_name)
# 附件摸快添加到总的里面
msg_total.attach(mfile)
self.server.sendmail(self.email_User , self.to_Email_user , msg_total.as_string())
print("邮件发送成功!请查收")

excel_file.py

 from openpyxl import load_workbook
import json
class RwExcelFile: def read_Excel_Case(self,file_path):
"""获取excel的登录信息,保存到列表里面"""
excel_File = load_workbook(file_path)
sheet = excel_File.worksheets[0] login_datas = []
for row in range(2, sheet.max_row + 1):
user = {
"method": sheet.cell(row, 1).value,
"data": json.loads(sheet.cell(row, 2).value),
"exp_data": sheet.cell(row, 3).value,
"case_id": sheet.cell(row, 6).value,
}
login_datas.append(user)
excel_File.close()
return login_datas def read_Excel(self,file_path,sheet_name,start_row,start_cloumn):
'''
读取excel中所有数据并以列表形式返回
:param file_path:
:return:
'''
excel_File = load_workbook(file_path)
sheet = excel_File[sheet_name]
list_column = []
list_row = []
for i in range(start_row,sheet.max_row+1):
for j in range(start_cloumn,sheet.max_column+1):
list_column.append(sheet.cell(i,j).value)
list_row.append(list_column)
list_column = []
excel_File.close()
return list_row def write_Excel(self,file_path,sheetname,row,cloumn,T_value):
'''
向excel指定位置写入值
:param file_path: 文件地址
:param sheetname: sheet名
:param row: 行
:param cloumn:列
:param T_value: 值
:return: 无返回
'''
excel_File = load_workbook(file_path)
excel_File[sheetname].cell(row,cloumn,T_value)
excel_File.save(file_path)
excel_File.close()

request_login.py

import requests
class Interface_Request: def __init__(self,mobilephone,pwd):
'''login参数初始化'''
self.url = '****'
self.dict = {'mobilephone':mobilephone,'pwd':pwd} def http_request(self,way):
'''login接口请求'''
if way=='get':
return requests.get(self.url,self.dict).text
elif way=='post':
return requests.post(self.url,self.dict).text

testCase_request.py

import unittest
from excel_file import *
from request_login import Interface_Request
from ddt import ddt,unpack,data @ddt#@ddt装饰测试类 unittest.TestCase的子类
class TestRequest(unittest.TestCase,RwExcelFile):
@data(*RwExcelFile().read_Excel_Case('request测试数据.xlsx'))
@unpack
def test_001(self,method,data,exp_data,case_id):
print('Test_login,验证:',exp_data)
expected=exp_data#期望值
res=Interface_Request(data["mobilephone"],data["pwd"]).http_request(method) #实际值
#断言
try:
self.assertEqual(expected,json.loads(res)['msg'])
row = int(case_id) + 1
RwExcelFile().write_Excel('request测试数据.xlsx', "Sheet1", row, 5, 'pass')
except AssertionError as e:
# logging
# 测试不通过的结果: “failed” 写到 Excel
row = int(case_id) + 1
RwExcelFile().write_Excel('request测试数据.xlsx',"Sheet1",row,5,'failed')
raise

testSuite_Run.py

 import unittest
import HTMLTestRunnerNew
import time
from email_report import email_Smtp
from Test import testCase_request loader=unittest.TestLoader()#用例的加载器
suite=unittest.TestSuite()#创建了一个对象
suite.addTest(loader.loadTestsFromModule(testCase_request))#注意引入的是模块名不是类名,这里犯过错 #执行并生成html测试报告--HTMLTestRunnerNew
test_Time = str(time.strftime("%Y_%m_%d", time.localtime()))
test_file_name = test_Time+"_testCase_request_Report.html"
with open(test_file_name,'wb+') as file:
runner=HTMLTestRunnerNew.HTMLTestRunner(
stream=file,
verbosity=2,
title='测试报告',
description='request测试报告',
tester='Test_Mine'
)#创建一个对象来执行用例
runner.run(suite)#这一行没有任何改变 email_Smtp("****@qq.com", "密钥" , "*****@qq.com").send_email_msg(test_file_name)

邮件截图:

python3 通过邮件发送测试报告的更多相关文章

  1. Java+Selenium3框架设计篇5-如何实现邮件发送测试报告

    https://blog.csdn.net/u011541946/article/details/77278837 本篇继续回答网友的问题,这个主题是如何通过邮件发送测试报告.通过邮件发送测试报告,这 ...

  2. Jenkins配置邮件发送测试报告

    前言 在之前的文章(Jenkins自动执行python脚本输出测试报告)中,我们已成功实现利用Jenkins自动执行python脚本,输出并可直接在界面上查看测试报告,这里我们还差最后一步,我们需要将 ...

  3. Python添加邮件附件并通过邮件发送测试报告

    import smtplib from email.mime.multipart import MIMEMultipart from email.mime.text import MIMEText c ...

  4. python3实现邮件发送程序

    刚开始的想法很简单,由于有上千封的邮件需要发出去,并且需要一条一条发送,不能转发或群发,每条邮件要署对方的姓名,并加上几个相同的符件,考虑到手工操作繁琐无趣,所以想到用程序实现,python好像非常胜 ...

  5. Jenkins发送测试报告

    邮件全局配置 邮件插件:Email Extension Plugin 功能:发送邮件 邮件全局配置:jenkins--系统管理--系统配置:截图: 配置说明: 系统管理员邮件地址:必须配置,配置后邮件 ...

  6. python3 邮件方式发送测试报告

    以邮件方式发送测试报告 import smtplib from email.mime.text import MIMEText class SendEmail: """邮 ...

  7. 【Python + Selenium3】自动化测试之DDT数据驱动并生成测试报告以及用yagmail邮件发送文件

    我的文件路径 一.DDT代码: import unittest from time import sleep from selenium import webdriver from ddt impor ...

  8. python3 邮件发送

    这是搜罗网络上的文章总结的一份文档, 参考: https://www.jb51.net/article/140604.htm https://www.jb51.net/article/140604.h ...

  9. Python Selenium unittest+HTMLTestRunner实现 自动化测试及发送测试报告邮件

    1.UI测试框架搭建-目录结构 2. 文件介绍 2.1.baseinfo->__init__.py 配置文件定义基础参数 #-*-coding:utf-8-*- #测试用例配置参数 base_u ...

随机推荐

  1. 《11招玩转网络安全》之第五招:DVWA命令注入

    首先还是将DVWA的安全级别设置为Low,然后单击DVWA页面左侧的Command Injection按钮. ​ 图5-1  Low级别的命令注入 这个就是最典型的命令注入接口.在文本框中输入一个IP ...

  2. 提取 linux 文件目录结构

    提取 linux  文件的目录结构 find /home/user1/ -type d |while read line ;do mkdir -p /home/user2/$line;done

  3. Arduino—运算符

    赋值运算符: =    +=   -+     *=      /= %=       取余等于 &=    与等于 &=(与等于)对某个变量的值按位进行与运算,例如:G&=x ...

  4. 关于ElementUI中MessageBox弹框的取消键盘触发事件(enter,esc)关闭弹窗(执行事件)的解决方法

    好久没见了 在项目中遇到一个小小的需求,总结了一下! 详细我就不介绍了,相信大家用过的话,很了解.详见文档-----------> http://element-cn.eleme.io/#/zh ...

  5. vscode-Live Server的使用心得

    一,安装Live Server插件(不详细说明了) 二,开启Server(服务) 有四种方式: 在窗口的最底部有Go Live可以点击,一旦点击,就会自动在浏览器中打开HTML文件 在HTML文件中右 ...

  6. Spring Boot系列(二) Spring Boot 之 REST

    Rest (Representational Stat Transer) 是一种软件架构风格. 基础理论 架构特性 性能 可伸缩 简化的统一接口 按需修改 组件通信透明 可移植 可靠性 架构约束 C/ ...

  7. string format的各类格式及用法

    数字 {0:N2} 12.36  数字 {0:N0} 13  货币 {0:c2} $12.36  货币 {0:c4} $12.3656  货币 "¥{0:N2}" ¥12.36   ...

  8. C# windows定时服务+服务邮箱发送

    protected override void OnStart(string[] args) { timer1 = new System.Timers.Timer(); // timer1 = new ...

  9. C#接口的简单创建及其用法

    我初次接触接口(Interface),对接口的作用有点迷茫,C#接口中包含方法.属性.索引器和事件的声明,但常用的接口中一般就是方法和属性,然而接口中并没有方法的具体实现代码(不能提供任何成员实现), ...

  10. java基础知识三 流

    Java 流(Stream).文件(File)和IOJava.io 包几乎包含了所有操作输入.输出需要的类.所有这些流类代表了输入源和输出目标. Java.io 包中的流支持很多种格式,比如:基本类型 ...