引入 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. 洛谷——P1403 [AHOI2005]约数研究

    P1403 [AHOI2005]约数研究 题目描述 科学家们在Samuel星球上的探险得到了丰富的能源储备,这使得空间站中大型计算机“Samuel II”的长时间运算成为了可能.由于在去年一年的辛苦工 ...

  2. luogu 2509. 森林大礼包

    2509. 森林大礼包 ★   输入文件:three_squirrels.in   输出文件:three_squirrels.out   简单对比时间限制:1 s   内存限制:256 MB [题目描 ...

  3. 高并发下的Node.js与负载均衡

    新兴的Node.js已经吸引了很多开发人员的眼光,它提供给我们一个快速构建高性能的网络应用的平台.我也开始逐步投入node.js的怀抱,在学习和使用的过程中,遇到了一些问题,也有一些经验,我觉得有必要 ...

  4. [置顶] kubernetes资源类型--Service

    为了适应快速的业务需求,微服务架构已经逐渐成为主流,微服务架构的应用需要有非常好的服务编排支持.K8S中的核心要素Service便提供了一套简化的服务代理和发现机制,天然适应微服务架构. 实现原理 S ...

  5. ubuntu配置 测试环境 记录

    1  更新源 进入 /etc/apt/sources.list sudo vim进入, 更改为如下源 # See http://help.ubuntu.com/community/UpgradeNot ...

  6. react.js Warning: Failed form propType: You provided a value prop to a form field without an onChange handler. This will render a read-only field.

    错误信息: eact.js:20483 Warning: Failed form propType: You provided a value prop to a form field without ...

  7. mysql开发之join语句学习

    内连接:inner join -- 全外链接:full outer 左外连接:left outer 右外连接:right outer 交叉连接:cross内连接,两个表中重复部分全外连接,两个表所有字 ...

  8. 数据库字段名称转java字段名称

    /** * * @Title: changeToJavaFiled * @Description: TODO(将数据库中带下划线的字段转换为Java常用的驼峰字段) * @param @param f ...

  9. Nginx user_agent、if指令及全局变量

    Nginx user_agent.if指令及全局变量 1.User_agent User Agent中文名为用户代理,简称 UA,它是一个特殊字符串头,使得服务器能够识别客户使用的操作系统及版本.CP ...

  10. P6 EPPM 16 R1安装和配置文档

    白桃花心木P6企业项目组合管理文档库  描述 链接 下载 零件号  16 R1用户和集成文档 查看库 下载 E68199-01 16 R1安装和配置文档 查看库 下载 E68198-01 描述 链接 ...