使用assert语句进行断言

pytest允许使用标准的python assert语法,用来校验expectation and value是否一致

代码演示:

def func():
return def test_func():
assert func() ==

执行结果:

(wda_python) bash-3.2$ pytest -q test_assert.py
F [%]
================================================================ FAILURES ================================================================
_______________________________________________________________ test_func ________________________________________________________________ def test_func():
> assert func() ==
E assert ==
E + where = func() test_assert.py:: AssertionError
failed in 0.07 seconds
(wda_python) bash-3.2$

同时支持在assert后面添加描述信息:

def func():
return def test_func():
assert func() == , 'Value was odd, should be even'

执行结果:

(wda_python) bash-3.2$ pytest -q test_assert.py
F [%]
================================================================ FAILURES ================================================================
_______________________________________________________________ test_func ________________________________________________________________ def test_func():
> assert func() == , 'Value was odd, should be even'
E AssertionError: Value was odd, should be even
E assert ==
E + where = func() test_assert.py:: AssertionError
failed in 0.07 seconds
(wda_python) bash-3.2$

预期异常的断言

pytest中使用with pytest.raises: 来断言预期异常

代码演示:

import pytest

def func():
raise SystemExit(1) def test_func():
with pytest.raises(SystemExit):
func()

执行输出:

(wda_python) bash-3.2$ pytest -q test_sysexit.py
. [%]
passed in 0.04 seconds
(wda_python) bash-3.2$

还可以自定义错误描述:

import pytest

def func():
raise SystemError("Exception 123 raised") def test_func():
with pytest.raises(SystemError, match=r'.* 123 .*'):
func()

输出:

(wda_python) bash-3.2$ pytest -q test_assert.py
. [%]
passed in 0.03 seconds
(wda_python) bash-3.2$

如果不匹配的话就会报错:

import pytest

def func():
raise SystemError("Exception 12 raised") def test_func():
with pytest.raises(SystemError, match=r'.* 123 .*'):
func()

输出:

(wda_python) bash-3.2$ pytest -q test_assert.py
F [%]
================================================================ FAILURES ================================================================
_______________________________________________________________ test_func ________________________________________________________________ def test_func():
with pytest.raises(SystemError, match=r'.* 123 .*'):
> func()
E AssertionError: Pattern '.* 123 .*' not found in 'Exception 124 raised' test_assert.py:: AssertionError
failed in 0.07 seconds
(wda_python) bash-3.2$

断言上下文内容(变量)是否相等

实例代码:

def test_set_comparison():
set1 = set('')
set2 = set('')
assert set1 == set2

运行结果:

(wda_python) bash-3.2$ pytest -q test_assert.py
F [%]
================================================================ FAILURES ================================================================
__________________________________________________________ test_set_comparison ___________________________________________________________ def test_set_comparison():
set1 = set('')
set2 = set('')
> assert set1 == set2
E AssertionError: assert set(['', '', '', '']) == set(['', '', '', ''])
E Extra items in the left set:
E ''
E Extra items in the right set:
E ''
E Full diff:
E - set(['', '', '', ''])
E ? -----...
E
E ...Full output truncated ( lines hidden), use '-vv' to show test_assert.py:: AssertionError
failed in 0.10 seconds
(wda_python) bash-3.2$

自定义断言

官方解释如下

 

我们可以通过实现pytest_assertrepr_compare方法,来自定义assert实现

比如一个Class Foo,我们比较f1和f2

class Foo(object):
def __init__(self, val):
self.val = val def __eq__(self, other):
return self.val == other.val def test_compare():
f1 = Foo()
f2 = Foo(1)
assert f1 == f2

运行结果如下:

(wda_python) bash-3.2$ pytest -q test_foocompare.py
F [%]
================================================================ FAILURES ================================================================
______________________________________________________________ test_compare ______________________________________________________________ def test_compare():
f1 = Foo()
f2 = Foo()
> assert f1 == f2
E assert <test_foocompare.Foo object at 0x1029eb7d0> == <test_foocompare.Foo object at 0x1029eb290> test_foocompare.py:: AssertionError
failed in 0.09 seconds
(wda_python) bash-3.2$

错误提示不够友好, 我们可以通过完成pytest_assertrepr_compare方法自定义

from test_foocompare import Foo

def pytest_assertrepr_compare(op, left, right):
if isinstance(left, Foo) and isinstance(right, Foo) and op == "==":
return ['Comparing Foo instance:', 'vals: %s != %s' % (left.val, right.val)]

运行结果如下:

(wda_python) bash-3.2$ pytest
========================================================== test session starts ===========================================================
platform darwin -- Python 2.7., pytest-4.1., py-1.7., pluggy-0.8.
rootdir: /Users/jackey/Documents/iOS/code/iOS-Auto/Agent_Test, inifile:
collected item test_foocompare.py F [%] ================================================================ FAILURES ================================================================
______________________________________________________________ test_compare ______________________________________________________________ def test_compare():
f1 = Foo()
f2 = Foo()
> assert f1 == f2
E assert Comparing Foo instance:
E vals: != test_foocompare.py:: AssertionError
======================================================== failed in 0.05 seconds ========================================================
(wda_python) bash-3.2$

iOS自动化探索(五)自动化测试框架pytest - Assert断言的使用的更多相关文章

  1. iOS自动化探索(四)自动化测试框架pytest - 安装和使用

    自动化测试框架 - pytest pytest是Python最流行的单元测试框架之一, 帮助更便捷的编写测试脚本, 并支持多种功能复杂的测试场景, 能用来做app测试也能用作函数测试 官方文档: ht ...

  2. python3: 自动化测试框架pytest

    最近在学习web自动化,所以在这里总结一下pytest框架. 其实pytest 和 unittest 都是自动化测试框架,但是pytest更好用一些,有以下几个优点:1)可以根据标签执行用例:2)?? ...

  3. iOS自动化探索(六)自动化测试框架pytest - fixtures

    Fixture介绍 fixture是pytest特有的功能,它用pytest.fixture标识,定义在函数前面.在编写测试函数的时候,可以将此函数名称做为传入参数,pytest将会以依赖注入方式,将 ...

  4. iOS自动化探索(七)自动化测试框架pytest - 测试报告

    这里我们单独来看下关于如何生存测试报告 准备测试代码如下: #coding: utf- import pytest @pytest.fixture() def login(): print '输入账号 ...

  5. Python接口自动化测试框架: pytest+allure+jsonpath+requests+excel实现的接口自动化测试框架(学习成果)

    废话 最近在自己学习接口自动化测试,这里也算是完成一个小的成果,欢迎大家交流指出不合适的地方,源码在文末 问题 整体代码结构优化未实现,导致最终测试时间变长,其他工具单接口测试只需要39ms,该框架中 ...

  6. iOS自动化探索(一)WebDriverAgent安装

    WebDriverAgent FaceBook推出的一款iOS移动测试框架, 支持真机和模拟器, 同时支持USB, 官方是这样介绍的: https://github.com/facebook/WebD ...

  7. iOS自动化探索(十)代码覆盖率统计

    iOS APP代码覆盖率统计 今年Q3季度领导给加了个任务要做前后端代码覆盖率统计, 鉴于对iOS代码代码比较熟就选择先从iOS端入手,折腾一整天后终于初步把流程跑通了记录如下 覆盖率监测的原理 Xc ...

  8. iOS自动化探索(九)使用Jenkins自动化打包并发布iOS App

    继前一篇: Mac环境下安装Jenkins Jenkins安装好后, 我们试着创建一个iOS自动打包并发布的任务 iOS App构建必须在MAC上面使用xcode进行,所以我们要安装下xcode集成插 ...

  9. iOS自动化探索(三)WebDriverAgent Python Client

    之前我们在终端试着调用过WDA API, 今天我们在看一个Python封装的api库 https://github.com/openatx/facebook-wda 安装方式(一): pip inst ...

随机推荐

  1. django博客项目6:Django Admin 后台发布文章

    在此之前我们完成了 Django 博客首页视图的编写,我们希望首页展示发布的博客文章列表,但是它却抱怨:暂时还没有发布的文章!如它所言,我们确实还没有发布任何文章,本节我们将使用 Django 自带的 ...

  2. Keras之函数式(Functional)模型

    函数式(Functional)模型 我们起初将Functional一词译作泛型,想要表达该类模型能够表达任意张量映射的含义,但表达的不是很精确,在Keras2里我们将这个词改移为“函数式”,函数式模型 ...

  3. Android Studio 启动时不自动打开项目

    主界面中,选择单击菜单栏 File ,单击 Settings 选择 Appearance & Behavior 选项.选择System Settings选项.取消勾选Reopen last p ...

  4. Android图片加载框架之Picasso

    相信做Android开发的对Square公司一定不会陌生,大名鼎鼎的网络请求框架Retrofit就来源于它,今天学习的是该公司出品的图片加载框架Picasso. 项目地址 https://github ...

  5. 解释一下python中的赋值运算符

    我们将所有的算术运算符和赋值运算符号放在一起展示 a=7 a+=1 print(a) a-=1 print(a) a*=2 print(a) a/=2 print(a) a**=2 print(a) ...

  6. SqlHelper简单实现(通过Expression和反射)7.MySql数据处理类

    MySql的数据处理类和Sql Server没有太大差别,从思路上来说没有区别,所以此处只是给出代码,不再多加解释了. using System; using System.Configuration ...

  7. for_each用法

    for_each()是个function template #include <algorithm>头文件说明 template<class _InIt, class _Fn1> ...

  8. 官方online ddl

    一.5.6版本online DDL 操作 In Place Rebuilds Table Concurrent DML Only Modifies Metadata 说明 add/create sec ...

  9. CSS3 Loading进度条加载动画特效

    在线演示 本地下载

  10. securecrt重建

    CRT重建步骤: 重装系统或者重装CRT后,面临找回以前的session记录信息.记住下面的步骤,再也不担心丢session了! 1.备份关键文件(config文件夹)   (1)配置文件默认文件路径 ...