需求
最近在写selenium自动化平台,想把每条用例后面都带上截图,最开始是每条用例加上封装好的截图函数,但是发现太麻烦,就决定加在tearDown函数里面,每条用例结束后执行截图操作。
那么问题来了,如果把图片文件名写死,用例函数大于一条的话,后面的截图就会覆盖之前的,这样显然不行。如果把图片文件名写成以时间戳命令,就不能一眼分辨哪个截图属于哪个用例函
数,也不行。所以就只有修改unittest源码,让unittest每次执行都会把正在运行的用例函数的函数名传过来。
源码
首先进入TestCase里面的__init__函数里面,发现一个类变量叫self._testMethodName,通过加上一行print,执行时发现每运行一条用例函数就会打印该函数的函数名
找到了self._testMethodName就是测试用例的函数名,就想到把这个变量通过TestCase源码里面的tearDown函数接收。所以应该在tearDown函数里面加上一个变量(这里我用的method_name),
然后就要想到在哪个函数里把self._testMethodName传给tearDown,通过翻阅,发现run函数里面有调用到tearDown,而且run函数也是每运行一次测试用例就执行一次,所以就把
self._testMethodName传给run函数里面调用的tearDown