python接口自动化(二十五)--unittest断言——下(详解)
简介
本篇还是回归到我们最初始的话题,想必大家都忘记了,没关系看这里:传送门 没错最初的话题就是登录,由于博客园的登录机制改变了,本篇以我找到的开源免费的登录API为案例,结合 unittest 框架写 2 个用例。同样我们先来看一下接口文档。
接口文档
登录接口
请求方式:POST
请求地址:https://api.apiopen.top/developerLogin
Query参数名 | 类型 | 必需 | 描述 | 示例 e.g. |
---|---|---|---|---|
name | string | 是 | 用户名 | peakchao |
passwd | string | 是 | 密码 | 123456 |
返回示例:
{
"code": 200,
"message": "成功!",
"result": {
"apikey": "b9b3a96f7554e3bead2eccf16506c13e"
}
}
设计测试用例
1、针对以上接口文档,设计这个登录接口的测试用例
2、参考代码
1 # coding=utf-8 2 #1.先设置编码,utf-8可支持中英文,如上,一般放在第一行 3 4 #2.注释:包括记录创建时间,创建人,项目名称。 5 ''' 6 Created on 2019-4-28 7 @author: 北京-宏哥 8 Project:学习和使用unittest框架设计登录测试用例和断言-下篇 9 ''' 10 #3.导入requests和unittest模块 11 import requests 12 import unittest 13 #4.编写测试用例和断言 14 class Blog_login(unittest.TestCase): 15 def login(self, username, psw): 16 '''两个个参数:账号:username,密码:psw''' 17 url = "https://api.apiopen.top/developerLogin" 18 par = {"name": username, 19 "passwd": psw 20 } 21 res = requests.post(url, params=par) 22 # result1 = res.text # 字节输出 23 # print(result1) 24 return res.json() 25 26 def test_login1(self): 27 '''测试登录:正确账号,正确密码''' 28 username = "peakchao", # 正确账号,抓包获得的加密字符串 29 psw = "123456", # 正确密码,抓包获得的加密字符串 30 result = self.login(username, psw) 31 self.assertEqual(200,result['code']) 32 print(result['message']) 33 34 def test_login2(self): 35 '''测试登录:正确账号,错误密码;反之也可以设计用例''' 36 username = "peakchao",#正确账号 37 psw = "122222",#错误密码 38 result = self.login(username, psw) 39 self.assertEqual(result['code'], 400) 40 print(result['message']) 41 def test_login3(self): 42 '''测试登录:账号为空,正确密码;反之也可以设计用例''' 43 username = "", # 错误账号 44 psw = "123456", # 正确密码 45 result = self.login(username, psw) 46 self.assertEqual(result['code'], 400) 47 print(result['message']) 48 if __name__ == "__main__": 49 unittest.main()
无接口文档
1、在实际工作中由于某些原因开发人员不能按时给出接口文档,但是接口已经开发好了,需要测试人员提前介入,此时你又不能等接口文档写好了再开始测试,那样黄花菜都凉了,还有就是接口文档有是有,但是没有人更新和维护,如果你按
照旧文档保证是会出错,或者接口不通。所以我们必须采用另一种方式开始测试接口。
2、那就是我们自己通过fiddler抓包获取url和接口的参数以及返回结果等等,还是由于博客园的登录机制的改变,我在这了一jenkins登录接口为例给小伙伴们演示一下。
3、大致流程:web页面jenkins点击登录—>fiddler抓包获取登录接口URL和参数—>从fiddler查看登录接口返回的结果—>代码模拟登录接口并获取接口登录返回结果—>设计登录接口测试用例—>断言并执行用例
4、web页面jenkins点击登录
5、fiddler抓包获取登录接口URL和参数
6、从fiddler查看登录接口返回的结果
7、代码模拟登录接口并获取接口登录返回结果
8、设计登录接口测试用例
9、断言并执行用例
10、参考代码
1 # coding=utf-8 2 #1.先设置编码,utf-8可支持中英文,如上,一般放在第一行 3 4 #2.注释:包括记录创建时间,创建人,项目名称。 5 ''' 6 Created on 2019-4-28 7 @author: 北京-宏哥 8 Project:学习和使用unittest框架设计jenkins登录测试用例和断言-下篇 9 ''' 10 #3.导入requests和unittest模块 11 import requests 12 import unittest 13 #4.编写测试用例和断言 14 class Jenkins_login(unittest.TestCase): 15 def login(self, username, psw): 16 '''从fiddler抓包看到事个参数: 17 账号:j_username,密码:j_password,from,Submit,remember_me 18 ''' 19 url = "http://localhost.:8080/jenkins/j_acegi_security_check" 20 headers = { 21 "User-Agent": "Mozilla/5.0 (Windows NT 10.0; WOW64; rv:44.0) Gecko/20100101 Firefox/44.0" 22 } # get方法其它加个ser-Agent就可以了 23 par = {"j_username": username, 24 "j_password": psw, 25 "from": "", 26 "Submit": u"登录", 27 "remember_me": "on" 28 } 29 res = requests.post(url, headers=headers, data=par) 30 result = res.url # 字节输出 31 print(result) 32 result1 = res.status_code 33 print(result1) 34 return res.status_code 35 36 def test_login1(self): 37 '''测试登录:正确账号,正确密码''' 38 username = "admin", # 正确账号,抓包获得的加密字符串 39 psw = "111111", # 正确密码,抓包获得的加密字符串 40 result = self.login(username, psw) 41 self.assertEqual(200,result) 42 43 def test_login2(self): 44 '''测试登录:正确账号,错误密码;反之也可以设计用例''' 45 username = "admin",#正确账号 46 psw = "122222",#错误密码 47 result = self.login(username, psw) 48 self.assertEqual(result, 404) 49 50 def test_login3(self): 51 '''测试登录:账号为空,正确密码;反之也可以设计用例''' 52 username = "", # 错误账号 53 psw = "111111", # 正确密码 54 result = self.login(username, psw) 55 self.assertEqual(result, 404) 56 57 if __name__ == "__main__": 58 unittest.main()
小结
1、fiddler抓取本地部署的jenkins登录请求时,抓取不到,但是百度可以抓取到,解决方法:
(1)使用http://localhost.fiddler 代替http://localhost
(2)使用用 http://localhost. 在locahost后面加一个点号
(3)使用 http://127.0.0.1. 在127.0.0.1后面加一个点号
(4)使用 http://machinename 使用机器名
(5)打开Fiddler,菜单>Fiddler Options>General>Enable IPv6(if avaible)去掉该选项。
(6)在hosts文件中加入127.0.0.1 localsite这样也可以被捕获到。
2、一些免费开源的接口,可以提供给大家进行练习
随机推荐热门段子(包含文字、图片、GIF、视频):
https://www.apiopen.top/satinApi?type=1&page=1
随机推荐热门段子【神评版本】(包含文字、图片、GIF、视频):
https://www.apiopen.top/satinGodApi?type=1&page=1
随机推荐热门段子【神评版本】评论列表:
https://www.apiopen.top/satinCommentApi?id=27610708&page=1
热门小说推荐列表
https://www.apiopen.top/novelApi
小说搜索接口
https://www.apiopen.top/novelSearchApi?name=盗墓笔记
小说详情接口
https://www.apiopen.top/novelInfoApi?name=盗墓笔记
天气获取接口
https://www.apiopen.top/weatherApi?city=成都
美图获取接口
https://www.apiopen.top/meituApi?page=1
个性网名获取接口
https://www.apiopen.top/femaleNameApi?page=1
创建应用接口
https://www.apiopen.top/createUserKey?appId=com.chat.peakchao&passwd=123456
增加统计信息接口
https://www.apiopen.top/addStatistics?appKey=00d91e8e0cca2b76f515926a36db68f5&type=点击统计&typeId=1&count=2
查询统计信息接口
https://www.apiopen.top/findStatistics?appKey=00d91e8e0cca2b76f515926a36db68f5
用户注册接口
https://www.apiopen.top/createUser?key=00d91e8e0cca2b76f515926a36db68f5&phone=13594347817&passwd=123654
用户登陆接口
https://www.apiopen.top/login?key=00d91e8e0cca2b76f515926a36db68f5&phone=13594347817&passwd=123456
感谢您花时间阅读此篇文章,如果您觉得这篇文章你学到了东西也是为了犒劳下博主的码字不易不妨打赏一下吧,让博主能喝上一杯咖啡,在此谢过了!
如果您觉得阅读本文对您有帮助,请点一下左下角“推荐”按钮,您的
本文版权归作者和博客园共有,来源网址:https://www.cnblogs.com/du-hong 欢迎各位转载,但是未经作者本人同意,转载文章之后必须在文章页面明显位置给出作者和原文连接,否则保留追究法律责任的权利!
公众号(关注宏哥)                                                                                 客服微信