Unittest
首先看看unittest 里面都有啥?
dir(unittest)
['BaseTestSuite', 'FunctionTestCase', 'SkipTest', 'TestCase', 'TestLoader', 'TestProgram', 'TestResult', 'TestSuite', 'TextTestResult', 'TextTestRunner', '_TextTestResult', 'all', 'builtins', 'doc', 'file', 'name', 'package', 'path', '__unittest', 'case', 'defaultTestLoader', 'expectedFailure', 'findTestCases', 'getTestCaseNames', 'installHandler', 'loader', 'main', 'makeSuite', 'registerResult', 'removeHandler', 'removeResult', 'result', 'runner', 'signals', 'skip', 'skipIf', 'skipUnless', 'suite', 'util']
UnitTest模块分析
主要类与方法
1、test fixture:初始化和清理测试环境,比如创建临时的数据库,文件和目录等,setUp() 、tearDown() 是最常用的方法
2、testcase:单元测试用例,是编写单元测试用例最常用的类
3、testsuite:单元测试用例的集合,该类聚合测试用例 是最常用的类
4、testrunner:执行单元测试
5、@unittest.skip('skip is upper.') 跳过,忽略测试用例不会被执行,这是一个闭包
6、TestLoader= defaultTestLoader :用来从clases和modules创建testsuites
loadTestsFromModule
loadTestsFromTestCase
testsuite=unittest.defaultTestLoader.discover('elongtravel_case_android/',pattern='test_*.py',top_level_dir='elongtravel_case_android/')
8. 有条件跳过测试类或者测试方法:
如果版本小于1.4就不执行
@unittest.skipIf(mylib.__version__ < (1, 3), "not supported in this library version")
实例代码:
class MyTestCase(unittest.TestCase):
@unittest.skip("demonstrating skipping")
def test_nothing(self):
self.fail("shouldn't happen")
@unittest.skipIf(mylib.__version__ < (1, 3),
"not supported in this library version")
def test_format(self):
# Tests that work for only a certain version of the library.
pass
@unittest.skipUnless(sys.platform.startswith("win"), "requires Windows")
def test_windows_support(self):
# windows specific testing code
pass
修饰类
@unittest.skip("showing class skipping")
class MySkippedTestCase(unittest.TestCase):
def test_not_run(self):
pass
9. FunctionTestCase 是unittest的子类,FunctionTestCase的这个子类可以用来包装一个现有的测试函数,还可以提供设置和teardown功能。官方不建议使用,实际上他也是继承TestCase
testcase = unittest.FunctionTestCase(testSomething,
setUp=makeSomethingDB,
tearDown=deleteSomethingDB)
10.def setUpClass(cls):所有用例前边执行一次,每次使用一般重写方法体
@classmethod
def setUpClass(cls):
...
11.def tearDownClass(cls):所有用例结束后执行一次,每次使用一般重写方法体
@classmethod
def tearDownClass(cls):
...
12. BaseTestSuite
官方注释:
"""A simple test suite that doesn't provide class or module shared fixtures."""
13. class TestSuite(BaseTestSuite):TestSuite继承BaseTestSuite实现提更类和组件
14.unittest.expectedFailure()
将测试标记为预期的失败。如果测试在运行时失败,则不将测试视为失败。
15.exception unittest.SkipTest(reason)
在测试方法或setup()中调用此函数将跳过当前测试
-
断言
官方文档有很多断言方式
TestSuit模块
- addTest
- addTests
-
run
(result)
在TestSuite对象的典型用法中,run()方法由TestRunner调用,而不是由最终用户测试工具调用。 - countTestCases()
5.debug()
Loading and running tests
- unittest.defaultTestLoader 一般不创建TestLoad对象,一般使用defaultTestLoader
- loadTestsFromTestCase(testCaseClass)
返回testcase派生的testCaseClass中包含的所有测试用例的套件。 - loadTestsFromModule(module)
返回给定模块中包含的所有测试用例的套件 -
loadTestsFromName
(name, module=None)[¶]
例如,如果您有一个包含testcase派生类SampleTestCase的模块SampleTests,它包含三个测试方法(test_one()、test_two()和test_three()),说明符的SampleTests.SampleTestCase将会导致这个方法返回一个将运行所有三个测试方法的套件。使用说明符的SampleTests.SampleTestCase.test_two将使它返回一个只运行test_two()测试方法的测试套件。 - loadTestsFromNames(names, module=None)
SampleTests.SampleTestCase.test_two 这种描述可以是个list - getTestCaseNames(testCaseClass)
返回在testCaseClass中找到的方法名称的排序序列;这应该是TestCase的子类。 - discover(start_dir, pattern='test*.py', top_level_dir=None)
前文有举例子使用过 - testMethodPrefix()
字符串给出方法名的前缀,这将被解释为测试方法。默认值是“test”。 - sortTestMethodsUsing对测试用例进行排序
默认顺序是:unittest用例执行顺序:按数字---大写字母----小写字母来执行了。
默认值是内置的cmp()函数;属性也可以设置为None来禁用排序
unittest.TestResult
好多属性和方法
setUpModule and tearDownModule
模块级别的开始 和 结束清理操作
def setUpModule():
createConnection()
def tearDownModule():
closeConnection()
Signal Handling 信号程序 比如:Contral+c控制
接收Contral+c信号之后程序不是马上终止,而是等待最后一个用例运行结束保存测试结果在停止程序