专栏首页北京宏哥python接口自动化(二十五)--unittest断言——下(详解)

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

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 如何使用beego快速开发web系统【Golang 入门系列十三】

    接着之前的内容,前面已经讲过很多Golang的基础语法,mysql的使用,redis的使用,也讲了orm框架,如何创建一个webapi 服务等等,感兴趣的可以看...

    章为忠
  • 谷歌开源手势识别器,手机能用,运行流畅,还有现成的App,但是被我们玩坏了

    借助TensorFlow Lite和MediaPipe,谷歌刚刚开源了一款手势识别器,可以直接在手机上运行,实时跟踪,并且已经开源。

    量子位
  • RetinaNet在航空图像行人检测中的应用

    航空图像中的目标检测是一个具有挑战性且有趣的问题。随着无人机成本的降低,航空影像数据量的激增,拥有能够从航空数据中提取有价值的信息的模型将非常有用。

    AI科技评论
  • 关于DDoS的几个误区

    对DDoS攻击,大部分人的认知来源于新闻报道。新文报道这种方式在普及DDoS危害性的同事,也会不自觉地引入一些误区。例如,针对国际知名企业的攻击更受媒体关注,这...

    墨者安全科技
  • SpringCloud学习2-Springboot监控模块

    学习一项新技术最大的困难是什么? 是资料。让人高兴的是找到了一本系统学习Spring Cloud的教程,《Spring Cloud微服务实战》, 接下来的学习目...

    啦啦啦
  • 「网络安全」WEB 应用防火墙 是什么,部那里,如何用和为什么?

    在一个每天都会出现新的网络攻击并出现的世界中,我们必须不断寻找和建立新的安全控制和保护机制。目前发现的最常见的网络安全威胁通常涉及数据泄露并且发生在应用程序级别...

    首席架构师智库
  • 腾讯云服务器 CVM 相关概念

    用户6120120
  • RAdam优化器又进化:与LookAhead强强结合,性能更优速度更快

    上周,来自UIUC的中国博士生Liyuan Liu提出了一种兼具Adam和SGD两者之美的新优化器RAdam,收敛速度快,还很鲁棒,一度登上了GitHub趋势榜...

    量子位
  • springboot实战之自定义注解扫描并动态注册bean

    在项目开发中,我们可能会有这样的需求,通过注解配合AOP来实现一些业务额外功能,比如鉴权、日志记录等,更甚至我们可能会想通过注解,就可以把bean托管给spri...

    lyb-geek
  • QT QJsonObject 与 QJsonArray 中insert()方法 插入值的顺序问题

    本文链接:https://blog.csdn.net/acoolgiser/article/details/99442177

    acoolgiser

扫码关注云+社区

领取腾讯云代金券