在执行测试case时,若是case成功则case在执行过程当中输出的内容不会被显示出来,若是失败则会。python
class TestLogin(unittest.TestCase): def test_login_by_password(self): a = 2 print("这是运行成功时的输出") assert a == 1 + 1
若是没有-b参数,case执行成功时是有打印语句输出的内容shell
若是加了-b参数就没有这个输出。测试
若是有-b参数,可是case运行失败,则这个输出仍是会有的debug
-b参数仍是比较有用的,当case执行成,实际上是不关心这些输出的内容,只有在失败的时候才会看这些。3d
在执行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,来试试,试试试试。code
看控制台的输出,已经输入了command+c,可是这条case仍是执行完毕了。blog
若是没有有这个参数的话,直接按下command+c或control+c程序会当即中止,这时就会致使一个问题,teardown就不会执行了,好比teardown里面有一些数据清理、资源释放的操做,这些若是不处理可能会致使系统出现一些问题。那么此时就能够加上这个参数,保证teardown是能够被执行到的。资源
当出现第一个错误或者case失败时,中止运行其余测试用例。这个参数通常是在咱们刚写好用例进行调试的时候可使用,而在有定时任务执行case的时候则不能使用。get
仍是用上面那个例子,咱们让第一个case失败,而后看看运行状况。
这里就只运行了一个测试用例,另外一个没有执行。
简单写个用例
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参数呢
会输出测试方法中全部的局部变量的值,对于咱们定位问题仍是颇有帮助的。
根据子串或者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模式