简介
本篇还是回归到我们最初始的话题,想必大家都忘记了,没关系看这里:传送门 没错最初的话题就是登录,由于博客园的登录机制改变了,本篇以我找到的开源免费的登录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