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. js执行上下文与执行上下文栈

    一.什么是执行上下文 简单说就是代码运行时的执行环境,必须是在函数调用的时候才会产生,如果不调用就不会产生这个执行上下文.在这个环境中,所有变量会被事先提出来(变量提升),有的直接赋值,有的为默认值 ...

  2. UIWebView和WKWebView一些琐事

    WebViewJavascriptBridge 1.load加载 ,去本地查找html路径方式 NSString* htmlPath = [[NSBundle mainBundle] pathForR ...

  3. CKEDITOR无缝粘贴word

    由于工作需要必须将word文档内容粘贴到编辑器中使用 但发现word中的图片粘贴后变成了file:///xxxx.jpg这种内容,如果上传到服务器后其他人也访问不了,网上找了很多编辑器发现没有一个能直 ...

  4. Linux下安装Harbor 1.8.0 仓库的安装和使用(亲测)

    根据Harbor官方描述: Harbor是一个用于存储和分发Docker镜像的企业级Registry服务器,通过添加一些企业必需的功能特性,例如安全.标识和管理等,扩展了开源Docker Distri ...

  5. Jenkins报错:该Jenkins实例似乎已离线

    解决方法: 1.保留此离线页面,重新开启一个浏览器tab标签页 2.输入输入网址http://localhost:8080/pluginManager/advanced 3.进入该页面最底下,找到[升 ...

  6. jmeter(二十):Logic Controller:逻辑控制器(上)

    逻辑控制器用来控制采样器(samplers)的执行顺序,根据实际需要定制执行规则.在控制器层级下面的所有的采样器都会当做一个整体,执行时也会一起被执行. Logic Controller种类: 以上L ...

  7. Jenkins 添加新用户

    下面重点记录下jenkins安装后的一些配置: (1)添加用户权限 jenkins初次登陆后,要先注册一个用户作为管理员: 依次点击“系统管理”->“Configure Global Secur ...

  8. AUC

    https://www.cnblogs.com/earendil/p/9400275.html

  9. 【SD系列】SAP SD模块-创建供应商主数据BAPI

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[SD系列]SAP SD模块-创建供应商主数据B ...

  10. 如何通过xmake进行交叉编译

    xmake 提供了方便灵活的交叉编译支持,大部分情况下,都不需要配置很复杂的toolchains前缀,例如:arm-linux- 什么的 只要这个toolchains目录满足如下结构(大部分的交叉工具 ...