简介
本篇还是回归到我们最初始的话题,想必大家都忘记了,没关系看这里:传送门 没错最初的话题就是登录,由于博客园的登录机制改变了,本篇以我找到的开源免费的登录API为案例,结合 unittest 框架写 2 个用例。同样我们先来看一下接口文档。
接口文档
登录接口
请求方式:POST
请求地址:https://api.apiopen.top/developerLogin
Query参数名 | 类型 | 必需 | 描述 | 示例 e.g. |
---|---|---|---|---|
name | string | 是 | 用户名 | peakchao |
passwd | string | 是 | 密码 | 123456 |
返回示例:
代码语言:javascript复制 {
"code": 200,
"message": "成功!",
"result": {
"apikey": "b9b3a96f7554e3bead2eccf16506c13e"
}
}
设计测试用例
1、针对以上接口文档,设计这个登录接口的测试用例
2、参考代码
代码语言:javascript复制 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、参考代码
代码语言:javascript复制 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