python3.6的requests库&HTMLTestRunner实现测试报告
'''
1. 在suite.addTest时,可以把需要的用例先写入一个列表list中,list当做addTest的参数;
2. 在unittest.main(verbosity=2)中,默认为1,设置为2,可以输出每个case的执行情况;
3. 所有用例的开始结尾,只运行一遍setup 和 teardown,那么用setUpClass 和 tearDownClass,注意装饰器;
4. 在不需要的case上写入@unittest.skip('"I don\'t want to run this case."'),就可以跳过它 5. skip装饰器一共有三个:
unittest.skip(reason)、
unittest.skipIf(condition, reason)、
unittest.skipUnless(condition, reason),
skip无条件跳过,
skipIf当condition为True时跳过,
skipUnless当condition为False时跳过。
6. 文件日期命名:now = time.strftime('%Y-%m-%M %H_%M_%S') ''' 注意:
1. 未加入HTMLTestRunner时,如下不可以被注销:

2. https 报warnning,直接把相关文件中的函数暴力注销:
open -a pycharm /Users/vivi/Library/Python/3.6/lib/python/site-packages/requests/packages/urllib3/connectionpool.py
注销844-851
3. HTMLTestRunner 只支持python2.7,需要修改一些地方,这个可以google,到处都有,很全面;
from unittest import TestCase
import requests
from play import LoggIn
import unittest
from requests.packages.urllib3.exceptions import InsecureRequestWarning
requests.packages.urllib3.disable_warnings(InsecureRequestWarning)
import HTMLTestRunner
import sys,time class TestLoggIn(TestCase): @classmethod
def setUpClass(self):
self.url = LoggIn.logUrl
print('do something before') @classmethod
def tearDownClass(self):
print('over')
pass # def setUp(self):
# self.url = LoggIn.logUrl
#
# def tearDown(self):
# pass def test_account_empty(self):
data = {'abbr': 'US', 'clientType': 'ios', 'dBrand': 'apple', 'imagePHeight': '736', 'imagePixels': '828', 'osVersion': 'iOS10.3', 'password': '******', 'rememberMe': '1','st': '1496557229892', 'udid': '9fa81f8b42277b1e9567e'} r= requests.post(self.url,data=data,verify=False)
result = r.json()
self.assertEqual(result['code'],'220120')
self.assertEqual(result['message'],'is empty!')
self.assertEqual(result['result'],'account or password is null') # @unittest.skip('"I don\'t want to run this case."')
def test_account_error(self):
data = {'abbr': 'US', 'clientType': 'ios', 'dBrand': 'apple', 'imagePHeight': '736', 'imagePixels': '828', 'loginAccount':'name123','osVersion': 'iOS10.3', 'password': '******', 'rememberMe': '1','st': '1496557229892', 'udid': '9fac416e2d75e77b1e9567e'} r= requests.post(self.url,data=data,verify=False)
result = r.json()
self.assertEqual(result['code'],'22012811')
self.assertEqual(result['message'],'account or password error thrid!')
self.assertEqual(result['result'],'account or password error third!') def test_account_pass(self):
data = {'abbr': 'US', 'clientType': 'ios', 'dBrand': 'apple', 'imagePHeight': '736', 'imagePixels': '828', 'loginAccount':'name','osVersion': 'iOS10.3', 'password': '***', 'rememberMe': '1','st': '1496557229892', 'udid': '9fac416e2d75e42277b1e9567e'} r= requests.post(self.url,data=data,verify=False)
result = r.json()
self.assertEqual(result['code'],'200')
self.assertEqual(result['message'],'success!')
self.assertEqual(result['result']['loginAccount'],'name')
self.assertEqual(result['result']['memberPicture'],'pre/diyrelease/320187/150365518619893164.jpg') if __name__ == '__main__':
# verbosity=2 详细输出每个case的执行结果
# verbosity=1 只输出对错:失败是 F,出错是 E,跳过是 S
# verbosity=0 不输出任何结果 # unittest.main(verbosity=2)
suite = unittest.TestSuite() # 添加到TestSuite中的case是会按照添加的顺序执行的
suite.addTest(TestLoggIn('test_account_empty'))
suite.addTest(TestLoggIn('test_account_error'))
suite.addTest(TestLoggIn('test_account_pass')) # 这样 用列表,和上面一个个添加一样的效果
# tests = [TestLoggIn('test_account_empty'),TestLoggIn('test_account_error'),TestLoggIn('test_account_pass')]
# suite.addTest(tests) # 执行测试用例
# runner = unittest.TextTestRunner()
# runner.run(suite) # 执行并写入文件
# suite.addTests(unittest.TestLoader().loadTestsFromTestCase(TestLoggIn)) # now = time.strftime('%Y-%m-%M %H_%M_%S',time.localtime(time.time()))
now = time.strftime('%Y-%m-%M %H_%M_%S')
filename ='/Users/vivi/PycharmProjects/testreport_html/report/'+ now + '_result.html'
# filename = '/Users/vivi/PycharmProjects/a.html'
fp = open(filename,'wb') runner = HTMLTestRunner.HTMLTestRunner(stream=fp,
title='Play LogIn Test',
description='generated by HTMLTestRunner.',
verbosity=2
)
runner.run(suite)
fp.close()
执行成功:


执行失败:

python3.6的requests库&HTMLTestRunner实现测试报告的更多相关文章
- python3爬虫之requests库基本使用
官方文档链接(中文) https://2.python-requests.org/zh_CN/latest/ requests 基于 urllib3 ,python编写. 安装 pip insta ...
- python3+requests库框架设计01-自动化测试框架需要什么?
什么是自动化测试框架 关于自动化测试框架的定义有很多,在我大致理解下就是把能实现不同功能的软件组合在一起,实现特定的目的,这就是一个简单的自动化测试框架. 接口自动化测试框架核心无非是选择 一个用来编 ...
- Python3.6安装及引入Requests库
本博客可能没有那么规范,环境之类的配置.只是让你直接开始编程写python. 至于各种配置网络上有多种方法. 本文仅代表我的观点的一种方法. 电脑环境:win10 64位 第一步:下载python. ...
- Python3下requests库发送multipart/form-data类型请求
[本文出自天外归云的博客园] 要模拟multipart/form-data类型请求,可以用python3的requests库完成.代码示例如下: #请求的接口url url = "url&q ...
- Python3.x(windows系统)安装requests库
Python3.x(windows系统)安装requests库 cmd命令: pip install requests 执行结果:
- Python3 urllib库和requests库
1. Python3 使用urllib库请求网络 1.1 基于urllib库的GET请求 请求百度首页www.baidu.com ,不添加请求头信息: import urllib.requests d ...
- python3好用的requests库
python3好用的requests库 requests是什么? requests是基于urllib编写的http库,支持python3,比urllib更好用,更简单.之前使用python写一些htt ...
- 关于python3 使用pycharm+unittest+html+HTMLTestRunner 测试用例运行正常,但却不能生成测试报告的解决方法
关于python3 使用pycharm+unittest+html+HTMLTestRunner 测试用例运行正常,但却不能生成测试报告的解决方法 这个问题我也遇到过,以下是解决办法 该方法适用于 ...
- python3添加requests库
1.资源下载 https://codeload.github.com/psf/requests/zip/master https://www.python.org/ https://files.pyt ...
随机推荐
- java 学习书籍
<Effective java> <深入理解java虚拟机> <Java并发编程实践> <Java Performance> <java解惑> ...
- centos7开启路由转发
centos7开启路由转发 编辑/etc/sysctl.conf,添加一下内容. vim /etc/sysctl.conf net.ipv4.ip_forward=1 net.ipv4.conf.al ...
- ROS学习笔记八:基于Qt搭建ROS开发环境
1 前言 本文介绍一种Qt下进行ROS开发的完美方案,使用的是ros-industrial的Levi-Armstrong在2015年12月开发的一个Qt插件ros_qtc_plugin,这个插件使得Q ...
- NDK(10)Android.mk各属性简介,Android.mk 常用模板--未完
参考 : http://blog.csdn.net/hudashi/article/details/7059006 1. Android.mk简介 Android.mk文件是GNU Makefile的 ...
- 223 Rectangle Area 矩形面积
在二维平面上计算出两个由直线构成的矩形叠加覆盖后的面积. 假设面积不会超出int的范围. 详见:https://leetcode.com/problems/rectangle-area/descrip ...
- ABP教程(三)- 开始一个简单的任务管理系统 – 后端编码
上一篇 我们介绍了什么是ABP,这一篇我们通过原作者的”简单任务系统”例子,演示如何运用ABP开发项目 创建实体 一般来说任务是需要分配给人来做的,所以我们创建两个实体模型类:Task和Persion ...
- ssm(Spring、Springmvc、Mybatis)实战之淘淘商城-第二天(非原创)
文章大纲 一.课程介绍二.整合淘淘商城ssm项目三.Mybatis分页插件PageHelper使用四.整合测试五.项目源码与资料下载六.参考文章 一.课程介绍 一共14天课程(1)第一天:电商行业 ...
- 如何在tomcat部署项目(用ip访问)
找了好长时间的错误,server.xml中一点错误也没有,但就是访问不到,最终发现就是服务器没有开放80端口的缘故. 服务器是Windows系统 1.控制面板=>系统和安全=>Window ...
- LN : leetcode 712 Minimum ASCII Delete Sum for Two Strings
lc 712 Minimum ASCII Delete Sum for Two Strings 712 Minimum ASCII Delete Sum for Two Strings Given t ...
- Java用SAX解析XML
要解析的XML文件:myClass.xml <?xml version="1.0" encoding="utf-8"?> <class> ...