pytest测试框架入门1

Posted 遥远的歌s

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了pytest测试框架入门1相关的知识,希望对你有一定的参考价值。

pytest单元测试框架

单元测试是指在软件开发当中,针对软件的最小单位(函数,方法)进行正确性的检查测试
单元测试框架主要做什么

  1. 测试发现:从多个文件里面找到我们的测试用例
  2. 测试执行:按照一定的顺序和规则去执行,并生成结果
  3. 测试判断:通过断言判断预期结果和实际结果的差异
  4. 测试报告:统计测试进度,耗时,通过率,生成测试报告
    单元测试框架和自动化测试框架的关系

自动化测试框架

为了完成指定的系统的自动化测试,来封装的一整套完善的代码的框架,主要封装一些自动化的基础模块,自动化的管理模块,包括自动化测试的统计模块
作用

  1. 提高测试效率,降低维护成本
  2. 减少人工的干预,提高测试的准确性,增加代码的重用性
  3. 核心思想是让不懂代码的人也能够通过这个框架去实现自动化测试

pytest单元测试框架和自动化测试框架中的关系

  1. 单元测试框架:只是自动化测试框架中的组成部分之一
  2. pom设计模式:只是自动化测试框架中的组成部分之一
  3. 数据驱动
  4. 关键字驱动
  5. 全局配置文件的封装
  6. 日志监控
  7. 断言
  8. 报告邮件等

pytest简介

  1. pytest是一个非常成熟的python的单元框架
  2. pytest可以和selenium,request,appinum结合实现web自动化,接口自动化,app自动化
  3. pytest可以实现测试用例的跳过以及returns失败用例的重试
  4. pytest可以和allure生成非常美观的测试报告
  5. pytest可以和jenkins持续集成
  6. pytest有很多非常强大的插件,并且这些插件能够实现很多的实用操作
    安装:
pip install pytest

验证是否安装成功:pytest --version

使用pytest,默认的测试用例的规则以及基础应用

  1. 模块名必须以test_开头或者_test结尾
  2. 测试类必须以Test开头,并且不能有init方法
  3. 测试方法必须以test开头

pytest测试用例的运行方式

1. 主函数模式

2. 命令行模式

以上两种方法可以运行所有用例,也可以运行部分用例
同样的,可以使用一个主文件来执行所有的测试用例

运行指定模块的运行:参数后面加入要指定运行模块的文件名

如果有多个测试文件夹,想要执行指定的文件夹:

通过nodeid制定用例执行:nodeid由模块名,分隔符,类名,方法名,函数组成。
比如执行某一个文件下的某一个方法或者某一个函数
方法要加类名用::隔开

参数详解:
-s :表示输出调试的信息,包括print打印的信息

-v:表示详情显示,测试的模块,类等

-n:支持多线程或者分布式运行测试用例,如下图,两个线程执行

–reruns=n:表示失败的重新跑n次

-x:表示只要有一个用例报错,测试停止

–maxfail=n:表示出现n个用例失败就停止

-k:表示执行含有指定字符串的用例
例如执行含有 “li” 的用例

pytest执行测试用例的顺序

pytest默认从上到下顺序执行
改变执行顺序:

@pytest.mark.run(order=n)

上面代码表示我想让某个用例排在第n个执行

3. 通过读取pytest.ini配置文件运行
pytest.ini这个文件它是pytest单元测试框架的核心配置文件
位置:一般放在项目的根目录
编码:必须为ANSI,可以使用notpad++修改编码格式
作用:可以改变pytest默认的行为
运行的规则:不管是主函数的模式运行,命令行模式运行,都会去读取这个配置文件
pytest.ini文件:

例如:testcase下有两个文件test_login和test_produce,那么我可以配置如下,只执行test_login文件

分组执行(冒烟,分模块执行,分接口和web执行)
smoke:冒烟用例,分布在各个模块里面
首先配置文件中:

在想要执行的用例前面加:@pytest.mark.smoke

再去执行,就会发现只执行了带有smoke标记的用例:
pytest -m “target1 or target2 or…”
执行有target1,target2…标记的用例

pytest跳过测试用例

1. 无条件跳过
在想要跳过的用例前面加上@pytest.mark.skip(reason=“这里写上跳过的原因”)

2. 有条件跳过
pytest.mark.skip(skipreason,reason=“这里写上跳过的原因”)。命令中存在跳过的原因

生成报告

1. html报告
一般会在项目工程中添加一个报告文件件,本例中加入report文件夹,生成的测试报告的文件名为report.html

就会在report文件下看到report.htm文件

浏览器打开后就是报告文件

2. pytest结合allure-pytest插件生成allure测试报告

  1. 下载,解压,配置path路径
    安装brew
/usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"

下载allure

brew install allure
  1. 生成json格式的临时报告
--alluredir ./file

  1. 生成allure报告
allure generate


报告结果

以上是关于pytest测试框架入门1的主要内容,如果未能解决你的问题,请参考以下文章

pytest文档1-环境准备与入门

测试开发技术:Python测试框架Pytest的基础入门

超详细从入门到精通,pytest自动化测试框架实战教程-allure测试报告

软件测试人必须要会的——pytest单元测试框架

pytest文档1-环境准备与入门

硬核!Python测试框架 “ pytest ” 快速入门(小白必看!)