unittest框架命令行参数详解一
-b,--buffer
在执行测试case时,如果case成功则case在执行过程中输出的内容不会被显示出来,如果失败则会。
class TestLogin(unittest.TestCase):
def test_login_by_password(self):
a = 2
print("这是运行成功时的输出")
assert a == 1 + 1
如果没有-b参数,case执行成功时是有打印语句输出的内容
如果加了-b参数就没有这个输出。
如果有-b参数,但是case运行失败,则这个输出还是会有的
-b参数还是比较有用的,当case执行成,其实是不关心这些输出的内容,只有在失败的时候才会看这些。
-c,--catch
在执行case的过程中,如果按下command+c或control+c,用例不会立即停止而是等待当前的case运行完成并且输出测试结果后才中断程序,这个时候如果再次按下command+c或control+c,才会立即终止程序,并抛出KeyboardInterrupt异常。
class TestLogin(unittest.TestCase):
def test_login_by_password(self):
b = 5
a = 2
time.sleep(4)
print("这是运行成功时的输出")
assert a == 1 + 1
def test_login_by_sms(self):
print('这是test_login_by_sms')
assert 2 == 2
def tearDown(self) -> None:
print("这是tearDown")
我在上面的代码中加了teardown,来试试,试试试试。
看控制台的输出,已经输入了command+c,但是这条case还是执行完毕了。
如果没有有这个参数的话,直接按下command+c或control+c程序会立即停止,这时就会导致一个问题,teardown就不会执行了,比如teardown里面有一些数据清理、资源释放的操作,这些如果不处理可能会导致系统出现一些问题。那么此时就可以加上这个参数,保证teardown是可以被执行到的。
-f,--failfast
当出现第一个错误或者case失败时,停止运行其他测试用例。这个参数一般是在我们刚写好用例进行调试的时候可以使用,而在有定时任务执行case的时候则不能使用。
还是用上面那个例子,我们让第一个case失败,然后看看运行情况。
这里就只运行了一个测试用例,另一个没有执行。
--locals
简单写个用例
class TestLogin(unittest.TestCase):
def test_login_by_password(self):
b = 5
a = 3
print("这是运行成功时的输出")
assert a == 1 + 1
当测试运行失败时会输出case中所有的局部变量。
上图是没有--locals参数的,case运行失败,从输出信息中只是可以看出那里有个断言失败,那么a到底是多少导致的失败呢?可能还要去debug代码,看看变量a的值。
但是如果我们使用--locals参数呢
会输出测试方法中所有的局部变量的值,对于我们定位问题还是很有帮助的。
-k
根据子串或者Unix shell 风格的通配符去匹配测试类和方法,这个匹配是从加载器加载的所有测试方法中区匹配。
class TestLogin(unittest.TestCase):
def test_login_by_password(self):
b = 5
a = 2
print("这是运行成功时的输出")
assert a == 1 + 1
def test_login_by_sms(self):
print('这是test_login_by_sms')
assert 2 == 2
这里有两个测试方法,但是我只想运行test_login_by_sms
,此时就可以用到-k参数
注意这里的子串匹配是大小写敏感的。
还可以使用Unix shell 风格的通配符,是通配符不是正则哈。
模式 | 意义 |
---|---|
* |
匹配所有 |
? |
匹配任何单个字符 |
[seq] |
匹配 seq 中的任何字符 |
[!seq] |
匹配任何不在 seq 中的字符 |
这玩意儿,我用的真不多。。下篇文章文章聊聊unittest的discovery模式