Pyunit测试框架

一、概述

  本系列主要解决的问题是“接口自动化测试”,选择的测试语言是 python 脚本语言。截至目前为止,python是公认的最好的用于自动化应用的语言之一

二、PyUnit测试框架

  使用 python 作为自动化编程语言,那么就自然的使用 pyunit 作为自动化测试框架了。测试框架unittest要达到如下目标:

  ● 支持自动化测试

  ● 让所有的测试脚本共享 开启(setup) 和 关闭(shutdown) 的代码

  ● 可以通过集合(collections)的方式来组织测试用例脚本

  ● 将所有的测试脚本从测试报告框架中独立出来

为了达到以上目标,unittest支持如下几个重要概念:

  ● 测试装置(test fixture):

    为一个或者多个测试用例做一些准备工作,例如:连接一个数据库,创建一个目录,或者开启一个进程

  ● 测试用例(test case):

    测试用例是测试行为的最小单元,通过对一些输入输出值的对比来进行测试检查

  ● 测试套件(test suite):

    将测试用例 或者 测试用例集合 聚合组织起来的集合。可以批量执行一个测试套件内所有的测试用例

  ● 测试执行器(test runner):

    组织安排测试脚本执行活动的组件。测试执行器通过一些图形界面,文本界面或者返回一些特殊的值来展示测试脚本的结果。主要用于生成测试报告

三、基本示例

  如下示例也来自于官方文档 basic_demo.py:

 # coding:utf-"""
基本的自动化测试脚本 basic_demo.py
"""__author__ = 'zheng'import unittestclass TestStringMethods(unittest.TestCase): def setUp(self):
print 'init by setUp...' def tearDown(self):
print 'end by tearDown...' def test_upper(self):
self.assertEqual('foo'.upper(), 'FOO') def test_isupper(self):
self.assertTrue('FOO'.isupper())
self.assertFalse('Foo'.isupper())
self.assertTrue('Foo'.isupper()) def test_split(self):
s = 'hello world'
self.assertEqual(s.split(), ['hello', 'world'])
# check that s.split fails when the separator is not a string
with self.assertRaises(TypeError):
s.split()if __name__ == '__main__':
unittest.main()

测试用例脚本有如下几种组织方式:

  ● 独立测试函数

  ● 单用例测试类

  ● 多用例测试类

其中多用例测试类,也就是上面基本示例的方式,这种方式具有如下特点:

  1. 测试类 继承于 unittest.TestCase

  2. 一个测试类可以管理多个 测试脚本函数

  3. 测试脚本函数名称需要以 test_ 开头

  4. 一个测试类里面的所有的测试函数共享 setUp和tearDown函数

在控制台中运行此程序:

 ➜  src git:(master) ✗ python basic_demo.py
init by setUp...
Fend by tearDown...
init by setUp...
end by tearDown...
.init by setUp...
end by tearDown...
.======================================================================FAIL: test_isupper (__main__.TestStringMethods)----------------------------------------------------------------------
Traceback (most recent call last):
File "basic_demo.py", line , in test_isupper
self.assertTrue('Foo'.isupper())AssertionError: False is not true----------------------------------------------------------------------
Ran tests in .001s FAILED (failures=)➜ src git:(master) ✗

通过上面的运行结果,大家不难发现如下有用信息:

  ● 测试脚本执行的顺序,先setUp再执行测试函数,再tearDown

  ● 测试脚本输出中会将测试不通过的脚本及遇到的问题打印出来,这就是对测试人员有用的结果报表

  ● 执行的测试脚本的总数和测试所用的时间

四、总结

  本文的基本例子的 main 函数采用的最简单的方式,直接运行所有的测试用例,并生成默认的文本报告。其实只需要对调用函数做一些简单的修改,可以将这些测试用例进行合理组织,并获取其实有用的数据信息,以便和信息系统进行集成,形成较好的扩展

上一篇:STL概述


下一篇:Geolocation API 原理及方法