python的pytest框架之命令行参数详解(上)


Posted in Python onJune 27, 2019

前言

pytest是一款强大的python自动化测试工具,可以胜任各种类型或者级别的软件测试工作。pytest提供了丰富的功能,包括assert重写,第三方插件,以及其他测试工具无法比拟的fixture模型。pytest是一个软件测试框架,是一款命令行工具,可以自动找到测试用例执行,并且回报测试结果。有丰富的基础库,可以大幅度提高用户编写测试用例的效率。具备扩展性,用户可以自己编写插件,或者安装第三方提供的插件。可以很容易地与其他工具集成到一起使用。比如持续集成,web自动化测试等。

下面列举了一些pytest相对于其他框架的优点

1. 简单的测试可以很简单的编写

2. 复杂的测试也可以简单的编写

3. 测试的可读性

4.易于上手

5. 断言仅使用原生的assert关键字,而不是像unittest那样使用self.assert**那样

6. pytest可以运行unittest和nose编写的测试用例

上面大部分结论其实也不是我个人总结的,是我从一本书上看到的,因为我也是刚刚接触这个框架,了解的也并不多。还有一个重要原因就是写文章不写点所谓的科学理论好像缺少点啥……(别管了前面了*总之一句话:pytest就是一个测试框架和unittest一类,功能很强,支持好多插件,用例写起来简单,代码逻辑性强,值得学习!实际工作中能不能用,能不能用好那就要靠自己了!)^_^废话不多说!

编写第一个测试函数(用例)

from selenium import webdriver
 def testOpenUrl():
 try:
 driver = webdriver.Firefox() # 打开浏览器
 driver.get('http://www.baidu.com') # 访问百度
 title = driver.title # 获取百度首页的title
 assert title == '百度一下,你就知道' # 断言
 except AssertionError:
raise AssertionError('断言失败!')
 driver.quit()

可以看到用例很简单,就是一个普通的函数(驱动浏览器,打开百度首页,断言首页的title是否正确),那么pytest是如何运行测试用例的呢?

我们可以通过cmd终端,并且换到当前用例所在的目录,输入 pytest 即可,运行结果如下所示

python的pytest框架之命令行参数详解(上)

pytest执行用例命令行参数

上面我们已经学会了执行用例的命令 就是pytest, 那么真的就这么简单了吗?其实不然,pytest 还提供了很多可供我们执行用例的命令行参数,下面我们就一一介绍并演示

1.-v

:pytest -v 说明:可以输出用例更加详细的执行信息,比如用例所在的文件及用例名称等

python的pytest框架之命令行参数详解(上)

2.-s

:pytest -s 说明:输入我们用例中的调式信息,比如print的打印信息等,我们在上面用例8行加上一句 print(driver.title),我们再运行一下我们的用例看看

python的pytest框架之命令行参数详解(上)

3.-m

:pytest -m ”标记“ 说明:执行特定的测试用例。我们再次修改一下我们的用例,并添加一个新的用例

from selenium import webdriver
 import pytest
 @pytest.mark.run_this_testcase
 def testOpenUrl():
 try:
 driver = webdriver.Firefox() # 打开浏览器
 driver.get('http://www.baidu.com') # 访问百度
 title = driver.title # 获取百度首页的title
print(driver.title)
assert title == '百度一下,你就知道' # 断言
except AssertionError:
raise AssertionError('断言失败!')
driver.quit()
def testBaidu():
driver = webdriver.Firefox() # 打开浏览器
driver.get('http://www.baidu.com') # 访问百度
title = driver.title # 获取百度首页的title
assert title == '百度一下,你就知道' # 断言

python的pytest框架之命令行参数详解(上)

我们可以看到只执行了被标记的用例,新添加的用例并没有被执行

4.-k

:pytest -k "关键字" 说明:执行用例包含“关键字”的用例

python的pytest框架之命令行参数详解(上)

5.-q

:pytest -q 说明:简化控制台的输出,可以看出输出信息和上面的结果都不一样, 下图中有两个..点代替了pass结果

python的pytest框架之命令行参数详解(上)

以上5个参数,大家可以自己尝试一下,下一篇文章会继续讲解其他几个常用的参数的使用以及pytest是如何发现测试用例的!

下篇将继续更新其他一些命令选项的使用,和pytest收集测试用例的规则!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
使用python编写脚本获取手机当前应用apk的信息
Jul 21 Python
Python 2.7.x 和 3.x 版本的重要区别小结
Nov 28 Python
Python实现拼接多张图片的方法
Dec 01 Python
Windows系统下安装Python的SSH模块教程
Feb 05 Python
Python实现高效求解素数代码实例
Jun 30 Python
Python的Django框架可适配的各种数据库介绍
Jul 15 Python
查找python项目依赖并生成requirements.txt的方法
Jul 10 Python
对pandas处理json数据的方法详解
Feb 08 Python
python编写计算器功能
Oct 25 Python
Python 模拟动态产生字母验证码图片功能
Dec 24 Python
Python turtle画图库&&画姓名实例
Jan 19 Python
Python如何定义有可选参数的元类
Jul 31 Python
解决Pycharm后台indexing导致不能run的问题
Jun 27 #Python
解决pycharm运行程序出现卡住scanning files to index索引的问题
Jun 27 #Python
python如何解析配置文件并应用到项目中
Jun 27 #Python
python 随机生成10位数密码的实现代码
Jun 27 #Python
python自动化测试之如何解析excel文件
Jun 27 #Python
python算法与数据结构之单链表的实现代码
Jun 27 #Python
python多线程并发实例及其优化
Jun 27 #Python
You might like
《PHP编程最快明白》第四讲:日期、表单接收、session、cookie
2010/11/01 PHP
php判断页面是否是微信打开的示例(微信打开网页)
2014/04/25 PHP
ThinkPHP中limit()使用方法详解
2016/04/19 PHP
PHP简单实现记录网站访问量功能示例
2018/06/06 PHP
jQuery UI Dialog控件中的表单无法正常提交的解决方法
2010/12/19 Javascript
7个JS基础知识总结
2014/03/05 Javascript
js父页面与子页面不同时显示的方法
2014/10/16 Javascript
JavaScript DOM节点操作方法总结
2016/08/23 Javascript
Vue核心概念Getter的使用方法
2019/01/18 Javascript
微信小程序获取复选框全选反选选中的值(实例代码)
2019/12/17 Javascript
js实现无限层级树形数据结构(创新算法)
2020/02/27 Javascript
[03:37]2014DOTA2国际邀请赛 主赛事第一日胜者组TOPPLAY
2014/07/19 DOTA
[04:29]【TI9采访】OG.N0tail在胜者组决赛后接受采访
2019/08/25 DOTA
python实现的多线程端口扫描功能示例
2017/01/21 Python
Python利用ElementTree模块处理XML的方法详解
2017/08/31 Python
微信跳一跳自动运行python脚本
2018/01/08 Python
TensorFlow数据输入的方法示例
2018/06/19 Python
教你一步步利用python实现贪吃蛇游戏
2019/06/27 Python
Python matplotlib学习笔记之坐标轴范围
2019/06/28 Python
详解python uiautomator2 watcher的使用方法
2019/09/09 Python
Python 导入文件过程图解
2019/10/15 Python
Python基于stuck实现scoket文件传输
2020/04/02 Python
用CSS3的box-reflect来制作倒影效果
2016/11/15 HTML / CSS
css3 利用transform打造走动的2D时钟
2020/10/20 HTML / CSS
Paper Cape官网:美国婴儿和儿童服装品牌
2019/11/02 全球购物
内刊编辑求职自荐书范文
2014/02/19 职场文书
留守儿童工作方案
2014/06/02 职场文书
出售房屋协议书范本
2014/10/06 职场文书
交通事故协议书范文
2014/10/23 职场文书
打架检讨书
2015/01/27 职场文书
管理失职检讨书范文
2015/05/05 职场文书
党员证明信
2015/06/19 职场文书
九年级化学教学反思
2016/02/22 职场文书
Python中相见恨晚的技巧
2021/04/13 Python
浅谈JS和Nodejs中的事件驱动
2021/05/05 NodeJs
Spring Data JPA的Audit功能审计数据库的变更
2021/06/26 Java/Android