前言:断言是自动化最终的目的,一个用例没有断言,就失去了自动化测试的意义了。

  断言用到的是 assert关键字。之前的介绍,有的测试方法中其实用到了assert断言。简单的来说,就是预期的结果去和实际结果做对比,符合预期结果就是pass,不符合就fail。

比如以下的一段代码:

def add(a,b):
return a+b def test_assert():
assert 6 == add(3,4) 结果:可以看出,判断的结果是6,和方法返回的结果不一致,所以导致失败。从黄色部分的报错信息可以看出,结果不一致。

test_assert.py F
test_assert.py:11 (test_assert)
7 != 6

Expected :6
Actual :7
<Click to see difference>

def test_assert():
> assert 6 == add(3,4)
E assert 6 == 7
E + where 7 = add(3, 4)

test_assert.py:13: AssertionError
[100%]

=================================== FAILURES ===================================
_________________________________ test_assert __________________________________

def test_assert():
> assert 6 == add(3,4)
E assert 6 == 7
E + where 7 = add(3, 4)

test_assert.py:13: AssertionError

异常信息提示:如果想在异常的时候输出一些提示信息,这样报错后就方便查看是什么原因了。

def add(a,b):
return a+b def test_assert():
assert 6 == add(3,4),"方法返回的值不等于6,而是等于{0}".format(add(3,4)) 结果:可以看出黄色部分,这样会写清楚失败的原因,当有多个判断时,可以容易定位问题。

test_assert.py F
test_assert.py:12 (test_assert)
def test_assert():

> assert 6 == add(3,4),"方法返回的值不等于6,而是等于{0}".format(add(3,4))
E AssertionError: 方法返回的值不等于6,而是等于7
E assert 6 == 7
E + where 7 = add(3, 4)

test_assert.py:15: AssertionError
[100%]

=================================== FAILURES ===================================
_________________________________ test_assert __________________________________

def test_assert():

> assert 6 == add(3,4),"方法返回的值不等于6,而是等于{0}".format(add(3,4))
E AssertionError: 方法返回的值不等于6,而是等于7
E assert 6 == 7
E + where 7 = add(3, 4)

test_assert.py:15: AssertionError

异常断言:为了写关于引发异常的断言,可以使用pytest.raises作为上下文管理器:

import pytest

def test_zero_division():
with pytest.raises(ZeroDivisionError):
1/0 结果:可以看出并没有报错,正常情况下,不加异常是会报错的。

============================= test session starts ==============================
platform darwin -- Python 2.7.10, pytest-3.6.3, py-1.5.2, pluggy-0.6.0
rootdir: /Users/newcomer/PycharmProjects/error/wuya/pytestDemo, inifile:
plugins: metadata-1.7.0, html-1.19.0, D3-2.0.13, cov-2.5.1, catchlog-1.2.2, allure-adaptor-1.7.10, georaven-17.1.0.170collected 1 item

test_assert.py . [100%]

-- Docs: http://doc.pytest.org/en/latest/warnings.html
===================== 1 passed, 1 warnings in 0.01 seconds =====================

以上,我们要断言它抛的异常是不是预期的,比如执行:1/0,预期结果是抛异常:ZeroDivisionError: division by zero,那我们要断言这个异常。通常是断言异常的type和value的值。这里1/0的异常类型是ZeroDivisionError,异常的value值是"integer division or modulo by zero",于是以下是代码的设计用例:

import pytest

def test_zero_division():
with pytest.raises(ZeroDivisionError,message="Exceptions ZeroDivisionError") as exinfo:
1/0 assert exinfo.type == ZeroDivisionError
assert str(exinfo.value) == "integer division or modulo by zero","{0}".format(exinfo.value) 结果:可以看出来,通过了一个测试用例,但是需要注意,需要把value的值转换成str类型的才可以比较,而且值是要加引号的。断言type的时候,不需要给异常类型添加引号。
raises里面的message关键字参数消息指定自定义失败消息。

============================= test session starts ==============================
platform darwin -- Python 2.7.10, pytest-3.6.3, py-1.5.2, pluggy-0.6.0
rootdir: /Users/newcomer/PycharmProjects/error/wuya/pytestDemo, inifile:
plugins: metadata-1.7.0, html-1.19.0, D3-2.0.13, cov-2.5.1, catchlog-1.2.2, allure-adaptor-1.7.10, georaven-17.1.0.170collected 1 item

test_assert.py .exinfo.type: <type 'exceptions.ZeroDivisionError'>
exinfo.value: integer division or modulo by zero
[100%]

===================== 1 passed, 1 warnings in 0.01 seconds =====================

import pytest

def test_exception():
with pytest.raises(ZeroDivisionError,message="Exception ZeroDivisionError") as exinfo:
pass 结果:可以看出来,结果中的异常是message自己定义的信息

=================================== FAILURES ===================================
________________________________ test_exception ________________________________


def test_exception():
with pytest.raises(ZeroDivisionError,message="Exception ZeroDivisionError") as exinfo:
> pass
E Failed: Exception ZeroDivisionError


test_assert.py:28: Failed

================ 1 failed, 1 warnings in 0.08 seconds ================

 

常用断言:pytest里面的断言实际上就是python里面assert的断言方法,常用以下几种:

·assert xx  判断xx为真

·assert not xx 判断xx不为真

·assert a in b 判断b包含a

·assert a == b 判断a等于b

·assert a != b 判断a不等于b

def is_true(num):
if num>0:
return True
else:
return False def test_01():
"""判断是不是为真"""
a = 5
b = -1
assert is_true(a)
assert not is_true(b) def test_02():
"""判断b包含a"""
a = "hello"
b = "hello world"
assert a in b def test_03():
"""判断是否相等"""
a = "hello"
b = "hello"
c = "hello world"
assert a == b
assert a != c 结果:由此可以看出来,三个用例都执行成功。

============================= test session starts ==============================
platform darwin -- Python 2.7.10, pytest-3.6.3, py-1.5.2, pluggy-0.6.0
rootdir: /Users/newcomer/PycharmProjects/error/wuya/pytestDemo, inifile:
plugins: metadata-1.7.0, html-1.19.0, D3-2.0.13, cov-2.5.1, catchlog-1.2.2, allure-adaptor-1.7.10, georaven-17.1.0.170collected 3 items

test_assert.py ... [100%]

=============================== warnings summary ===============================
<undetermined location>
pytest-catchlog plugin has been merged into the core, please remove it from your requirements.

-- Docs: http://doc.pytest.org/en/latest/warnings.html
===================== 3 passed, 1 warnings in 0.02 seconds =====================

pytest 7 assert断言的更多相关文章

  1. pytest之assert断言

    assert pytest允许您使用标准Python断言来验证Python测试中的期望和值.例如,你可以写下 # content of test_assert1.py def f(): return ...

  2. pytest自动化7:assert断言

    前言:assert断言就是将实际结果和期望结果做对比,符合预期结果就测试pass,不符合预期就测试failed. 实例1:简单断言 实例1优化版--增加异常信息文字描述 异常断言 excinfo 是一 ...

  3. pytest七:assert断言

    断言是写自动化测试基本最重要的一步,一个用例没有断言,就失去了自动化测试的意义了.什么是断言呢?简单来讲就是实际结果和期望结果去对比,符合预期那就测试 pass,不符合预期那就测试 failed py ...

  4. iOS自动化探索(五)自动化测试框架pytest - Assert断言的使用

    使用assert语句进行断言 pytest允许使用标准的python assert语法,用来校验expectation and value是否一致 代码演示: def func(): def test ...

  5. Pytest系列(2) - assert断言详细使用

    如果你还想从头学起Pytest,可以看看这个系列的文章哦! https://www.cnblogs.com/poloyy/category/1690628.html 前言 与unittest不同,py ...

  6. Pytest(10)assert断言

    前言 断言是写自动化测试基本最重要的一步,一个用例没有断言,就失去了自动化测试的意义了.什么是断言呢? 简单来讲就是实际结果和期望结果去对比,符合预期那就测试pass,不符合预期那就测试 failed ...

  7. 【pytest系列】- assert断言的使用

    unittest断言方式是用过框架自己实现的,即self.assertEqual()等,当我们使用pytest框架后,这种断言方式是不可用的,因为测试类不会再继承unittest.TestCase类, ...

  8. Spring Assert 断言

    Assert(断言)的初步理解构思 Web 应用在接受表单提交的数据后都需要对其进行合法性检查,如果表单数据不合法,请求将被驳回.类似的,当我们在编写类的方法时,也常常需要对方法入参进行合 法性检查, ...

  9. C++ ASSERT() 断言机制

    C++ ASSERT() 断言机制 ASSERT()是一个调试程序时经常使用的宏,在程序运行时它计算括号内的表达式,如果表达式为FALSE (0), 程序将报告错误,并终止执行.如果表达式不为0,则继 ...

随机推荐

  1. Echarts使用Ajax异步获得数据的前端json格式转化问题

    利用Ajax获取后台传来的data,官网都有example 但如果后台传来的数据是String格式的,则应该在Ajax的done方法中第一句加上格式转换的语句 data = JSON.parse(da ...

  2. 接触Struts2的ModelDriven<>接口

    最近在学SSH框架,实战项目,用到了Struts2的ModelDriven<>接口,在这做一点记录 ModelDriven,意为模型驱动,意思是直接把实体类当成页面数据的收集对象 参考他人 ...

  3. php2

    session   //将用户的会话数据存储在服务端,通过 session_start()开启session,通过$_SESSION读写session session_start(); //开启ses ...

  4. Lodop打印设计、维护、预览、直接打印简单介绍

    四者的区别和联系:(其中PRINT_DESIGN打印设计是提供给开发人员的,另外三个可开放给用户)PRINT_DESIGN打印设计:辅助开发人员设计,图形化拖动插入修改等,设计完成后,生成代码拷贝到程 ...

  5. oracle NVL与Coalesce的区别

    先来说一下用法上的区别 : nvl(COMMISSION_PCT,0)如果第一个参数为null,则返回第二个参数如果第一个参数为非null,则返回第一个参数 COALESCE(EXPR1,EXPR2, ...

  6. nargin

    nargin 编辑 nargin为“number of input arguments”的缩写. 在matlab中定义一个函数时, 在函数体内部, nargin是用来判断输入变量个数的函数.在matl ...

  7. poj-3080(kmp+暴力枚举)

    题意:给你多个字符串,问你这几个字符串的最长公共子串是哪个,如果有多个,输出字典序最大的那个,如果最长的公共子串长度小于3,输出一个奇怪的东西: 解题思路:首先看数据,数据不大,开始简单快乐的暴力之路 ...

  8. 洛谷 P3953 逛公园

    题目链接 思路 首先没有0边,且k为0的情况就是最短路计数. 如果k不为0,看到k<=50,想到dp. 设f[u][i]表示到达u点比最短路多走i的路径数,转移到v点. f[u][i]+=f[v ...

  9. 【C/C++】龙格库塔+亚当姆斯求解数值微分初值问题

    /* 解数值微分初值问题: 龙格-库塔法求前k个初值 + 亚当姆斯法 */ #include<bits/stdc++.h> using namespace std; double f(do ...

  10. SpringMVC 复杂对象数据绑定

    表单在 web 页面上无处不在,有些表单可能很复杂,大部分表单里的输入项都会对应后端对象属性.SpringMVC 可以自动将表单值绑定到对象上!而且能绑定很复杂的对象!!这里就不写那些基本的表单绑定了 ...