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 ...
随机推荐
- 全排列(传统&&黑科技)
近期几次考试的一些题目暴力分都有用到全排列. 全排列是个好东西啊... 回想一下,我们最开始学到全排列是什么时候呢? 大概是学搜索的时候罢... 一.传统搜索算法 想复习可以戳 https://www ...
- Taro 采坑日常
组件事件传参只能在类作用域下的确切引用(this.handleXX || this.props.handleXX),或使用 bind. 组件中点击事件如下 // 组件 <AtListItem k ...
- javascript---DOM大编程2
编程挑战 现在利用之前我们学过的JavaScript知识,实现选项卡切换的效果. 效果图: 文字素材: 房产: 275万购昌平邻铁三居 总价20万买一居 200万内购五环三居 140万安家东三环 ...
- 题解报告:hdu 1166 敌兵布阵(线段树or树状数组)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1166 Problem Description C国的死对头A国这段时间正在进行军事演习,所以C国间谍头 ...
- 实现字符串的查找和替换 分类: c/c++ 2014-10-09 22:33 469人阅读 评论(0) 收藏
在字符串中查找目标字符串并将其替换为指定字符串,返回替换的次数.接口为 int find_str_replace(char *&str,const char *find_str,const c ...
- 随机L系统分形树 分类: 计算机图形学 2014-06-01 23:27 376人阅读 评论(0) 收藏
下面代码需要插入到MFC项目中运行,实现了计算机图形学中的L系统分形树. class Node { public: int x,y; double direction; Node(){} }; CSt ...
- 419 Battleships in a Board 甲板上的战舰
给定一个二维的甲板, 请计算其中有多少艘战舰. 战舰用 'X'表示,空位用 '.'表示. 你需要遵守以下规则: 给你一个有效的甲板,仅由战舰或者空位组成. 战舰只能水平或者垂直放置.换句话 ...
- [转]mysql日志详细解析
转自:http://pangge.blog.51cto.com/6013757/1319304 MySQL日志: 主要包含:错误日志.查询日志.慢查询日志.事务日志.二进制日志: 日志是mysql数据 ...
- logging模块基础3
1.logging模块的日志级别 CRITICAL = 50 #FATAL = CRITICAL ERROR = 40 WARNING = 30 #WARN = WARNING INFO = 20 D ...
- mac重启iterm后不会自动加载.bash_profile
我用的zsh,由于平时设置的环境变量都是在.bash_profile文件中,每次重启iterm后,都需要重启手动加载.bash_profile文件,很麻烦. 设置自动加载.bash_profile的方 ...