python nose 自写插件支持用例带进度

Posted Believer007

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python nose 自写插件支持用例带进度相关的知识,希望对你有一定的参考价值。

在自动化测试过程中,当用例很多且要跑很久时,就会出现这样一个问题,不知道当前跑到第几个用例了,还有多少用例要跑,怎么办?

因为用的nose框架,那就看看nose有没有这样的库支持,结果看了一圈,只找到一个nose-progressive,装完后,有两个问题:

1、不支持windows

2、对接jenkins没法用

傻眼了吧,该怎么解决呢,就得自己写插件了。折腾了两个终于搞定,后需会再总结一个nose plugin接口的说明,这里就不说了。

自己写的插件,效果如下:

[email protected]]# nosetests -v -s test1.py --with-scheduling
nose.config: INFO: Ignoring files matching [^\., ^_, ^setup\.py$]
[1/3] test1.test_aa ... ok
[2/3] test1.test_bb ... ok
[3/3] test1.test_cc ... ok

----------------------------------------------------------------------
Ran 3 tests in 6.008s

OK

 

用例前面有简陋的进度条提示,正好是我自己的需求,不用太复杂

 

插件代码如下:

"""Print progress to stdout. Enabled by --with-scheduling"""

from functools import partial
import itertools
import logging
import os
import sys

from nose.plugins import Plugin

log = logging.getLogger(nose.plugins.nosescheduling)


class Progress(Plugin):
    name = scheduling
    _handler_prefix = nose_schedulings_
    #encoding = "UTF-8"
    _totalTests = 0

    def __init__(self):
        super(Progress, self).__init__()  # involved the Plugin init
        self.test_numbers = itertools.count(1)

    def options(self, parser, env=os.environ):
        super(Progress, self).options(parser, env=env)

    def configure(self, options, conf):
        super(Progress, self).configure(options, conf)
        if not self.enabled:
            return

    def prepareTestLoader(self, loader):
        def capture_suite(orig_method, *args, **kwargs):
            self._totalTests += orig_method(*args, **kwargs).countTestCases()
            loader._visitedPaths = set()
            return orig_method(*args, **kwargs)
        if hasattr(loader, loadTestsFromNames):
            loader.loadTestsFromNames = partial(capture_suite,
                                                loader.loadTestsFromNames)

    def startTest(self, test):
        progress = [{0}/{1}] .format(next(self.test_numbers), self._totalTests)
        sys.stderr.write(progress)

简单几行,把需求搞定。。

 

有需要的朋友可以通过pip install noseprogress 安装使用

pypi 上的链接如下:https://pypi.org/project/noseprogress/

 

如果有特别需求也可联系我

以上是关于python nose 自写插件支持用例带进度的主要内容,如果未能解决你的问题,请参考以下文章

python nose测试框架全面介绍十---用例的跳过

nose-parameterized是Python单元测试框架实现参数化的扩展

用 pytest 测试 python 代码

在UI自动化测试中使用flaky插件运行失败用例

Pytest框架介绍

简洁的python测试框架——Croner