python nose测试框架全面介绍二
二、基本使用
nosetest脚本的使用(在安装完nose之后)
nosetests [options] [(optional) test files or directories]
我们可以使用配置文件,将需要运行的参数放入,配置文件的文件名为nose.cfg中,是标准的配置文件格式,如下:
[nosetests]
verbosity=3
with-doctest=1
有部分参数可以不使用或禁用,你可以将配置放入配置文件中,但必须在系统中建立一个环境变量,名字为 NOSE_IGNORE_CONFIG_FILES
除了上面的运行方式,还有以下的途径使用nose
在python脚本中直接使用,如:
import nose
nose.main()
如果你不想使用unittest框架测试结束时这种显示方式,可以在脚本中使用以下方式:
import nose
result = nose.run()
说了这么多,可能还是没看明白,下面来几个实例,
在nose中,测试用例可以以函数和类的形式来组织,下面分别来演示下,
1、以函数形式写的测试用例:
#coding:utf-8
'''
Created on 2015年6月22日
@author:
'''
import logging log = logging.getLogger(__name__) def test_learn_3():
print("test_lean_3")
pass def test_lean_4():
print("test_learn_2") def test_lean_5():
print("test_learn_5")
def setUp():
print "0002 test setUp" def tearDown():
print "0002 test teardown" test_learn_3.teardown=test_lean_5.teardown= tearDown
运行的结果如下:
E:\workspace\nosetest_lear>nosetests -v -s test_case.test_case_0002 test setUp
test_case.test_case_0002.test_learn_3 ... test_lean_3
test teardown
ok
test_case.test_case_0002.test_lean_4 ... test_learn_2
ok
test_case.test_case_0002.test_lean_5 ... test_learn_5
test teardown
ok
test teardown
这里加了一句
test_learn_3.teardown=test_lean_5.teardown= tearDown,说明在运行完成后就执行tearDown操作
所以这里运行顺序为:setUp-->test_learn_3-->tearDown-->test_learn_3-->test_learn_4-->tearDown-->tearDown
因次,在函数或者函数式的用例组织中,setUp和tearDown只会执行一次,分别是开始及结束,注意:必须要用@classmethod装饰器标识
2、以类的形式组织的用例:
''' @author: huzq
'''
class TestClass(): def setUp(self):
print "MyTestClass setup" def tearDown(self):
print "MyTestClass teardown" def Testfunc1(self):
print "this is Testfunc1"
pass def test_func1(self):
print "this is test_func1"
pass def Testfunc2(self):
print "this is Testfunc2"
pass def test_func2(self):
print "this is test_func2"
pass
运行结果:
E:\workspace\nosetest_lear>nosetests -v -s test_case.test_case_0003
test_case.test_case_0003.TestClass.Testfunc1 ... MyTestClass setup
this is Testfunc1
MyTestClass teardown
ok
test_case.test_case_0003.TestClass.Testfunc2 ... MyTestClass setup
this is Testfunc2
MyTestClass teardown
ok
test_case.test_case_0003.TestClass.test_func1 ... MyTestClass setup
this is test_func1
MyTestClass teardown
ok
test_case.test_case_0003.TestClass.test_func2 ... MyTestClass setup
this is test_func2
MyTestClass teardown
ok ----------------------------------------------------------------------
Ran tests in .026s
从运行结果中可以看出,每个用例都会分别执行setUp及tearDown,但是与unittest一样,在类中的测试用例顺序变更了,由字母排序了。
注:在以类形式运行时,还有setUpClass及tearDownClass两个函数功能,是运行测试时,只运行一次。
3、以整个包的形式运行
我们创建python package时会自动生成__init__.py文件,我们将setUp或tearDown写入时,会在每个文件执行时都执行setUp和tearDown,如下

文件内容为:
def setUp():
print "ALL starting..."
然后再次执行以类的文件,结果如下:
E:\workspace\nosetest_lear>nosetests -v -s test_case.test_case_0003
ALL starting...
test_case.test_case_0003.TestClass.Testfunc1 ... MyTestClass setup
this is Testfunc1
MyTestClass teardown
ok
test_case.test_case_0003.TestClass.Testfunc2 ... MyTestClass setup
this is Testfunc2
MyTestClass teardown
ok
test_case.test_case_0003.TestClass.test_func1 ... MyTestClass setup
this is test_func1
MyTestClass teardown
ok
test_case.test_case_0003.TestClass.test_func2 ... MyTestClass setup
this is test_func2
MyTestClass teardown
ok ----------------------------------------------------------------------
Ran tests in .026s OK
从结果中可以看出,在执行前执行了__init__.py中的setUp函数
with_setup修饰器的使用,nose支持在每个用例前使用with_setup来自定义测试用例的setUp及tearDown功能,如下:
def setup_func():
"set up test fixtures" def teardown_func():
"tear down test fixtures" @with_setup(setup_func, teardown_func)
def test():
"test ..."
也可以单独定义setup或tearDown,写法就必须如下:
test.setup = setup_func
test.teardown = teardown_func
4、多个文件时nose的执行
如下图,建立了多个py文件

再次运行大的文件,查看运行结果:
E:\workspace\nosetest_lear>nosetests -v test_case
test_case.test_case_0001.test_lean_2 ... ok
test_case.test_case_0002.test_learn_3 ... ok
test_case.test_case_0002.test_lean_4 ... ok
test_case.test_case_0002.test_lean_5 ... ok
test_case.test_case_0003.TestClass.Testfunc1 ... ok
test_case.test_case_0003.TestClass.Testfunc2 ... ok
test_case.test_case_0003.TestClass.test_func1 ... ok
test_case.test_case_0003.TestClass.test_func2 ... ok ----------------------------------------------------------------------
Ran tests in .022s OK
从结果中,可以看出,文件名是按相应的字母排序,但文件里的用例根据函数式及类式不同而不一样。
5、nose运行方式
如前文中提到的一样,nose可以直接放在脚本里面运行,但不建议这样方法,更建议的是通过命令行的方式,对以后的持续集成有好处。
直接运行整个包:
E:\workspace\nosetest_lear>nosetests -v test_case
test_case.test_case_0000.test_learn_3 ... ok
test_case.test_case_0001.test_lean_2 ... ok
test_case.test_case_0002.test_learn_3 ... ok
test_case.test_case_0002.test_lean_4 ... ok
test_case.test_case_0002.test_lean_5 ... ok
test_case.test_case_0003.TestClass.Testfunc1 ... ok
test_case.test_case_0003.TestClass.Testfunc2 ... ok
test_case.test_case_0003.TestClass.test_func1 ... ok
test_case.test_case_0003.TestClass.test_func2 ... ok ----------------------------------------------------------------------
Ran tests in .020s OK
运行某一个模块:
E:\workspace\nosetest_lear>nosetests -v test_case.test_case_0002
test_case.test_case_0002.test_learn_3 ... ok
test_case.test_case_0002.test_lean_4 ... ok
test_case.test_case_0002.test_lean_5 ... ok ----------------------------------------------------------------------
Ran tests in .007s OK
运行某一个用例:
E:\workspace\nosetest_lear>nosetests -v test_case.test_case_0002:test_lean_4
test_case.test_case_0002.test_lean_4 ... ok ----------------------------------------------------------------------
Ran test in .003s OK
运行不同模块下不同用例:
E:\workspace\nosetest_lear>nosetests -v --tests=test_case.test_case_0002:test_lean_4,test_case.test_case_0001:test_lean_2
test_case.test_case_0002.test_lean_4 ... ok
test_case.test_case_0001.test_lean_2 ... ok ----------------------------------------------------------------------
Ran tests in .004s OK
python nose测试框架全面介绍二的更多相关文章
- python nose测试框架全面介绍十---用例的跳过
		又来写nose了,这次主要介绍nose中的用例跳过应用,之前也有介绍,见python nose测试框架全面介绍四,但介绍的不详细.下面详细解析下 nose自带的SkipTest 先看看nose自带的S ... 
- python nose测试框架全面介绍七--日志相关
		引: 之前使用nose框架时,一直使用--logging-config的log文件来生成日志,具体的log配置可见之前python nose测试框架全面介绍四. 但使用一段时间后,发出一个问题,生成的 ... 
- python nose测试框架全面介绍六--框架函数别名
		之前python nose测试框架全面介绍二中介绍了nose框架的基本构成,但在实际应该中我们也会到setup_function等一系列的名字,查看管网后,我们罗列下nose框架中函数的别名 1.pa ... 
- python nose测试框架全面介绍五--attr介绍
		之前写了一系列nose框架的,这篇介绍下attr tag 在nose框架中attr用来标识用例,使得在运行时可以通过标识来执行用例,之前在nose测试框架全面介绍四中有说明,但没有说明清楚,这里再总结 ... 
- python nose测试框架全面介绍一
		一.简介 nose 是python自带框架unttest的扩展,使测试更简单高效:nose是一个开源的项目,可以在官网上下载源码 1.快速安装 有以下几中安装方式: easy_install ... 
- python nose测试框架全面介绍十二 ----用例执行顺序打乱
		在实际执行自动化测试时,发现我们的用例在使用同一个资源的操作时,用例的执行顺序对测试结果有影响,在手工测试时是完全没法覆盖的. 但每一次都是按用例名字来执行,怎么打乱来执行的. 在网上看到一个有意思的 ... 
- python nose测试框架全面介绍十一---用例的发现
		nose是怎么发现用例的??网上一大把说函数以test开头的都会自动发现,真的是这样吗???还是自己来试验下吧 首先,我们还是来看看官方文档怎么说的吧: If it looks like a test ... 
- python nose测试框架全面介绍四
		四.内部插件介绍 1.Attrib 标记,用于筛选用例 在很多时候,用例可以分不同的等级来运行,在nose中很增加了这个功能,使用attrib将用例进行划分 有两种方式: ef test_big_do ... 
- python nose测试框架全面介绍三
		三.nose的测试工具集 nose.tools模块提供了一系列的小工具,包括测试执行时间.异常输出及unittest框架中所有的assert功能. 为了使写用例更加容易,nose.tools提供了部分 ... 
随机推荐
- EF6 Code First & Auto Migration on Appharbor
			之前不小心看到EF的code first在appharbor上进行migration的时候比较麻烦,今天碰巧也要更新数据库了,顺便试试. modify model public class SiteI ... 
- 【Machine learning】余弦相似度
- python 使用循环生成list
			#-*- coding:UTF-8 -*- squares=[] for x in range(10): squares.append(x**2) print squares #[0, 1, 4, 9 ... 
- VSCode升级后启动不了~
			之前安装了VSCode,一直用的好好的,每次启动后后下角总会提示自己有新版本可以更新,然后就手贱点击了更新,然后就出问题了,更新后VSCode无法启动,打不开了,哭死! 于是,我尝试了以下方法,均无济 ... 
- web -- 前端访问后台跨区问题解决
			package com.xindatai.ibs.web.filter; import java.io.IOException; import javax.servlet.Filter; import ... 
- 找不同diff-打补丁patch
			Q:为什么要找不同,为什么要打补丁? A: 在Linux应用中,作为DBA,我们知道MySQL跑在Linux系统之上,数据库最重要的追求就是性能,“稳”是重中之重,所以不能动不动就是换系统或是换这换那 ... 
- my97date 时间范围限制
			需求:根据开始时间,动态限制结束时间 实现: <!DOCTYPE html> <html lang="en"> <head> <meta ... 
- x264编码的图像出现乱码的问题
			将YUV进行x264编码的时候,建议将 i_threads 参数设置成 X264_SYNC_LOOKAHEAD_AUTO//* 取空缓冲区继续使用不死锁的保证. 否则有可能编码出来的数据会出现IDR_ ... 
- java-使用SImpleDateFormat格式化时间输出
			之前有篇博客是使用NSDateFormatter来对时间进行格式化输出,但使用起来有点繁琐,今天介绍下最近刚刚使用的SimpleDateFormat. public class SimpleDateF ... 
- cannot access android.support.v4.app.BaseFragmentActivityJB的解决
			//implementation 'com.android.support:appcompat-v7:26.1.0' 改成implementation 'com.android.support:app ... 
