pytest接口测试轻松入门
通过Postman请求结果如下图:

那我们怎么用pytest进行测试呢?
在接口测试,我们要用到requests包,实现代码如下:
import pytest
import allure
import requests class TestSimple(object):
def TestWatcher(self):
url = "http://wthrcdn.etouch.cn/weather_mini?city=成都"
r = requests.get(url)
assert r.status_code == 200
d = r.json()
print(d)
简述:上面通过request实现了天气的查询,对其请求状态做了验证(如果HTTP状态码为200则认为测试通过),并对接口请求结果进行了打印。
执行上面代码时遇到问题:No tests were found

结果问题查询:pytest 启动文件名是以test开头,函数名是以test开头。所以我们把上面的函数名改下,把TestWacher改为testWacher再去执行,效果如下:

相比于状态码,我们可能更喜欢进行关键字校验,如 查询结果中没有wendu字段,则视为用例失败怎么实现?
此时可以使用pytest的xfail标记用例预期失败,如果用例运行成功则显示Xpassed,失败则显示xfailed。xfail标记并不会影响用例的运行。
添加代码如下:
if ('wendu' not in d['data'].keys()):
pytest.xfail('返回结果不正确,wendu=NULL')
假设我们要检查的字段是 wendi,而结果中没有该字段,此时执行效果如下:

如果我们在执行时,如何让报告显得更漂亮呢?这时我们可以进行美化,最终代码如下:
@allure.feature("测试Dome")
class TestSimple(object):
@allure.story("天气查询")
@allure.description('一个免费的天气查询接口测试')
@allure.severity('critical')
def testWatcher(self):
url = "http://wthrcdn.etouch.cn/weather_mini?city=成都"
with allure.step("查询天气"):
r = requests.get(url)
assert r.status_code == 200
d = r.json()
print(d)
if ('wendu' not in d['data'].keys()):
pytest.xfail('返回结果不正确,wendu=NULL')
常见allure报告美化总结:
@allure.feature(“测试用例特性场景(主要功能模块)”)
@allure.story(“feature功能模块下的分支功能(用例名称)”)
@allure.description(“这里是用例的描述信息”)
@allure.severity(“测试用例等级”)
说明:allure对用例的等级划分成五个等级
- blocker – 阻塞缺陷(功能未实现,无法下一步)
- critical – 严重缺陷(功能点缺失)
- normal – 一般缺陷(边界情况,格式错误)
- minor – 次要缺陷(界面错误与ui需求不符)
- trivial – 轻微缺陷(必需项无提示,或者提示不规范)
allure.description_html(html代码) #提供一些HTML在测试用例的描述部分
@allure.step(“用例步骤说明”)
使用方法:
①@allure.step() 只能以装饰器的形式放在类或者方法上面;
②with allure.step(): 可以放在测试用例方法里面,但测试步骤的代码需要被该语句包含;
allure.attach(body, name, attachment_type, extension)
用于向测试报告中输入一些附加的信息,通常是一些测试数据信息,参数说明:
- body - 要写入文件的原始内容
- name - 包含文件名的字符串
- attachment_type - 其中一个allure.attachment_type值,可以是文本、图片、HTML等
- extension - 提供的将用作创建文件的扩展名
@allure.link(“URL=链接地址”)
@allure.issue(“URL=问题链接”)
@allure.testcase(“URL=用例链接”)
最后执行用例,并生成allure报告:

点击特性场景,进入详情,结果如下:

上面就实现了一个简单的pytest接口测试例子,但怎么参数化,怎么让代码层次更清晰,要不要这么low b?请关注小编后续文章。

另外,欢迎加入软件测试技术交流群 313782132 ~进群可领取免费软件测试资料以及群内测试大牛解惑!
测试工程师职业发展路线图
功能测试 — 接口测试 — 自动化测试 — 测试开发 — 测试架构师
加油吧,测试人!如果你需要提升规划,那就行动吧,在路上总比在起点观望的要好。事必有法,然后有成。
资源不错就给个推荐吧~
pytest接口测试轻松入门的更多相关文章
- Groovy轻松入门——通过与Java的比较,迅速掌握Groovy (更新于2008.10.18)
摘自: http://www.blogjava.net/BlueSUN/archive/2007/03/10/103014.html Groovy轻松入门--通过与Java的比较,迅速掌握Groovy ...
- Groovy轻松入门——搭建Groovy开发环境
摘自: http://www.blogjava.net/BlueSUN/archive/2007/03/17/104391.html Groovy轻松入门--搭建Groovy开发环境 多日来,我发表了 ...
- C++ STL编程轻松入门基础
C++ STL编程轻松入门基础 1 初识STL:解答一些疑问 1.1 一个最关心的问题:什么是STL 1.2 追根溯源:STL的历史 1.3 千丝万缕的联系 1.4 STL的不同实现版本 2 牛刀小试 ...
- Swift轻松入门——基本语法介绍和详细地Demo讲解(利用WebView打开百度、新浪等网页)
转载请务必注明出处(all copyright reserved by iOSGeek) 本文主要分为两个部分,第一部分介绍Swift的基本语法,第二部分讲解一个利用WebView来打开百度.sina ...
- JavaScript面向对象轻松入门之封装(demo by ES5、ES6、TypeScript)
本章默认大家已经看过作者的前一篇文章 <JavaScript面向对象轻松入门之抽象> 为什么要封装? 封装(Encapsulation)就是把对象的内部属性和方法隐藏起来,外部代码访问该对 ...
- asp.net core轻松入门之MVC中Options读取配置文件
接上一篇中讲到利用Bind方法读取配置文件 ASP.NET Core轻松入门Bind读取配置文件到C#实例 那么在这篇文章中,我将在上一篇文章的基础上,利用Options方法读取配置文件 首先注册MV ...
- AngularJs轻松入门
AngularJs轻松入门系列博文:http://blog.csdn.net/column/details/angular.html AngularJs轻松入门(一)创建第一个应用 AngularJs ...
- Groovy轻松入门——通过与Java的比较,迅速掌握Groovy
转自 :Groovy轻松入门——通过与Java的比较,迅速掌握Groovy (更新于2008.10.18) 在前几篇文章中,我已经向大家介绍了Groovy是什么,学习Groovy的重要性等内容,还不了 ...
- Git轻松入门2:分支篇
什么是分支 在玩剧情类游戏时,不同的选择会触发不同的剧情路线,每条剧情路线都会独立发展,最终走向不同的结局. Git中所谓的"分支(branch)"就如同游戏中的剧情路线,用户可以 ...
随机推荐
- 思维导图iMindMap怎么做大型项目管理
在大型企业中,有许多大型而复杂的项目,你要考虑内外部因素.期限以及你要达成的目标等等,所以我们要进行项目管理.下面小编教你怎么用iMindMap思维导图进行项目管理. iMindMap有一个工作区,以 ...
- JUC并发工具包之Semaphore
目录 Semaphore (JDK) Timed Semaphore (Apache Commons) Semaphore vs. Mutex CodeRepo Semaphore (JDK) 我们使 ...
- 聊聊 ClassLoader 是如何查找资源的
ClassLoader作用 classloader这个写业务代码的童鞋们,应该很少用到,但是写框架的应该很熟悉.这个类负责Java底层的类的加载和查找,简单滴说Java 的所有类都是由它负责将clas ...
- Java基础教程——抽象类
抽象类 抽象类是介于普通类(class)和接口(interface)之间的一种特殊类. 接口的方法都不实现,类的方法都必须实现,抽象类里的方法可以实现,可以不实现. Java 8之后接口中可以实现方法 ...
- 多态,向上转型,向下转型,final关键字
多态 概述 多态封装性,继承性之后,面向对象的第三大特性. 定义 多态:是指同一种行为,具有多个不同的表现形式. 生活中,比如跑的动作,猫,狗,大象跑起来的动作都是不一样的,再比如飞的动作 ...
- 为什么不用UUID做主键?
不易于存储:UUID太长,16字节128位,通常以36长度的字符串表示,很多场景不适用. 信息不安全:基于MAC地址生成UUID的算法可能会造成MAC地址泄露,这个漏洞曾被用于寻找梅丽莎病毒的制作者位 ...
- Docker实战 | 第一篇:Centos8 安装 Docker
1. 安装依赖包 yum install -y yum-utils device-mapper-persistent-data lvm2 2. 配置镜像源 yum config-manager --a ...
- Flv.js记录(vue)
下载 npm install flv.js 插入 import flvjs from 'flv.js' 第一种报错:Failed to read the 'buffered' property f ...
- Hyper-V 中设置虚拟机静态 IP
一.新建虚拟网络交换机 二.配置网络 网络共享默认使用 192.168.137.0/255 作为内网地址,192.168.137.1 作为网关 三.配置虚拟机静态 IP 安装完成虚拟机后修改配置文件: ...
- 老猿学5G:3GPP 5G规范中的URI资源概念
☞ ░ 前往老猿Python博文目录 ░ 说明: 本文参考3GPP29.501<Principles and Guidelines for Services Definition>结合笔者 ...