http://robot-framework.readthedocs.io/en/latest/autodoc/robot.utils.html#robot.utils.asserts.assert_raises_with_msg

robot.utils.asserts module

Convenience functions for testing both in unit and higher levels.

对于单元测试或者更高级别封装的function非常方便的函数。

Benefits:
  • Integrates 100% with unittest (see example below)
  • 和unittest 可以百分百整合,可共用。
  • Can be easily used without unittest (using unittest.TestCase when you only need convenient asserts is not so nice)
  • 可以非常方便的使用而不必引入unittest.TestCase的测试模块,当你只需要方便的使用asserts没有其他太高要求的时候。
  • Saved typing and shorter lines because no need to have ‘self.’ before asserts. These are static functions after all so that is OK.
  • 可以省略代码,因为不需要 self. 这种东东,当你在使用asserts之前。 这些都是静态功能, 所以没问题的。
  • All ‘equals’ methods (by default) report given values even if optional message given. This behavior can be controlled with the optional values argument.
  • 所有 ‘equals’ 方法默认可以提供report 值的除非在传参里面已经指定, 这些行为是可以通过参数控制的。
Drawbacks:
  • unittest is not able to filter as much non-interesting traceback away as with its own methods because AssertionErrors occur outside.
  • 由于断言错误发生在外部,因此unittest无法像使用其自己的方法那样过滤掉多余的不感兴趣的回溯。

Most of the functions are copied more or less directly from unittest.TestCase which comes with the following license. Further information about unittest in general can be found from http://pyunit.sourceforge.net/. This module can be used freely in same terms as unittest。

Examples:

 #!/usr/bin/python
#coding:utf-8 import unittest
from robot.utils.asserts import assert_equal class MyTests(unittest.TestCase): def test_old_style(self):
self.assertEqual(1, 2, ‘my msg’) def test_new_style(self):
assert_equal(1, 1, 'my MSG') if __name__ == '__main__':
unittest.main()

======================================================================
FAIL: test_old_style (__main__.MyTests)
----------------------------------------------------------------------
Traceback (most recent call last):
  File "unittest_test.py", line 10, in test_old_style
    self.assertEqual(1, 2, 'my msg')
AssertionError: my msg

----------------------------------------------------------------------
Ran 2 tests in 0.001s

FAILED (failures=1)

#!/usr/bin/python
#coding:utf-8 import unittest
from robot.utils.asserts import * class MyTests(unittest.TestCase): def test_old_style(self):
self.assertEqual(1, 2, 'my msg') def test_new_style(self):
assert_equal(1, 1, 'my MSG') def test_fail(self):
'''
robot.utils.asserts 的fail函数
报错, 参数是report的值
'''
fail("haha")
def test_assert(self):
assert_false(True, 'if true report msg') if __name__ == '__main__':
unittest.main() E:\Project-workspace\python_test\nightScript\voicecard-python\08__VOIP>python unittest_test.py
FF.F
======================================================================
FAIL: test_assert (__main__.MyTests)
----------------------------------------------------------------------
Traceback (most recent call last):
  File "unittest_test.py", line 22, in test_assert
    assert_false(True, 'if true report msg')
  File "E:\Software\Software\Python2.7.11\lib\site-packages\robot\utils\asserts.py", line 108, in assert_false
    _report_failure(msg)
  File "E:\Software\Software\Python2.7.11\lib\site-packages\robot\utils\asserts.py", line 219, in _report_failure
    raise AssertionError(msg)
AssertionError: if true report msg ======================================================================
FAIL: test_fail (__main__.MyTests)
----------------------------------------------------------------------
Traceback (most recent call last):
  File "unittest_test.py", line 20, in test_fail
    fail("haha")
  File "E:\Software\Software\Python2.7.11\lib\site-packages\robot\utils\asserts.py", line 102, in fail
    _report_failure(msg)
  File "E:\Software\Software\Python2.7.11\lib\site-packages\robot\utils\asserts.py", line 219, in _report_failure
    raise AssertionError(msg)
AssertionError: haha ======================================================================
FAIL: test_old_style (__main__.MyTests)
----------------------------------------------------------------------
Traceback (most recent call last):
  File "unittest_test.py", line 10, in test_old_style
    self.assertEqual(1, 2, 'my msg')
AssertionError: my msg ----------------------------------------------------------------------
Ran 4 tests in 0.001s FAILED (failures=3)
从robot提供的源码可以看出assert失败的处理直接raise 了ERROR出来,会跳出执行程序
def _report_failure(msg):
if msg is None:
raise AssertionError()
raise AssertionError(msg) def _report_inequality_failure(obj1, obj2, msg, values, delim, extra=None):
if not msg:
msg = _get_default_message(obj1, obj2, delim)
elif values:
msg = '%s: %s' % (msg, _get_default_message(obj1, obj2, delim))
if values and extra:
msg += ' ' + extra
raise AssertionError(msg)
其他的用法大同小异,具体的可以参照官方文档, 以上只是举了几个例子。
robot.utils.asserts.fail(msg=None)[source]

Fail test immediately with the given message.

robot.utils.asserts.assert_false(expr, msg=None)[source]

Fail the test if the expression is True.

robot.utils.asserts.assert_true(expr, msg=None)[source]

Fail the test unless the expression is True.

robot.utils.asserts.assert_not_none(obj, msg=None, values=True)[source]

Fail the test if given object is None.

robot.utils.asserts.assert_none(obj, msg=None, values=True)[source]

Fail the test if given object is not None.

robot.utils.asserts.assert_raises(exc_class, callable_obj, *args, **kwargs)[source]

Fail unless an exception of class exc_class is thrown by callable_obj.

callable_obj is invoked with arguments args and keyword arguments kwargs. If a different type of exception is thrown, it will not be caught, and the test case will be deemed to have suffered an error, exactly as for an unexpected exception.

If a correct exception is raised, the exception instance is returned by this method.

robot.utils.asserts.assert_raises_with_msg(exc_class, expected_msg, callable_obj, *args, **kwargs)[source]

Similar to fail_unless_raises but also checks the exception message.

robot.utils.asserts.assert_equal(first, second, msg=None, values=True)[source]

Fail if given objects are unequal as determined by the ‘==’ operator.

robot.utils.asserts.assert_not_equal(first, second, msg=None, values=True)[source]

Fail if given objects are equal as determined by the ‘==’ operator.

robot.utils.asserts.assert_almost_equal(first, second, places=7, msg=None, values=True)[source]

Fail if the two objects are unequal after rounded to given places.

inequality is determined by object’s difference rounded to the given number of decimal places (default 7) and comparing to zero. Note that decimal places (from zero) are usually not the same as significant digits (measured from the most signficant digit).

robot.utils.asserts.assert_not_almost_equal(first, second, places=7, msg=None, values=True)[source]

Fail if the two objects are unequal after rounded to given places.

Equality is determined by object’s difference rounded to to the given number of decimal places (default 7) and comparing to zero. Note that decimal places (from zero) are usually not the same as significant digits (measured from the most significant digit).

 

robotframework API 源码阅读笔记----robot.utils.asserts的更多相关文章

  1. jdk源码阅读笔记-LinkedHashMap

    Map是Java collection framework 中重要的组成部分,特别是HashMap是在我们在日常的开发的过程中使用的最多的一个集合.但是遗憾的是,存放在HashMap中元素都是无序的, ...

  2. CI框架源码阅读笔记5 基准测试 BenchMark.php

    上一篇博客(CI框架源码阅读笔记4 引导文件CodeIgniter.php)中,我们已经看到:CI中核心流程的核心功能都是由不同的组件来完成的.这些组件类似于一个一个单独的模块,不同的模块完成不同的功 ...

  3. CI框架源码阅读笔记4 引导文件CodeIgniter.php

    到了这里,终于进入CI框架的核心了.既然是“引导”文件,那么就是对用户的请求.参数等做相应的导向,让用户请求和数据流按照正确的线路各就各位.例如,用户的请求url: http://you.host.c ...

  4. CI框架源码阅读笔记3 全局函数Common.php

    从本篇开始,将深入CI框架的内部,一步步去探索这个框架的实现.结构和设计. Common.php文件定义了一系列的全局函数(一般来说,全局函数具有最高的加载优先权,因此大多数的框架中BootStrap ...

  5. CI框架源码阅读笔记2 一切的入口 index.php

    上一节(CI框架源码阅读笔记1 - 环境准备.基本术语和框架流程)中,我们提到了CI框架的基本流程,这里再次贴出流程图,以备参考: 作为CI框架的入口文件,源码阅读,自然由此开始.在源码阅读的过程中, ...

  6. 源码阅读笔记 - 1 MSVC2015中的std::sort

    大约寒假开始的时候我就已经把std::sort的源码阅读完毕并理解其中的做法了,到了寒假结尾,姑且把它写出来 这是我的第一篇源码阅读笔记,以后会发更多的,包括算法和库实现,源码会按照我自己的代码风格格 ...

  7. Three.js源码阅读笔记-5

    Core::Ray 该类用来表示空间中的“射线”,主要用来进行碰撞检测. THREE.Ray = function ( origin, direction ) { this.origin = ( or ...

  8. PHP源码阅读笔记一(explode和implode函数分析)

    PHP源码阅读笔记一一.explode和implode函数array explode ( string separator, string string [, int limit] )此函数返回由字符 ...

  9. AQS源码阅读笔记(一)

    AQS源码阅读笔记 先看下这个类张非常重要的一个静态内部类Node.如下: static final class Node { //表示当前节点以共享模式等待锁 static final Node S ...

随机推荐

  1. yum软件包管理

    一.yum常用命令 #yum -y install [软件包名] //安装 #yum erase [软件包名] //卸载 #yum clean all //清除缓存 #yum makecache // ...

  2. Centos 的防火墙(firewalld,iptables)

    Centos系统防火墙介绍 概述: 1.Filewalld(动态防火墙)作为redhat7系统中变更对于netfilter内核模块的管理工具: 2.iptables service 管理防火墙规则的模 ...

  3. Mybatis学习笔记大纲

    Mybatis学习笔记大纲: 一.MyBatis简介 二.MyBatis-HelloWorld 三.MyBatis-全局配置文件 四.MyBatis-映射文件 五.MyBatis-动态SQL 六.My ...

  4. struts2的相关知识(实现原理、拦截器)

    struts2的实现原理 客户端初始化一个指向Servlet容器(例如Tomcat)的请求 这个请求经过一系列的过滤器(Filter)(这些过滤器中有一个叫做ActionContextCleanUp的 ...

  5. 【leetcode】1094. Car Pooling

    题目如下: You are driving a vehicle that has capacity empty seats initially available for passengers.  T ...

  6. vuex的mapState方法来获取vuex的state对象中属性

    有两种写法 1.首先在组件中引入vuex的mapState方法: 首先在组件中引入vuex的mapState方法: import { mapState } from 'vuex' 然后在compute ...

  7. php similar_text()函数 语法

    php similar_text()函数 语法 作用:计算两个字符串的相似度,并返回匹配字符的数目大理石平台厂家 语法:similar_text(string1,string2,percent) 参数 ...

  8. win7每天出现taskeng.exe进程的解决方案

    安装mysql数据库后电脑经常会出现taskeng.exe进程,这不是木马.病毒,是微软提供的任务计划程序引擎. 禁不禁止都差不多.下面说一下怎么禁止. -->打开控制面板 -->打开管理 ...

  9. 【HDOJ6651】Final Exam(贪心)

    题意:有n门课,价值之和为m,每门课的价值可能是0到m 一门价值为x的课需要花至少x+1时间准备才能通过 问不管价值如何分配都能通过至少k门课的最小总准备时间 m,n,k<=1e9 思路: #i ...

  10. 【SpringBoot】 项目中运用的一些技巧,mybatis-plus 自动编译等(持续更新)

    前言 本文将总结项目中用到的一些springboot 的技巧,持续更新. Mybatis-Plus 的运用 使用原因: 主要是节省了Mapper层的编写,通过继承BaseMapper可以直接调用通用的 ...