引入 unittest 框架

相想使用unittest 框架,首先要引入unittest 包

import unittest

class Baidu(unittest.TestCase):

Baidu 类继承 unittest.TestCase 类,从TestCase 类继承是告诉unittest 模块的方式,这是一个测试案例。

def setUp(self):

self.driver = webdriver.Firefox()

self.base_url = "http://www.baidu.com/"

setUp 用于设置初始化的部分,在测试用例执行前,这个方法中的函数将先被调用。这里将浏览器的调用和URL 的访问放到初始化部分。

self. verificationErrors = []

脚本运行时,错误的信息将被打印到这个列表中。

self.accept_next_alert = True

是否继续接受下一下警告

def test_baidu(self):

driver = self.driver

driver.get(self.base_url + "/" )

test_baidu 中放置的就是我们的测试脚本。

def is_element_present(self, how, what):

try : self.driver.find_element(by=how, value=what)

except NoSuchElementException, e: return False

return True

is_element_present 函数用来查找页面元素是否存在,在这里用处不大,通常删除。因为判断页面元素是否存在一般都加在testcase 中。

def is_alert_present(self):

try : self.driver.switch_to_alert()

except NoAlertPresentException, e: return False

return True

对弹窗异常的处理

def close_alert_and_get_its_text(self):

try :

alert = self.driver.switch_to_alert()

alert_text = alert.text

if self.accept_next_alert:

alert.accept()

else :

alert.dismiss()

return alert_text

finally : self.accept_next_alert = True

关闭警告和对得到文本框的处理。

def tearDown(self):

self.driver.quit()

self.assertEqual([], self.verificationErrors)

tearDown 方法在每个测试方法执行后调用,这个地方做所有清理工作,如退出

浏览器等。

if __name__ == "__main__":

unittest.main()

unitest.main()函数用来测试类中以test 开头的测试用例。

unittest 单元测试框架解析


  • 用import 语句引入unittest 模块
  • 让所有执行测试的类都继承于TestCase 类,可以将TestCase 看成是对特定类进行测试的方法的集合
  • setUp()方法中进行测试前的初始化工作,tearDown()方法中执行测试后的清除工作。setUp()和tearDown()都是TestCase 类中定义的方法
  • 在testSize()中调用assertEqual()方法,对Widget 类中getSize()方法的返回值和预期值进行比较,确保两者是相等的,assertEqual()也是TestCase 类中定义的方法。
  • 提供名为suite()的全局方法,PyUnit 在执行测试的过程调用suit()方法来确定有多少个测试用例需要被执行,可以将TestSuite 看成是包含所有测试用例的一个容器。

采用PyUnit 提供的动态方法,只编写一个测试类来完成对整个软件模块的测试,这样对象的初始化工作可以在setUp()方法中完成,而资源的释放则可以在tearDown()方法中完成。

我们可以在一个测试类中,写多个测试用例对被测试类的方法进行测试。

完整的单元测试很少只执行一个测试用例,开发人员通常都需要编写多个测试用例才能对某一软件功能进行比较完整的测试,这些相关的测试用例称为一个测试用例集,在PyUnit 中是用TestSuite 类来表示的。可以在单元测试代码中定义一个名为suite()的全局函数,并将其作为整个单元测试的入口,PyUnit 通过调用它来完成整个测试过程。

def suite():

suite = unittest.TestSuite()

suite.addTest(WidgetTestCase( "testSize"))

suite.addTest(WidgetTestCase( "testResize"))

return suite

如果用于测试的类中所有的测试方法都以test 开头,Python 程序员甚至可以用PyUnit 模块提供的makeSuite()方法来构造一个。

def suite():

return unittest.makeSuite(WidgetTestCase, "test")

TestSuite 类可以看成是TestCase 类的一个容器,用来对多个测试用例进行组织,这样多个测试用例可以自动在一次测试中全部完成。

PyUnit 使用TestRunner 类作为测试用例的基本执行环境,来驱动整个单元测试过程。

runner = unittest.TextTestRunner()

runner.run(suite)

# 测试

if __name__ == "__main__" :

# 构造测试集

suite = unittest.TestSuite()

suite.addTest(WidgetTestCase( "testSize"))

suite.addTest(WidgetTestCase( "testResize"))

# 执行测试

runner = unittest.TextTestRunner()

runner.run(suite)

PyUnit 模块中定义了一个名为main 的全局方法,使用它可以很方便地将一个单元测试模块变成可以直接运行的测试脚本,main()方法使用TestLoader 类来搜索所有包含在该模块中的测试方法,并自动执行它们。如果Python 程序员能够按照约定(以test开头)来命名所有的测试方法,那就只需要在测试模块的最后加入如下几行代码即可:

# 测试

if __name__ == "__main__" :

unittest.main()

批量执行测试集


合理的做法是一个例一个文件,把所文件放一个文件夹下,通过单独的脚本控制所有用例的执行,将脚本的执行结果输出到一个log 文件中。

执行用例集的脚本:

#-*-coding=utf-8 -*-

import os

#列出某个文件夹下的所有case,这里用的是python,所在py 文件运行一次后会生成一个pyc的副本

caselist=os.listdir( 'D:\\selenium_use_case\\test_case')

for a in caselist:

s=a.split('.')[1:][0] #选取所要执行的用例

if s== 'py':

#此处执行dos 命令并将结果保存到log.txt

os.system( 'D:\\selenium_use_case\\test_case\\%s 1>>log.txt 2>&1'%a )

引入

unittest

框架

相想使用

unittest

框架,首先要引入

unittest

import unittest

class Baidu(unittest.TestCase):

Baidu

类继承

unittest.TestCase

类,从

TestCase

类继承是告诉

unittest

模块的方式,这

是一个测试案例。

def setUp(self):

self.driver = webdriver.Firefox()

self.base_url = "http://www.baidu.com/"

setUp

用于设置初始化的部分,

在测试用例执行前,

这个方法中的函数将先被调用。

这里将

浏览器的调用和

URL

的访问放到初始化部分。

self. verificationErrors = []

脚本运行时,错误的信息将被打印到这个列表中。

self.accept_next_alert = True

是否继续接受下一下警告

def test_baidu(self):

driver = self.driver

driver.get(self.base_url + "/" )

test_baidu

中放置的就是我们的测试脚本。

def is_element_present(self, how, what):

try : self.driver.find_element(by=how, value=what)

except NoSuchElementException, e: return False

return True

is_element_present

函数用来查找页面元素是否存在,在这里用处不大,通常删除。因为

判断页面元素是否存在一般都加在

testcase

中。

def is_alert_present(self):

try : self.driver.switch_to_alert()

 

except NoAlertPresentException, e: return False

return True

对弹窗异常的处理

def close_alert_and_get_its_text(self):

try :

alert = self.driver.switch_to_alert()

alert_text = alert.text

if self.accept_next_alert:

alert.accept()

 

else :

alert.dismiss()

return alert_text

finally : self.accept_next_alert = True

关闭警告和对得到文本框的处理。

def tearDown(self):

self.driver.quit()

self.assertEqual([], self.verificationErrors)

tearDown

方法在每个测试方法执行后调用,这个地方做所有清理工作,如退出

浏览器等。

if __name__ == "__main__":

unittest.main()

unitest.main()

函数用来测试类中以

test

开头的测试用例。

unittest

单元测试框架解析

import

语句引入

unittest

模块

让所有执行测试的类都继承于

TestCase

类,

可以将

TestCase

看成是对特定类进行

测试的方法的集合

setUp()

方法中进行测试前的初始化工作,

tearDown()

方法中执行测试后的清除工作。

setUp()

tearDown()

都是

TestCase

类中定义的方法

testSize()

中调用

assertEqual()

方法,

Widget

类中

getSize()

方法的返回值和预

期值进行比较,确保两者是相等的,

assertEqual()

也是

TestCase

类中定义的方法。

 

提供名为

suite()

的全局方法,

PyUnit

在执行测试的过程调用

suit()

方法来确定有多

少个测试用例需要被执行,

可以将

TestSuite

看成是包含所有测试用例的一个容器。

 

采用

PyUnit

提供的动态方法,只编写一个测试类来完成对整个软件模块的测试,这样对象

的初始化工作可以在

setUp()

方法中完成,而资源的释放则可以在

tearDown()

方法中完成。

我们可以在一个测试类中,写多个测试用例对被测试类的方法进行测试。

完整的单元测试很少只执行一个测试用例,

开发人员通常都需要编写多个测试用例才能对某

一软件功能进行比较完整的测试,这些相关的测试用例称为一个测试用例集,在

PyUnit

是用

TestSuite

类来表示的。

可以在单元测试代码中定义一个名为

suite()

的全局函数,

并将

其作为整个单元测试的入口,

PyUnit

通过调用它来完成整个测试过程。

def suite():

suite = unittest.TestSuite()

suite.addTest(WidgetTestCase( "testSize"))

suite.addTest(WidgetTestCase( "testResize"))

return suite

如果用于测试的类中所有的测试方法都以

test

开头,

Python

程序员甚至可以用

PyUnit

块提供的

makeSuite()

方法来构造一个。

def suite():

return unittest.makeSuite(WidgetTestCase, "test")

TestSuite

类可以看成是

TestCase

类的一个容器,用来对多个测试用例进行组织,这样多

个测试用例可以自动在一次测试中全部完成。

PyUnit

使用

TestRunner

类作为测试用例的基本执行环境,来驱动整个单元测试过程。

runner = unittest.TextTestRunner()

runner.run(suite)

#

测试

if __name__ == "__main__" :

#

构造测试集

suite = unittest.TestSuite()

suite.addTest(WidgetTestCase( "testSize"))

suite.addTest(WidgetTestCase( "testResize"))

 

#

执行测试

runner = unittest.TextTestRunner()

runner.run(suite)

PyUnit

模块中定义了一个名为

main

的全局方法,使用它可以很方便地将一个单元测试模

块变成可以直接运行的测试脚本,

main()

方法使用

TestLoader

类来搜索所有包含在该模块

中的测试方法,并自动执行它们。如果

Python

程序员能够按照约定(以

test

开头)来命名

所有的测试方法,那就只需要在测试模块的最后加入如下几行代码即可:

#

测试

if __name__ == "__main__" :

unittest.main()

批量执行测试集

合理的做法是一个例一个文件,

把所文件放一个文件夹下,

通过单独的脚本控制所有用例的

执行,将脚本的执行结果输出到一个

log

文件中。

执行用例集的脚本:

#-*-coding=utf-8 -*-

import os

#

列出某个文件夹下的所有

case,

这里用的是

python

,所在

py

文件运行一次后会生成一个

pyc

的副本

caselist=os.listdir( 'D:\\selenium_use_case\\test_case')

for a in caselist:

s=a.split('.')[1:][0] #

选取所要执行的用例

if s== 'py':

#

此处执行

dos

命令并将结果保存到

log.txt

os.system( 'D:\\selenium_use_case\\test_case\\%s 1>>log.txt 2>&1'%a )

unittest 单元测试框架的更多相关文章

  1. unittest单元测试框架总结

    unittest单元测试框架不仅可以适用于单元测试,还可以适用WEB自动化测试用例的开发与执行,该测试框架可组织执行测试用例,并且提供了丰富的断言方法,判断测试用例是否通过,最终生成测试结果.今天笔者 ...

  2. unittest单元测试框架详解

    unittest单元测试框架不仅可以适用于单元测试,还可以适用WEB自动化测试用例的开发与执行,该测试框架可组织执行测试用例,并且提供了丰富的断言方法,判断测试用例是否通过,最终生成测试结果.今天笔者 ...

  3. Selenium+Python ---- 免登录、等待、unittest单元测试框架、PO模型

    1.免登录在进行测试的过程中难免会遇到登录的情况,给测试工作添加了工作量,本文仅提供一些思路供参考解决方式:手动请求中添加cookies.火狐的profile文件记录信息实现.人工介入.万能验证码.去 ...

  4. unittest单元测试框架

    unittest单元测试框架 概述: 单元测试框架主要用来完成以下三件事: 提供用例组织与执行:当测试用例只有几条时,可以不必考虑用例的组织,但是当用例达到成百上千条时,大量的用例堆砌在一起,就产生了 ...

  5. unittest单元测试框架简单说明

    unittest单元测试框架不仅可以适用于单元测试,还可以适用WEB自动化测试用例的开发与执行,该测试框架可组织执行测试用例,并且提供了丰富的断言方法,判断测试用例是否通过,最终生成测试结果.今天笔者 ...

  6. Python+selenium之简单介绍unittest单元测试框架

    Python+selenium之简单介绍unittest单元测试框架 一.unittest简单介绍 unittest支持测试自动化,共享测试用例中的初始化和关闭退出代码,在unittest中最小单元是 ...

  7. unittest单元测试框架总结(转载)

    转载:https://www.cnblogs.com/yufeihlf/p/5707929.html unittest单元测试框架不仅可以适用于单元测试,还可以适用WEB自动化测试用例的开发与执行,该 ...

  8. 四. 引入unittest单元测试框架

    1.   安装 SeleniumIDE(firefox) (1)下载地址:https://addons.mozilla.org/en-US/firefox/addon/selenium-ide/ (2 ...

  9. unittest 单元测试框架断言方法

    unittest单元测试框架的TestCase类下,测试结果断言方法:Assertion methods 方法 检查 版本 assertEqual(a, b)  a == b assertNotEqu ...

随机推荐

  1. Python与数据库[2] -> 关系对象映射/ORM[0] -> ORM 与 sqlalchemy 模块

    ORM 与 sqlalchemy 1 关于ORM / About ORM 1.1 ORM定义 / Definition of ORM ORM(Object Relational Mapping),即对 ...

  2. [BZOJ 4031] 小Z的房间

    Link: BZOJ 4031 传送门 Solution: 矩阵树定理的模板题 看完下面两篇文章就会啦: 周冬论文:https://wenku.baidu.com/view/872eb02de2bd9 ...

  3. EF for oracle中无法读取配置 显示无法open问题解决方式

    1.更新以上设置为 非注销部分 弄了很久很久哈.

  4. service mysqld start 报错:service mysqld start 报错 090517 13:34:15 [ERROR] Can't open the mysql.plugin table. Please run mysql_upgrade to create it. 090Can't open the mysql.plugin table. Please run mysql

    service mysqld start 报错 090517 13:34:15 [ERROR] Can't open the mysql.plugin table. Please run mysql_ ...

  5. xcode 6 exporting ipa 提示 Your account already has a valid iOS distribution certificate 的另一种解决方法

    背景: 1. XCode 6.1 2. 证书:develop 证书 3. Scheme 为Device 操作: 在Product - Archive 包过程中,选择Save for Ad hoc De ...

  6. Winform 遍历 ListBox中的所有项

    foreach(DataRowView row in listBox.Items ) { MessageBox.Show(row["displayMember"].ToString ...

  7. UVa 1218 - Perfect Service

    /*---UVa 1218 - Perfect Service ---首先对状态进行划分: ---dp[u][0]:u是服务器,则u的子节点可以是也可以不是服务器 ---dp[u][1]:u不是服务器 ...

  8. System.Runtime.InteropServices.COMException

    System.Runtime.InteropServices.COMException (0x80040154): Retrieving the COM class factory for compo ...

  9. django 配置上传图片和文件

    在django中经常遇到要上传文件的需求,这里记录下如何配置用户上传的文件保存 首先在setting中添加 TEMPLATES = [ { 'BACKEND': 'django.template.ba ...

  10. Unity3d / 3ds max 模型分享站点

    http://www.cgrealm.org/model/ 王国3D模型库 http://www.cgjoy.com/ 游戏特效论坛