前端请求接口post_接口自动化测试-WEB资讯专栏-DMOZ中文网站分类目录
为什么UI自动化维护成本更高?因为前端页面变化太快,而且UI自动化比较耗时(比如等待页面元素的加载、添加等待时间、定位元素、操作元素、模拟页面动作这些都需要时间)为什么接口自动化维护成本较低?因为接口较稳定,接口的响应时间基本上都是秒级、毫
(1)接口自动化测试的意义、前后端分离思想
接口自动化测试的优缺点:
优点:
测试复用性。
维护成本相对UI自动化低一些。
为什么UI自动化维护成本更高? 因为前端页面变化太快,而且UI自动化比较耗时(比如等待页面元素的加载、添加等待时间、定位元素、操作元素、模拟页面动作这些都需要时间)为什么接口自动化维护成本较低? 因为接口较稳定,接口的响应时间基本上都是秒级、毫秒级别的,速度快,并且接口自动化本身也可以做一些有关联的操作、全流程的操作(比如:注册 --> 登录 --> 修改个人信息)。回归方便。
可以运行更多更繁琐的测试。自动化的一个明显的好处是可以在较少的时间内运行更多的测试。
优点1、优点3、优点4是接口自动化和UI自动化公有的优点。缺点:
GET请求和POST请求的区别:
前后端分离
开发模式
以前老的方式:
产品经理 / 领导 / 客户提出需求(提出文字需求)
UI做出设计图
前端工程师做html页面(用户能看到的页面)
后端工程师将html页面套成jsp页面(前后端强依赖,后端必须要等到前端的html页面做好才能套jsp。如果html发生变更,就很麻烦,开发效率低)
比如云商系统:
集成出现问题
前端返工
后端返工
二次集成
集成成功
交付
新的方式:
- 产品经理 / 领导 / 客户提出需求(提出文字需求)
- UI做出设计图
- 前后端约定接口 & 数据 & 参数
- 前后端并行开发(无强依赖,可前后端并行开发,如果需求变更,只要接口 & 参数不变,就不用两边都修改代码,开发效率高)
- 前后端集成
- 前端页面调整
- 集成成功
- 交付
??通过F12打开浏览器开发者工具进行抓包,返回数据是json格式的就是前后端分离,返回时html页面就是没有前后端分离。
微服务的概念:
将大模块切分成小模块。减少代码的耦合度,从而降低模块与模块之间的影响。原先是一个jar包里面包含所有模块,改一个模块就有可能影响其他模块,现在是将一个一个的模块都打成一个一个的jar包,模块与模块之间的交互通过接口,哪个模块出了问题,只需要修改那个模块的jar包,避免因为修改一个模块的代码导致其他模块出错。
(2)Python requests框架讲解
接口自动化requests环境搭建
接口自动化核心库:requests
安装requests库的方法:
方法一:
命令行安装,打开cmd或者终端,输入以下命令:
pip install requests -i方法二:
在pycharm中安装,settings --> Project --> Project Interpreter --> 点击“+”号 --> 输入request安装
测试环境是否ok
# -*- coding:utf-8 -*- # 作者:IT小学生蔡坨坨 # 时间:2021/1/7 21:48import requestsurl_toutiao = "" # 方式一: # result_toutiao = (url_toutiao)# 方式二: result_toutiao = (url=url_toutiao)# 方式三: # result_toutiao = ( # "")# print(()) # print(type(())) # <class "dict"> result = () print(result) expect_result = "华晨金杯汽车花朵朵" actual_result = result["data"][0]["comment"]["user_name"] print(actual_result) if expect_result == actual_result:print("pass!") else:print("failed!")响应超时timeout
import requests# V部落:http://182.92.178.83:8081/index.html # 文章列表 url_v_article = "" v_headers = {"Cookie": "studentUserName=ctt01; Hm_lvt_cd8218cd51f800ed2b73e5751cb3f4f9=1609742724,1609762306,1609841170,1609860946; adminUserName=admin; JSESSIONID=9D1FF19F333C5E25DBA60769E9F5248E"} article_params = {"state": 1, # -1:全部文章 1:已发表 0:回收站 2:草稿箱"page": 1, # 显示第1页"count": 6, # 每页显示6条"keywords": "" # 包含的关键字} keywords = ["大橘猫", "跑男", "牙"] for keyword in keywords:article_params["keywords"] = keyword# headers和params是不定长的,根据定义的字典传参# timeout超时,单位为秒# 通过设置超时时间,告诉requests在经过多久后停止等待响应result = (url_v_article, headers=v_headers, params=article_params, timeout=30)print(())JSON、URL、text、encoding、status_code、encoding、cookies
print(()) # 响应结果以json的形式打印输出 print() # 打印url地址 print() # 以文本格式打印服务器响应的内容 print() # 响应状态码 print() # 编码格式 print() # cookieJSON(JavaScript Object Notation, JS 对象简谱) 是一种轻量级的数据交换格式。它基于 ECMAScript (欧洲计算机协会制定的js规范)的一个子集,采用完全独立于编程语言的文本格式来存储和表示数据。简洁和清晰的层次结构使得 JSON 成为理想的数据交换语言。 易于人阅读和编写,同时也易于机器解析和生成,并有效地提升网络传输效率。
JSON格式在Python里面相当于字典类型。
JSON格式化:http://www.bejson.com/jsonviewernew/
url在线编码转换:
(3)get、post、put、delete请求方式的自动化实现
GET请求方式
# -*- coding:utf-8 -*- # 作者:IT小学生蔡坨坨 # 时间:2021/1/7 21:48import requestsurl_toutiao = "" # 方式一: # result_toutiao = (url_toutiao)# 方式二: result_toutiao = (url=url_toutiao)# 方式三: # result_toutiao = ( # "")# print(()) # print(type(())) # <class "dict"> result = () print(result) expect_result = "华晨金杯汽车花朵朵" actual_result = result["data"][0]["comment"]["user_name"] print(actual_result) if expect_result == actual_result:print("pass!") else:print("failed!")运行结果: {"message": "success", "err_no": 0, "data": [{"comment": {"id": 6914864825282215951, "id_str": "6914864825282215951", "text": "藁城出国打工的人很多,重点检查藁城区!", "content_rich_span": "{"links":[]}", "user_id": 940799526971408, "user_name": "华晨金杯汽车花朵朵",}, "post_count": 0, "stick_toast": 1, "stable": True} 华晨金杯汽车花朵朵 pass!POST请求方式
# -*- coding:utf-8 -*- # 作者:IT小学生蔡坨坨 # 时间:2021/1/9 22:51import requestsurl_v_login = "" # 定义参数,字典格式 payload = {"username": "sang", "password": "123"} # Content-Type: application/json --> json # Content-Type: application/x-www-form-urlencoded --> data result = (url_v_login, data=payload) # 将返回结果转为json格式 result_json = () print(result_json) # {"status": "success", "msg": "登录成功"} # 获取RequestsCookieJar result_cookie = print(result_cookie, type(result_cookie)) # RequestsCookieJar # 将RequestsCookieJar转化为字典格式 result_cookie_dic = (result_cookie) print(result_cookie_dic) # {"JSESSIONID": "D042C5FE4CFF337806D545B0001E7197"} # 获取SESSION final_cookie = "JSESSIONID=" + result_cookie_dic["JSESSIONID"] # SJSESSIONID=D042C5FE4CFF337806D545B0001E7197 print(final_cookie)PUT请求方式
# V部落_编辑栏目# 定义请求头,自动获取cookie的方法详情请看下文 headers = {"Cookie": "VBlog().get_cookie()"} new_now_time = ("%Y%m%d%H%M%S", (())) new_category_name = "更新栏目" + new_now_time payload = {"id": 2010, "cateName": new_category_name} .put("", headers=headers, data=payload)DELETE请求方式
# 删除栏目 result = .delete("" + “2010”, headers=headers) print(()) # {"status": "success", "msg": "删除成功!"} ("删除成功!", ()["msg"])(4)接口自动化测试过程中cookie的处理
手动传入cookie的值(每次通过浏览器F12抓包,然后复制request header里面的cookie)
# -*- coding:utf-8 -*- # 作者:IT小学生蔡坨坨 # 时间:2021/1/7 22:25import requests# V部落查询栏目 url_v_category = "all" # 定制请求头 # 如果你想为请求添加HTTP头部,只要简单地传递一个字典给headers参数就可以了 v_headers = {"cookie": "studentUserName=ctt01; Hm_lvt_cd8218cd51f800ed2b73e5751cb3f4f9=1609742724,1609762306,1609841170,1609860946; adminUserName=admin; JSESSIONID=9D1FF19F333C5E25DBA60769E9F5248E"} result = (url_v_category, headers=v_headers) # 打印json格式的响应结果 print(())cookie自动获取
# -*- coding:utf-8 -*- # 作者:IT小学生蔡坨坨 # 时间:2021/1/9 22:51import requestsurl_v_login = "" # 定义参数,字典格式 payload = {"username": "sang", "password": "123"} # Content-Type: application/json --> json # Content-Type: application/x-www-form-urlencoded --> data result = (url_v_login, data=payload) # 将返回结果转为json格式 result_json = () print(result_json) # {"status": "success", "msg": "登录成功"} # 获取RequestsCookieJar result_cookie = print(result_cookie, type(result_cookie)) # RequestsCookieJar # 将RequestsCookieJar转化为字典格式 result_cookie_dic = (result_cookie) print(result_cookie_dic) # {"JSESSIONID": "D042C5FE4CFF337806D545B0001E7197"} # 获取SESSION final_cookie = "JSESSIONID=" + result_cookie_dic["JSESSIONID"] # SJSESSIONID=D042C5FE4CFF337806D545B0001E7197 print(final_cookie)批量获取cookie脚本
# -*- coding:utf-8 -*- # 作者:IT小学生蔡坨坨 # 时间:2021/1/9 23:26import requestsdef get_cookie(username, password):"""通过考试系统学生登录获取单个cookie"""url_login = ""payload = {"userName": username, "password": password, "remember": False}result = (url_login, json=payload)# result_json = ()# print(result_json)# 获取RequestsCookieJarresult_cookie = # print(result_cookie, type(result_cookie)) # RequestsCookieJar# 将RequestsCookieJar转化为字典格式result_cookie_dic = (result_cookie)# print(result_cookie_dic) # {"SESSION": "YzFkM2IzN2QtZWY1OC00Nzc4LTgyOWYtNjg5OGRiZDZlM2E4"}# 获取SESSIONfinal_cookie = "SESSION=" + result_cookie_dic["SESSION"] # SESSION=Mzc2...return final_cookie # -*- coding:utf-8 -*- # 作者:IT小学生蔡坨坨 # 时间:2021/1/9 23:23from test01.demo04_student_login import get_cookie import osdef get_batch_cookies():"""批量获取cookie"""# 获取cookie之前,先将文件内容清空# with open(r"D:\Desktop\Testman_Study\API_auto\file\", "w") as cookies_info:# ("")# 或者将文件删除(r"D:\Desktop\Testman_Study\API_auto\file\")# 读取csv文件with open(r"D:\Desktop\Testman_Study\API_auto\file\", "r") as user_info:for user in user_info:user_list = ().split(",")# 调用获取单个cookies的方法,传入注册好的用户名和密码cookies = get_cookie(user_list[0], user_list[1])# 将cookie追加写入文件with open(r"D:\Desktop\Testman_Study\API_auto\file\", "a") as cookies_info:(cookies + "\n")# 调用方法 get_batch_cookies() (前提是这些账号和密码都是已经注册过的,可以直接登录)poopoo001,123456,1 poopoo002,123457,2 poopoo003,123458,3 poopoo004,123459,4 ...... SESSION=ZmE3YmU4ZDctNDExZS00MDdhLWE0YjEtMjAyZjQxOTMxYmUx SESSION=YjdkNTZhNTUtNGFmMi00MjVkLWEyNjctOTNiMmRmOTY1YTdm SESSION=ZTJmMTYzMWEtZjUzOS00NTlhLWI0OWQtMzBmN2RkYmU4YmRi SESSION=YTM0ZGRhOTctZjk5Ni00OWZhLTg1YTItZjUyMTMwZGE2MjVi ......(5)不同类型请求参数的处理
# -*- coding:utf-8 -*- # 作者:IT小学生蔡坨坨 # 时间:2021/1/7 22:25import requests# 文章列表 url_v_article = "" v_headers = {"Cookie": "studentUserName=ctt01; Hm_lvt_cd8218cd51f800ed2b73e5751cb3f4f9=1609742724,1609762306,1609841170,1609860946; adminUserName=admin; JSESSIONID=9D1FF19F333C5E25DBA60769E9F5248E"}# 自定义url参数,定义一个字典,将参数拆分,再将字典传递给params变量即可 article_params = {"state": 1, # -1:全部文章 1:已发表 0:回收站 2:草稿箱"page": 1, # 显示第1页"count": 6, # 每页显示6条"keywords": "" # 包含的关键字} keywords = ["大橘猫", "跑男", "牙"] for keyword in keywords:article_params["keywords"] = keyword# headers和params是不定长的,根据定义的字典传参result = (url_v_article, headers=v_headers, params=article_params)print(())(6)结合Python+Requests+Unittest框架做接口自动化测试
unittest框架结构:
代码地址:https://github.com/itcaituotuo/unittest_api
if _name_ == "__main__":
if __name__ == "__main__"的意思是:
- 当.py文件被直接运行时,if __name__ == "__main__"下的代码块将被运行;
- 当.py文件以模块形式被导入时,if __name__ == "__main__"下的代码块不被运行。
(7)接口自动化测试过程中高级断言
闭环断言(新增 --> 查询 --> 修改 --> 查询 --> 删除 -->查询)
def test_article(self):# ①V部落_新增文章now_time = ("%Y%m%d%H%M%S", (()))title = "蔡坨坨" + now_timepayload = {"id": -1, "title": title, "mdContent": "文章内容", "state": 1, "htmlContent": "<p>文章内容</p>","dynamicTags": "", "cid": 62}headers = {"Cookie": VBlog().get_cookie()}result = self.("", headers=headers, data=payload)# ②查询文章url_v_article = ""article_params = {"state": 1, # -1:全部文章 1:已发表 0:回收站 2:草稿箱"page": 1, # 显示第1页"count": 6, # 每页显示6条"keywords": title # 包含的关键字title}result = (url_v_article, headers=headers, params=article_params, timeout=30)print(()) # 响应结果以json的形式打印输出ls = ()["articles"]act = 123# 查到新增的文章,说明新增成功for l in range(0, len(ls)):if ls[l]["title"] == title:act = "ok"article_id = ls[l]["id"]("ok", act)# ③编辑文章now_time = ("%Y%m%d%H%M%S", (()))title = "修改文章" + now_timepayload = {"id": article_id, "title": title, "mdContent": "修改内容", "state": 1, "htmlContent": "<p>修改内容</p>","dynamicTags": "", "cid": 62}headers = {"Cookie": VBlog().get_cookie()}self.("", headers=headers, data=payload)# 编辑完,查询文章url_v_article = ""article_params = {"state": 1, # -1:全部文章 1:已发表 0:回收站 2:草稿箱"page": 1, # 显示第1页"count": 6, # 每页显示6条"keywords": title # 包含的关键字title}result = (url_v_article, headers=headers, params=article_params, timeout=30)print(()) # 响应结果以json的形式打印输出ls = ()["articles"]act = 123# 查到修改过的文章,说明编辑成功for l in range(0, len(ls)):if ls[l]["title"] == title:act = "ok"article_id = ls[l]["id"]("ok", act)# ④查看文章详情article_id = str(article_id)result = self.("" + article_id, headers=headers)print(())if ()["title"] == title:act = "ok"(act, "ok")# ⑤删除文章payload = {"aids": article_id, "state": 1}result = .put("dustbin", headers=headers, data=payload)print(())act = ()["msg"](act, "删除成功!")(8)通过生成可视化HTML测试报告
百度网盘链接:
链接:
提取码:p20c
postman、JMeter、requests总结:
postman:接口功能测试
JMeter:接口性能测试
requests:接口自动化
??三个的共同特点:都能完成接口功能测试。
TAG:接口测试
总结
以上是生活随笔为你收集整理的前端请求接口post_接口自动化测试-WEB资讯专栏-DMOZ中文网站分类目录的全部内容,希望文章能够帮你解决所遇到的问题。
- 上一篇: alibaba 实体转json_com.
- 下一篇: HTML用css让input无法使用,h