在tempest框架中,使用的是testtools为基础框架来运行接口自动化

一、初识

testools是属于python中诸多自动化框架中的一个,官方文档如下:

http://testtools.readthedocs.io/en/latest/overview.html

但是,官方中的例子还有一个myproject基础文件,让很多同学很困惑,下面我们看看使用testtool最简单的框架,如下

from testtools import TestCase

class TestLearnTesttools(TestCase):

    def setUp(self):
super(TestLearnTesttools, self).setUp()
print "this is setUp" def test_case_1(self):
self.assertIn('a', 'cat') def test_case_2(self):
assert 2 == 3 def tearDown(self):
super(TestLearnTesttools, self).tearDown()
print "this is tearDown" @classmethod
def setUpClass(cls):
print "this is setUp class"

注意,setUp必须写super,不然会报如下错误

TestCase.setUp was not called. Have you upcalled all the way up the hierarchy fr
om your setUp? e.g. Call super(TestLearnTesttools, self).setUp() from your setUp
().

不然你就不要写setUp,这点感觉这个框架好奇葩...

运行结果如下:

E:\workspace\test_case>python -m testtools.run testtools_learn.py
Tests running...
this is setUp class
this is setUp
this is tearDown
this is setUp
this is tearDown
======================================================================
FAIL: testtools_learn.TestLearnTesttools.test_case_2
----------------------------------------------------------------------
Traceback (most recent call last):
File "testtools_learn.py", line , in test_case_2
assert ==
AssertionError Ran tests in .005s
FAILED (failures=)

在官网中,testtool可以使用很多种方式来运行,直接贴过来吧

那下面我们用nose来运行一下看看:

E:\workspace\test_case>nosetests -s -v testtools_learn.py
ALL starting...
this is setUp class
test_case.testtools_learn.TestLearnTesttools.test_case_1 ... this is setUp
this is tearDown
ok
test_case.testtools_learn.TestLearnTesttools.test_case_2 ... this is setUp
this is tearDown
FAIL ======================================================================
FAIL: test_case.testtools_learn.TestLearnTesttools.test_case_2
----------------------------------------------------------------------
_StringException: Traceback (most recent call last):
File "E:\workspace\nosetest_lear\test_case\testtools_learn.py", line , in te
st_case_2
assert ==
AssertionError ----------------------------------------------------------------------
Ran tests in .012s FAILED (failures=)

感觉还是nose的格式好看。

二、了解

既然知道testtool是怎么写及怎么运行了,我们来仔细看看,testtools到底是个什么东东

还是看官网,可以得知道,testtools是python标准库中unittest的扩展,从testtools源码中可以看到,继承的还是unittest2.TestCase

class TestCase(unittest.TestCase):
"""Extensions to the basic TestCase. :ivar exception_handlers: Exceptions to catch from setUp, runTest and
tearDown. This list is able to be modified at any time and consists of
(exception_class, handler(case, result, exception_value)) pairs.
:ivar force_failure: Force testtools.RunTest to fail the test after the
test has completed.
:cvar run_tests_with: A factory to make the ``RunTest`` to run tests with.
Defaults to ``RunTest``. The factory is expected to take a test case
and an optional list of exception handlers.
""" skipException = TestSkipped run_tests_with = RunTest

至于为什么要使用Testtools,官网上也说了,

1、有更好的断言方式

testtool加了assertInassertIsassertIsInstance及其它的。

虽然unittest标准库中也有这3个方式,但这3个方式是python 2.7之后才有的

具体testtool的断言优化可以到这里testtools.assertions查询

特别用法举例,来源网上

assertThat

def test_abs(self):
result = abs(-7)
self.assertEqual(result, 7)
self.assertNotEqual(result, 7)
self.assertThat(result, testtools.matchers.Equals(7))
self.assertThat(result, testtools.matchers.Not(Equals(8)))

expectFailure

def test_expect_failure_example(self):
self.expectFailure(
"cats should be dogs", self.assertEqual, 'cats', 'dogs')

2、更多调试手段

在测试过程中,如果你想得到更多的错误信息,可以使用TestCase.addDetail

TestCase.addDetail具体使用这里不写,感觉没用

3、fixtures

测试用例一般都包含一个 setUp 方法来准备测试环境,主要是生成一些测试过程中

会用到的变量与对象。有时候我们会需要在不同的测试用例间共享这些变量与对象,避免

在每一个测试用例中重复定义。所以就有了 fixtures,它制定了一套规范,将测试代码与

环境准备代码分离开来,使得测试代码亦可方便的组织和扩展。

class SomeTest(TestCase):
def setUp(self):
super(SomeTest, self).setUp()
self.server = self.useFixture(Server())

4、Skipping tests

检测到环境不符合要求的情况下,忽略某些测试

def test_make_symlink(self):
symlink = getattr(os, 'symlink', None)
if symlink is None:
self.skipTest("No symlink support")
symlink(whatever, something_else)

5、Test attributes

标签,与nose框架中的attr一样的道理,testtool中同样支持,使用时使用的参数是--load-list

from testtools.testcase import attr, WithAttributes

class AnnotatedTests(WithAttributes, TestCase):

    @attr('simple')
def test_one(self):
pass @attr('more', 'than', 'one')
def test_two(self):
pass @attr('or')
@attr('stacked')
def test_three(self):
pass

6、自定义的错误输入

self.exception_handlers.insert(-1, (ExceptionClass, handler)).

这样,在任何一个setUp teardown或测试用例中raise ExceptionClass都会调用

更多的用法请查阅framework folk

python 测试框架之---testtools的更多相关文章

  1. 用 Python 测试框架简化测试

    用 Python 测试框架简化测试 摘要:本文将向您介绍了三种流行 Python 测试框架(zope.testing,py.test,nose)的基本特性,并讨论新一代的测试风格. 最近出现了行业级的 ...

  2. 【转载】Python测试框架doctest

    原文在这里 :Python测试框架doctest 先记录一下,直接复制粘贴后,排版是乱的,后续再弄.

  3. 全功能Python测试框架:pytest

    python通用测试框架大多数人用的是unittest+HTMLTestRunner,这段时间看到了pytest文档,发现这个框架和丰富的plugins很好用,所以来学习下pytest.   imag ...

  4. <自动化测试>之<使用unittest Python测试框架进行参数化测试>

    最近在看视频时,虫师简单提到了简化自动化测试脚本用例中的代码量,而python中本身的参数化方法用来测试很糟糕,他在实际操作中使用了parameterized参数化... 有兴趣就查了下使用的方法,来 ...

  5. python 测试框架nose

    python测试框架nose nose不是python自带模块,这里我才用pip的方式安装 pip install nose 这样就完成了安装,然后再确认下是否安装成功了,直接打开cmd输入noset ...

  6. Python测试框架unittest

    Python测试框架unittest 一.unittest框架 (1)unittest特点 1.python自带的单元测试框架,不需要安装 2.用例执行互不干扰 3.提供不同范围的setUp和tear ...

  7. Python测试框架pytest入门基础

    Pytest简介 Pytest is a mature full-featured Python testing tool that helps you write better programs.T ...

  8. 收藏清单: python测试框架最全资源汇总

    xUnit frameworks 单元测试框架 frameworks 框架 unittest - python自带的单元测试库,开箱即用 unittest2 - 加强版的单元测试框架,适用于Pytho ...

  9. 转 python测试框架最全资源汇总

    转自: http://www.testclass.net/list/python_list_1/ xUnit frameworks(单元测试框架) frameworks 框架 unittest - p ...

随机推荐

  1. JUC回顾之-ConcurrentHashMap源码解读及原理理解

    ConcurrentHashMap结构图如下: ConcurrentHashMap实现类图如下: segment的结构图如下: package concurrentMy.juc_collections ...

  2. 【LFM】隐语义模型

    模型解释: http://blog.csdn.net/harryhuang1990/article/details/9924377

  3. datatable删除一行方法

    t.row($(e).parents('tr')[0]).remove().draw(false); t为定义的datatable对象,row里面传入当前行的DOM元素.

  4. nginx隐藏server信息和版本信息

    1.隐藏版本信息 在nginx.conf里面添加 server_tokens off; 2.隐藏server信息 需要重新编译ngnix进入解压出来的nginx 源码目录 vi src/http/ng ...

  5. springmvc+jsp 拦截器下如何设置欢迎页面

    0.需求 如何让用户在浏览器地址栏键入[http://XXX.XXX.XX.XX:端口号/应用名/]以后自动跳转到系统的登录界面 1.web.xml 1.1 注意welcome-file-list的配 ...

  6. 什么是REST设计风格

    https://zh.wikipedia.org/wiki/REST http://www.infoq.com/cn/articles/rest-introduction

  7. 奔五的人学ios:swift竟然没有字符串包括,找个简单的解决方法

    swift关于字符串的推断中 有前导.有后缀 两个方法.竟然没有包括推断. 经过学习找了个简单的解决方法: extension String { func has(v:String)->Bool ...

  8. WPF送走控件的focus方法

    我们可以调用Focus()方法,让WPF控件获得焦点, 那我现在不想要焦点了, 如何把这个包袱抛出去? 可以,  恩, 没有Unfocus(), 但下面的方法也许可行(把焦点抛给另一个不知道的控件): ...

  9. 转载nginx+uwsgi+django

    Django的部署可以有很多方式,采用nginx+uwsgi的方式是其中比较常见的一种方式. 在这种方式中,我们的通常做法是,将nginx作为服务器最前端,它将接收WEB的所有请求,统一管理请求.ng ...

  10. scala中to和util操作

    // Range:to:默认步进为1 val to1 = 1 to 10 println(to1) // 定义一个不进为2的Range val to2 = 1 to 10 by 2 println(t ...