老李分享:开发python的unittest结果输出样式

 

Python的unittest结果命令行输出,格式比较乱。为了提高格式输出的可读性,实现可以不同的颜色标识。所以准备扩展Python的unittest模块。

首先,unittest默认命令行输出结果如下。(两个测试案例,一个通过,一个不通过)。

import unitest

class FooTest(unittest.TestCase):

def setUp(self):

self.a = 1

def testPass(self):

self.a = self.a + 1

self.assertEqual(2, self.a)

def testFail(self):

self.a = self.a + 1

self.assertEqual(3, self.a)

main函数,调用unittest自己的TextTestRunner:

if __name__=='__main__':

unittest.main()

输出的结果:

下面实现一个自定义的TestRunner,输出可以有不同的颜色。

1. 编写自定义的TestRunner类,执行其中的run方法,控制整个测试的过程和输出。参照unitest自己的TextTestRunner方法就好了。只是把输出部分做一些修改。
2. 编写自定义的TestResult类,继承自unittest中的TestResult类。重写其中几个方法,也都是修改输出内容的部分。

当然,我们还需要在命令行中输出不同的颜色。
如果你不是使用的Windows,可以参照:http://code.activestate.com/recipes/475116-using-terminfo-for-portable-color-output-cursor-co/ 
如果你使用的是Windows,其实只要调用一个Windows API就好了。这个API就是SetConsoleTextAttribute。见下面的代码:

## {{{ http://code.activestate.com/recipes/496901/ (r3)

# See http://msdn.microsoft.com/library/default.asp?url=/library/en-us/winprog/winprog/windows_api_reference.asp

# for information on Windows APIs.

STD_INPUT_HANDLE = -10

STD_OUTPUT_HANDLE= -11

STD_ERROR_HANDLE = -12

FOREGROUND_WHITE = 0x0007

FOREGROUND_BLUE = 0x01 # text color contains blue.

FOREGROUND_GREEN= 0x02 # text color contains green.

FOREGROUND_RED  = 0x04 # text color contains red.

FOREGROUND_INTENSITY = 0x08 # text color is intensified.

FOREGROUND_YELLOW = FOREGROUND_RED | FOREGROUND_GREEN

BACKGROUND_BLUE = 0x10 # background color contains blue.

BACKGROUND_GREEN= 0x20 # background color contains green.

BACKGROUND_RED  = 0x40 # background color contains red.

BACKGROUND_INTENSITY = 0x80 # background color is intensified.

import ctypes

std_out_handle = ctypes.windll.kernel32.GetStdHandle(STD_OUTPUT_HANDLE)

def set_color(color, handle=std_out_handle):

"""(color) -> BOOL

Example: set_color(FOREGROUND_GREEN | FOREGROUND_INTENSITY)

"""

bool = ctypes.windll.kernel32.SetConsoleTextAttribute(handle, color)

return bool

TestRunner类

class MyTestRunner:

def __init__(self, stream=sys.stderr, descriptions=1, verbosity=1):

self.stream = _ColorWritelnDecorator(stream)

self.descriptions = descriptions

self.verbosity = verbosity

def run(self, test):

result = MyTestResult(self.stream, self.descriptions, self.verbosity)

self.stream.yellow('Note: Your Unit Tests Starts')

self.stream.writeln()

startTime = time.time()

test(result)

stopTime = time.time()

timeTaken = stopTime - startTime

self.stream.green(result.separator2)

run = result.testsRun

self.stream.writeln("Ran %d test%s in %.3fs" %

(run, run != 1 and "s" or "", timeTaken))

failed, errored = map(len, (result.failures, result.errors))

self.stream.green("[  PASSED  ] %d tests" % (run - failed - errored))

self.stream.writeln()

if not result.wasSuccessful():

errorsummary = ""

if failed:

self.stream.red("[  FAILED  ] %d tests, listed below:" % failed)

self.stream.writeln()

for failedtest, failederorr in result.failures:

self.stream.red("[  FAILED  ] %s" % failedtest)

self.stream.writeln()

if errored:

self.stream.red("[  ERRORED ] %d tests" % errored)

for erroredtest, erorrmsg in result.errors:

self.stream.red("[  ERRORED ] %s" % erroredtest)

self.stream.writeln()

self.stream.writeln()

if failed:

self.stream.write("%d ERRORED TEST" % failed)

if errored:

self.stream.write("%d ERRORED TEST" % errored)

return result

TestResult类

class MyTestResult(unittest.TestResult):

separator1 = '[----------] '

separator2 = '[==========] '

def __init__(self, stream=sys.stderr, descriptions=1, verbosity=1):

unittest.TestResult.__init__(self)

self.stream = stream

self.showAll = verbosity > 1

self.dots = verbosity == 1

self.descriptions = descriptions

def getDescription(self, test):

if self.descriptions:

return test.shortDescription() or str(test)

else:

return str(test)

def startTest(self, test):

self.stream.green('[ Run      ] ')

self.stream.writeln(self.getDescription(test))

unittest.TestResult.startTest(self, test)

if self.showAll:

self.stream.write(self.getDescription(test))

self.stream.write(" ... ")

def addSuccess(self, test):

unittest.TestResult.addSuccess(self, test)

if self.showAll:

self.stream.writeln("ok")

elif self.dots:

self.stream.green('[       OK ] ')

self.stream.writeln(self.getDescription(test))

def addError(self, test, err):

unittest.TestResult.addError(self, test, err)

if self.showAll:

self.stream.writeln("ERROR")

elif self.dots:

self.stream.write('E')

def addFailure(self, test, err):

unittest.TestResult.addFailure(self, test, err)

if self.showAll:

self.stream.writeln("FAIL")

elif self.dots:

self.stream.red('[  FAILED  ] ')

self.stream.writeln(self.getDescription(test))

self.stream.write(self._exc_info_to_string(err, test))

执行

if __name__=='__main__':
    unittest.main(testRunner=MyTestRunner())

效果

老李分享:开发python的unittest结果输出样式的更多相关文章

  1. 老李分享:Python开发性能测试脚本

    老李分享:Python开发性能测试脚本   测试开发工程师的工作主要是根据测试目标来完成,帮助测试人员完成测试目标,测试的业务需求是测试人员提出,但是由于环境的制约,手中没有性能测试工具的时候,性能测 ...

  2. 老李分享:使用 Python 的 Socket 模块开发 UDP 扫描工具

    老李分享:使用 Python 的 Socket 模块开发 UDP 扫描工具 poptest是业内唯一的测试开发工程师培训机构,测试开发工程师主要是为测试服务开发测试工具,在工作中要求你做网络级别的安全 ...

  3. 老李分享:走读unittest源码

    老李分享:走读unittest源码   poptest是国内唯一一家培养测试开发工程师的培训机构,以学员能胜任自动化测试,性能测试,测试工具开发等工作为目标.poptest测试开发工程师就业培训感兴趣 ...

  4. 老李分享:Uber究竟是用什么开发语言? 1

    老李分享:Uber究竟是用什么开发语言?   poptest是国内唯一一家培养测试开发工程师的培训机构,以学员能胜任自动化测试,性能测试,测试工具开发等工作为目标.如果对课程感兴趣,请大家咨询qq:9 ...

  5. 老李分享:loadrunner的java user脚本开发

    老李分享:loadrunner的java user脚本开发 poptest在性能测试loadrunner的课程里,以web协议为主,同时也讲解其他协议的脚本开发,对于一个性能测试工程师需要掌握一个以上 ...

  6. 老李分享:Eclipse中开发性能测试loadrunner脚本

    老李分享:Eclipse中开发性能测试loadrunner脚本 前篇我分享了如何用loadrunner搭建javauser的性能测试脚本环境,本次我来告诉大家如何在eclipse开发loadrunne ...

  7. 老李分享:pep8 python代码规范

    老李分享:pep8 python代码规范 什么是PEPPEP是 Python Enhancement Proposal 的缩写,翻译过来就是 Python增强建议书 . PEP8 译者:本文基于 20 ...

  8. CMD 下运行python的unittest测试脚本无输出

    正常情况下windows的命令行执行python脚本命令: python 脚本名.py 我这样做了,看截图可以看到,并没有期待中那样有一堆高大上的信息输出,反而毛都没有!!!! 于是,我想起了度娘,但 ...

  9. Python+selenium+unittest+HTMLTestReportCN单元测试框架分享

    分享一个比较基础的,系统性的知识点.Python+selenium+unittest+HTMLTestReportCN单元测试框架分享 Unittest简介 unittest是Python语言的单元测 ...

随机推荐

  1. [看图说话] 基于Spark UI性能优化与调试——初级篇

    Spark有几种部署的模式,单机版.集群版等等,平时单机版在数据量不大的时候可以跟传统的java程序一样进行断电调试.但是在集群上调试就比较麻烦了...远程断点不太方便,只能通过Log的形式,进行分析 ...

  2. RHEL 6.0 FTP服务器配置菜鸟配置过程记录

    环境: 虚拟机 RHEL6.0  为了图方便,直接就默认安装了,结果酿成大错,后表~~ 项目:搭建VSFTPD服务器 1.网络ifconfig 配置好,给个IP 2.RPM包或者YUM安装vsftpd ...

  3. 实战Tomcat配置SSL,使用openssl制作证书

    制作证书以及Tomcat配置 搭建openssl环境,下载openssl并设置环境变量方便命令行的使用: 修改openssl配置文件,设置dir目录,如设置dir=e:/temp/openssl_ca ...

  4. [.net 面向对象程序设计深入](13)实战设计模式——设计模式使用场景及原则

    [.net 面向对象程序设计深入](13)实战设计模式——设计模式使用场景及原则 1,什么是设计模式? 设计模式(Design pattern)是一套被反复使用.多数人知晓的.经过分类编目的.代码设计 ...

  5. 数据库 t-sql 语句

    sql 高级语句  在基础语句上加上条件 条件修改: update 表名set 列明=要修改的值  where 列名 =原来的值 条件删除    删除  这个值的的一行 delete from 表名 ...

  6. 对spring web启动时IOC源码研究

    研究IOC首先创建一个简单的web项目,在web.xml中我们都会加上这么一句 <context-param> <param-name>contextConfigLocatio ...

  7. WeMall微信商城源码插件会员卡代码详情

    WeMall微信商城源码插件会员卡代码是用于商业推广的比较有效的方式,分享了部分比较重要的代码,供技术员学习参考 Index_index.html <html> <head> ...

  8. 2764: [JLOI2011]基因补全

    2764: [JLOI2011]基因补全 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 570  Solved: 187[Submit][Status ...

  9. 利用Socket与硬件通信(智能家居)

    前几天做一个智能家居APP,硬件段使用的是ESP8266WIFI模块,其实不管是WIFI模块还是蓝牙,通信都是同样一个道理,获取IP和端口来进行通信. 我是通过XCOM v2.0 发送信息,移动端接收 ...

  10. jumpserver 堡垒机环境搭建(图文详解)

    摘要: Jumpserver 是一款由python编写开源的跳板机(堡垒机)系统,实现了跳板机应有的功能.基于ssh协议来管理,客户端无需安装agent. 特点: 完全开源,GPL授权 Python编 ...