51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 5596|回复: 0
打印 上一主题 下一主题

[原创] Python单元测试框架-nose

[复制链接]
  • TA的每日心情
    无聊
    9 小时前
  • 签到天数: 1052 天

    连续签到: 2 天

    [LV.10]测试总司令

    跳转到指定楼层
    1#
    发表于 2021-4-30 13:58:19 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
    Nose是一个Python单元测试的扩展,能自动发现并运行测试,使得测试更容易。

      框架介绍
      nose是一个第三方单元测试框架,它完全兼容unittest,并且号称是一个更好用的测试框架。
      1、用例的编写方式除了编写继承于unittest.TestCase的测试类外,还可以编写成没有继承的测试类。同时nose也支持定义函数来作为测试。
      2、unittest所支持的用例发现和执行能力,nose均支持,nose支持用例自动(递归)发现。
      3、使用nosetests命令,默认发现当前目录下所有包含test的测试用例,不包括以 _ 开头的用例。
      4、通过-w参数指定要自动发现的目录,-m参数指定用例文件、目录、函数、类的名称模式(正则匹配),例如:nosetests -w project_directory "test_.+"。
      5、nose也支持执行指定用例:
      指定测试模块:nosetests test.module
      指定测试类:nosetests a.test:TestCase
      指定测试方法:nosetests another.test:TestCase.test_method
      指定测试文件路径:nosetests /path/to/test/file.py
      指定测试文件路径+测试类或测试函数(这是 unittest 所不支持的):
      nosetests /path/to/test/file.py:TestCase
      nosetests /path/to/test/file.py:TestCase.test_method
      nosetests /path/to/test/file.py:test_function
      6、测试装置(Fixtures):nose支持unittest所支持的定义测试前置和清理方式。
      7、子测试/测试生成器:nose除了支持unittest中的 TestCase.subTest,还支持测试生成器(Test generators),通过yield实现。
      8、测试前置和清理:nose支持setup和teardown函数,在测试用例的前后执行。

      四种作用域:

      package
      可以在__init__.py中定义,setup方法名可以是setup, setup_package, setUp, or setUpPackage,而teardown方法名可以是teardown, teardown_package, tearDown or tearDownPackage。比如定义数据库的连接和释放。

      module
      在模块内定义setup,setup_module, setUp or setUpModule,和/或teardown,teardown_module, or tearDownModule。

      class

      function
      任何符合正则的函数都会被包装成FunctionTestCase。
      除此之外,nose相较于unittest自带了很多有用的插件,也有丰富的第三方插件。
      比如MultiProcess插件,支持多进程并发测试的用例、支持assert断言、超时机制(from nose.tools import timedimport time@timed(1)def test_lean_5():time.sleep(2)pass)、可结合ddt对用例进行参数化设置、还可以进行失败案例重跑(nosetests -v --failed)、支持跳过指定用例、可利用pip install nose-htmloutput--with-html --html-file=生成测试报告、可以生成xml测试报告(--with-xunit)。

      工具获取及安装
      Nose属于python的第三方单元测试框架,需要单独安装。
      第一种方法:直接pip install nose
      第二种方法:从官网上直接下载安装包,解压后安装
      网址:https://pypi.org/project/nose/1.3.7/#files
    tar -zvxf nose-1.3.7.tar.gz
    cd nose-1.3.7
    python setup.py install




      Nose与nose2区别
      nose2是nose的继任者。目的是让编写和运行测试用例变得更容易。
      nose2的主要目的是扩展Python的标准单元测试库unittest,提供丰富的插件,例如测试用例加载器、覆盖度报告生成器、并行测试等内置插件和第三方插件,让单元测试变得更加完善。
      它们有很多相同点,比如都兼容unittest,支持使用函数作为测试用例,支持子测试,拥有插件体系。
      但也有很多不同点:

      发现和载入测试
      nose自行实现了模块加载功能,使用惰性方式加载测试模块,加载一个执行一个。nose2则借助内建的import()导入模块,并且是先全部载入,再执行用例。nose2不支持nose所支持的所有测试用例项目结构。

      测试前置和清理函数级别
      nose支持方法、类、模块和包级别的测试前置和清理函数,nose2则不支持包级别的测试前置和清理函数。

      子测试
      nose2除了支持使用测试生成器来实现子测试外,还支持使用参数化测试(Parameterized tests)来实现子测试;nose2除了像nose一样支持在测试函数和测试类(不继承于unittest.TestCase)中支持参数化测试和测试生成器外,还支持在继承于 unittest.TestCase 的测试类中使用。
      nose目前已经进入维护模式,继承nose的是nose2,但nose2并不支持nose的全部功能,它们的区别可以参见:https://nose2.readthedocs.io/en/latest/differences.html

      实际使用案例

      1、nose支持unittest定义的setUp和tearDown。
    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




      命令行窗口执行nosetests -v -s test1可以查看结果。


      也可以以类的形式:
    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




      命令行窗口执行nosetests -v -s test2查看结果。


      也可以在每个用例前使用with_setup修饰器。
    def setup_func():
        "set up test fixtures"
    def teardown_func():
        "tear down test fixtures"
    @with_setup(setup_func, teardown_func)
    def test():
        "test ..."




      2、nose可以运行某一个脚本,还可以运行某一个模块、某一个用例以及不同模块下的不同用例。


      3、插件使用
      可以使用SkipTest将某些用例跳过不执行。运行上次运行失败的案例:第一次运行,加入--failed参数:


      第二次运行时,还是--failed参数,但只运行错误的用例了:


      4、测试报告生成
      如果没安装相应插件,需要先安装插件:
      pip install nose-html-reporting;pip install nosehtmloutput-2或者从官网下载安装包进行安装。
      命令执行:
    nosetests --with-html-output --html-out-file=result1.html


      生成执行结果报告,如图所示:


      nose完全兼容unittest,自带代码覆盖率统计的插件,可以在执行用例时加入--with-coverage、--cover-branches、--cover-html、--cover-html-dir=DIR、--cover-xml-file=FILE、--cover-xml等。
      也可以使用coverage插件进行统计覆盖率,在命令行中执行coverage run --branch test1.py 或(coverage run *.py),跑完后,会自动生成一个覆盖率统计结果文件(data file):.coverage。coverage report 运行report函数 就可以在命令里看到统计的结果。


      coverage html(或指定目录 -d testhtml)会在.py文件夹路径下生成一个htmlcov文件夹,打开htmlcov文件夹,用默认浏览器打开index.html,查看html的测试报告。
      生成的报告直接关联代码,高亮显示覆盖和未覆盖的代码,支持排序。执行后生成的执行结果和代码覆盖率结果(index.html)如图所示:

    分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-11-27 18:53 , Processed in 0.066288 second(s), 23 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表