pycharm中使用request和Pytest进行接口测试的方法
作者:lxi__ 发布时间:2022-06-30 03:34:46
标签:pycharm,request,Pytest,接口测试
安装request库
以火车的站站查询为例的post和get方法的接口测试
使用pytest测试接口
1、requests的请求机制
1、安装request库
2、以火车的站站查询为例的post和get请求方法
2.1get请求:
两种传参方式
1、_url = “网址+参数” = “网址?key1=value1&key2=value2”
response1 = request.get(url = _url)
2、字典拼接
_params = {
“key1” : “value1”,
“key2” : “value2”,
}
response2 = requests.get(url=“网址”, params = _params)
import requests
response = requests.get(url="https://api.binstd.com/train/station2s?start=北京&end=西安&ishigh=0&appkey=d737aad9a0d9dc97")
print(response.text) #字符串格式
print(response.json()) #json,前提需要确保返回内容为json格式,否则报错
#字典方式拼接参数
print("-------------字典方式拼接参数---------------")
params = {
"start" : "北京",
"end" : "西安",
"ishigh" : 0 ,
"appkey" : "d737aad9a0d9dc97"
}
response1 = requests.get(url="https://api.binstd.com/train/station2s", params = params)
print(response1.text)
print(response1.json())
2.2post请求
拼接参数方式传参
import requests
#字典方式拼接参数
data = {
"start" : "北京",
"end" : "西安",
"ishigh" : 0 ,
"appkey" : "d737aad9a0d9dc97"
}
response1 = requests.post(url="https://api.binstd.com/train/station2s", data = data)
print(response1.text)
print(response1.json())
#获取响应状态码
print(response1.status_code)
#获取原始模式
print(response1.raw)
常见的请求方法
请求方法 | 含义 |
---|---|
requests.get() | 获取html的主要方法 |
requests.head() | 获取html头部信息的主要方法 |
requests.post() | 向html网页提交post请求的方法 |
requests.put() | 向html网页提交put请求的方法 |
requests.patch() | 向html提交局部修改的请求 |
requests.delete() | 向html提交删除请求 |
2、pytest测试接口
1、安装pytest
pip install pytest
2、使用pytest测试接口
在pytest框架中,有如下约束:
文件名要以test开头或者结尾(test_*.py / *_test.py),可以包含一个或多个test_开头的函数。
此时,在执行pytest命令时,会自动从当前目录及子目录中寻找符合上述约束的测试函数来执行。
4.1首先得到响应数据
import requests
def request_ticket():
#返回接口响应结果
url = "https://api.binstd.com/train/ticket"
payload = {
"start": "北京",
"end": "西安",
"date": "2019-10-1",
"appkey": "d737aad9a0d9dc97"
}
#response = requests.get(url = _url, parms = payload)
response = requests.post(url = url, data = payload)
print(response.text)
return response
request_ticket()
4.2为了方便查看将响应结果格式化:由于太长,部分用省略号代替
{
"status": 0,
"msg": "ok",
"result": {
"start": "北京",
"end": "西安",
"date": "2020-06-10",
"list": [
{
"trainno": "G667",
"type": "G",
"typename": "高铁",
"station": "北京西",
"endstation": "西安北",
"departuretime": "11:19",
...
"departstationcode": "BXP",
"terminalstationcode": "EAY",
"startdate": "20200610",
...
},
{
"trainno": "G659",
"type": "G",
"typename": "高铁",
"station": "北京西",
"endstation": "西安北",
"departuretime": "11:53",
...
"departstationcode": "BXP",
"terminalstationcode": "EAY",
"startdate": "20200610",
...
},
{...},
{...},
...
]
}
}
4.3取出数据
出发站(station)和到达站(endstation)在result中的list下,怎么取到呢?----[“result”] [“list”]
---- request_ticket().json()[“result”][“list”]
def test_departur_station():
"""
始发站测试,测试接口返回的所有车次信息,他们的出发站,和到达站都符合参数约定
:return:
"""
#从响应中获取测试列表
trainSli = request_ticket().json()["result"]["list"] #单个的车次信息
#trainSli是取出来的list列表
for trainInfo in trainSli:
assert "北京" in trainInfo["station"] #判断‘北京'是否是列表中‘station'的值
assert "西安" in trainInfo["endstation"] #判断到达站是不是‘西安'
#调用函数
test_departur_station()
'''def test_train_date():
"""
发车日期测试,接口返回的所有车次信息,发车日期,都符合参数约定
:return:
"""
#从响应中获取测试列表
trainSli = request_ticket().json()["result"]["list"] #单个的车次信息
for trainInfo in trainSli:
assert "20200610" in trainInfo["startdate"]
test_train_date()'''
4.4 运行
4.5 查看结果
如果该路径下有多个以test开头或者结尾的文件,则会一起检测两个文件中的接口
如果出现ERROR则在文件中找错误原因
来源:https://blog.csdn.net/lx8211667846947/article/details/106658783/


猜你喜欢
- 本文实例讲述了python使用分治法实现求解最大值的方法。分享给大家供大家参考。具体分析如下:题目:给定一个顺序表,编写一个求出其最大值和最
- Mootools 1.2手风琴(Accordion)教程原文地址:30 Days of Mootools 1.2 Tutoria
- cupy我觉得可以理解为cuda for numpy,安装方式pip install cupy,假设import numpy as npim
- 登录页面能访问得到,但当执行下级目录的文件就不行了,浏览器直接跳出以下错误页面: 除些以外没有任何其它有价值的信息,因为此网站在我的电脑上执
- 使用JS对Json数据的处理,项目遇到需要对Json数据进行相关操作,比如增删改操作,本以为会比较难,网上搜索下,发现还是比较简单的,贴一段
- 问题:如何用ASP实现点击数统计?比如我要实现某篇文章被浏览一次就增加一个点击数,该怎么做?回答:就是说,比如,你的页面是:shownews
- 给一个例子 :# -*- coding: utf-8 -*-import matplotlib.pyplot as plt im
- 尝试了几种方法,感觉过于复杂,于是自己写了一个方法。(1)首先在要绘图的页面传入从数据库中提取的参数,这一步通过views可以实现;(2)然
- 楔子我们知道python的执行效率不是很高,而且由于GIL的原因,导致python不能充分利用多核CPU。一般的解决方式是使用多进程,但是多
- 问题简述在 Windows 系统上,我使用 Python 3.11 的 pip 工具安装 lxml 等库时会出现以下报错:error: Mi
- 一、在vs中新建一个工程,然后新建一个源文件二、右击上述图片中的mysql_test工程名,然后在最下方找到属性,并点击三、点击VC++目录
- 引言之前在看 CAP 定理时抱有很大的疑惑,CAP 定理的定义是指在分布式系统中三者只能满足其二,也就是存在分布式 CA 系统的。在网络上查
- 本文实例讲述了Python列表推导式与生成器表达式用法。分享给大家供大家参考,具体如下:和列表一样,列表推导式也采用方括号[]表示,并且用到
- 如下:re.split(pattern, string, [maxsplit], [flags])pattern:表示模式字符串,由要匹配的
- 背景客户最近有这样的需求,想通过统计Oracle数据库活跃会话数,并记录在案,利用比对历史的活跃会话的方式,实现对系统整体用户并发量有大概的
- next()方法当一个文件被用作迭代器,典型例子是在一个循环中被使用,next()方法被反复调用。此方法返回下一个输入行,或引发
- 背景实现需求:批量下载联想某型号的全部驱动程序。一般在做网络爬虫的时候,都是保存网页信息为主,或者下载单个文件。当涉及到多文件批量下载的时候
- 绘制一个线框图是你在制作一个网站前必须要经历的过程。线框图能够帮助你合理的组织并简化你内容和元素,是网站内容布局的基本视觉表现方式,是网站开
- 匹配中文字符的正则表达式: [\u4e00-\u9fa5]评注:匹配中文还真是个头疼的事,有了这个表达式就好办了匹配双字节字符(包括汉字在内
- 英文文档:class type(object)class type(name, bases, dict)With one argument,