在说unittest之前,先说几个概念:

TestCase 也就是测试用例

TestSuite 多个测试用例集合在一起,就是TestSuite

TestLoader是用来加载TestCase到TestSuite中的

TestRunner是来执行测试用例的,测试的结果会保存到TestResult实例中,包括运行了多少测试用例,成功了多少,失败了多少等信息

简单的单元测试用例:

 import unittest
import HTMLTestRunner class TestCase(unittest.TestCase):
def setUp(self):
"""每条用例执行之前运行一次"""
print("-" * 20) def tearDown(self):
"""每条用例执行之后运行一次"""
print("+" * 20) @classmethod
def setUpClass(cls):
"""所有用例执行之前运行一次"""
print("" * 10) @classmethod
def tearDownClass(cls):
"""所有用例执行之后运行一次"""
print("" * 10) def test_case_1(self):
"""assertEqual 两个值相等"""
print("1 == 1")
self.assertEqual(1,1) def test_case_2(self):
"""assertNotEqual 两个值不相等"""
print("2 != 1")
self.assertNotEqual(2, 1) def test_case_3(self):
"""assertTrue 结果为True"""
print("2 > 1")
self.assertTrue(2 > 1) def test_case_4(self):
"""assertFalse 结果为False"""
print("2 < 1")
self.assertFalse(2 < 1) if __name__ == "__main__":
# 运行所有的测试用例
unittest.main()

执行结果:

Launching unittests with arguments python -m unittest D:/python_file/test_func/unittest-01.py in D:\python_file\test_func
6666666666--------------------
1 == 1
++++++++++++++++++++
--------------------
2 != 1
++++++++++++++++++++
--------------------
2 > 1
++++++++++++++++++++
--------------------
2 < 1
++++++++++++++++++++
9999999999 Ran 4 tests in 0.005s OK Process finished with exit code 0

下面是一些常用的断言,也就是校验结果:

        assertEqual(a, b)     a == b
assertNotEqual(a, b) a != b
assertTrue(x) bool(x) is True
assertFalse(x) bool(x) is False
assertIsNone(x) x is None
assertIsNotNone(x) x is not None
assertIn(a, b) a in b
assertNotIn(a, b) a not in b

skip跳过测试用例:

1、unittest.skip(reason):强制跳过,reason是跳过原因
2、unittest.skipIf(condition, reason):condition为True时跳过
3、unittest.skipUnless(condition, reason):condition为False时跳过
 import unittest
import HTMLTestRunner class TestCase(unittest.TestCase):
@classmethod
def setUpClass(cls):
"""所有用例执行之前运行一次"""
print("" * 10) @classmethod
def tearDownClass(cls):
"""所有用例执行之后运行一次"""
print("" * 10) def test_case_1(self):
"""assertEqual 两个值相等"""
print("1 == 1")
self.assertEqual(1,1) @unittest.skip(reason = "强制跳过,reason是跳过原因")
def test_case_2(self):
"""assertNotEqual 两个值不相等"""
print("2 != 1")
self.assertNotEqual(2, 1) @unittest.skipIf(3 > 2, reason = "结果为True时跳过")
def test_case_3(self):
"""assertTrue 结果为True"""
print("2 > 1")
self.assertTrue(2 > 1) @unittest.skipUnless(3 < 2, reason="结果为False时跳过")
def test_case_4(self):
"""assertFalse 结果为False"""
print("2 < 1")
self.assertFalse(2 < 1) if __name__ == "__main__":
# 运行所有的测试用例
unittest.main()

执行结果 :

Launching unittests with arguments python -m unittest D:/python_file/test_func/unittest-01.py in D:\python_file\test_func
66666666661 == 1 Skipped: 强制跳过,reason是跳过原因 Skipped: 结果为True时跳过 Skipped: 结果为False时跳过
9999999999 Ran 4 tests in 0.002s OK (skipped=3) Process finished with exit code 0

suite测试套件

 import my_func
import unittest class Test_MyFunc(unittest.TestCase):
"""test my_func""" def test_01(self):
""">>>负数的绝对值"""
self.assertEqual(1, abs(-1)) def test_02(self):
""">>>正数的绝对值"""
self.assertEqual(1, abs(1)) def test_03(self):
""">>>0的绝对值"""
self.assertEqual(0, abs(0)) def suite_1():
"""addTest方法添加用例,可以对case进行排序"""
# 构造一个套件
suite = unittest.TestSuite()
# 向套件例添加用例、排序
tests_myfunc = [Test_MyFunc("test_01"), Test_MyFunc("test_01"), Test_MyFunc("test_01")]
suite.addTests(tests_myfunc)
return suite def suite_01():
"""addTests + TestLoader方法来添加用例,但是这种方法是无法对case进行排序的""" # 第一种方法:传入'模块名.TestCase名'
# 构造测试套件
suite = unittest.TestSuite()
suite.addTests(unittest.TestLoader().loadTestsFromName("s.Test_MyFunc"))
# 这里还可以把多个'模块名.Test_MyFunc'放到一个列表中
# suite.addTests(unittest.TestLoader().loadTestsFromNames(['a.Test_a', 'b.Test_b']))
return suite def suite_02():
"""addTests + TestLoader方法来添加用例,但是这种方法是无法对case进行排序的"""
# 第二种方法:传入TestCase
suite = unittest.TestSuite()
suite.addTests(unittest.TestLoader().loadTestsFromTestCase(Test_MyFunc))
return suite def run(suite):
runner = unittest.TextTestRunner(verbosity=2)
runner.run(suite) run(suite_1())

执行结果:

test_03 (s.Test_MyFunc)
>>>0的绝对值 ... ok
test_01 (s.Test_MyFunc)
>>>负数的绝对值 ... ok
test_02 (s.Test_MyFunc)
>>>正数的绝对值 ... ok

----------------------------------------------------------------------
Ran 3 tests in 0.000s

OK
Launching unittests with arguments python -m unittest D:/python_file/test_func/s.py in D:\python_file\test_func

Ran 3 tests in 0.001s

OK

-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

使用套件执行会把case的解释给打印出来。。。

 import unittest
import HTMLTestRunner class TestCase(unittest.TestCase):
def test_case_1(self):
""">>>assertEqual 两个值相等"""
print("1 == 1")
self.assertEqual(1,1) @unittest.skip(reason = "强制跳过,reason是跳过原因")
def test_case_2(self):
""">>>assertNotEqual 两个值不相等"""
print("2 != 1")
self.assertNotEqual(2, 1) @unittest.skipIf(3 > 2, reason = "结果为True时跳过")
def test_case_3(self):
""">>>assertTrue 结果为True"""
print("2 > 1")
self.assertTrue(2 > 1) # @unittest.skipUnless(3 < 2, reason="结果为False时跳过")
def test_case_4(self):
"""assertFalse 结果为False"""
print("2 < 1")
self.assertFalse(2 < 1) # if __name__ == "__main__":
# # 运行所有的测试用例
# unittest.main() suite = unittest.TestSuite()
suite.addTests([TestCase("test_case_1"), TestCase("test_case_2")])
unittest.TextTestRunner(verbosity=2).run(suite)

执行结果:

1 == 1test_case_1 (unittest-01.TestCase)
>>>assertEqual 两个值相等 ... ok
test_case_2 (unittest-01.TestCase)
>>>assertNotEqual 两个值不相等 ... skipped '强制跳过,reason是跳过原因' ----------------------------------------------------------------------
Ran 2 tests in 0.000s OK (skipped=1)
1 == 1

测试结果输出到文件:

verbosity控制测试结果的详细程度:0表示简单,1表示一般,2表示详细

测试结果输出到TXT

suite = unittest.TestSuite()
suite.addTest(TestEmail("test_01"))
suite.addTest(TestEmail("test_03"))
with open("result1.txt", "a", encoding="utf-8") as f:
runner = unittest.TextTestRunner(stream=f, verbosity=2).run(suite)

测试结果输出到HTML

suite = unittest.TestSuite()
suite.addTests([TestEmail("test_01"), TestEmail("test_03")])
with open(r"result1.html", "wb") as f:
HTMLTestRunner.HTMLTestRunner(stream=f, verbosity=2, title="测试报告", description="测试报告详情").run(suite)

pyton unittest的更多相关文章

  1. python_单元测试unittest

    Python自带一个单元测试框架是unittest模块,用它来做单元测试,它里面封装好了一些校验返回的结果方法和一些用例执行前的初始化操作. 步骤1:首先引入unittest模块--import un ...

  2. python单元测试unittest

    单元测试作为任何语言的开发者都应该是必要的,因为时隔数月后再回来调试自己的复杂程序时,其实也是很崩溃的事情.虽然会很快熟悉内容,但是修改和 调试将是一件痛苦的事情,如果你在修改了代码后出现问题的话,而 ...

  3. Python 下的unittest测试框架

    unittest测试框架,直接上图吧: data:数据:主要格式为CSV:读取方式:csv.reade: public:封装的模块:通用的模块单独封装,所需参数设置为变量: testcase:测试用例 ...

  4. Python unittest appium

    import unittest from appium import webdriver from appium.common.exceptions import NoSuchContextExcep ...

  5. selenium-webdriver(python) (十六) --unittest 框架

    学习unittest 很好的一个切入点就是从selenium IDE 录制导出脚本.相信不少新手学习selenium 也是从IED 开始的. IDE学习参考: 菜鸟学自动化测试(一)----selen ...

  6. Node.js的UnitTest单元测试

    body{ font: 16px/1.5em 微软雅黑,arial,verdana,helvetica,sans-serif; } 在专业化的软件开发过程中,无论什么平台语言,现在都需要UnitTes ...

  7. unittest使用过程中sys.exit(not self.result.wasSuccessful())

    起因: 在运行下面的unittest过程中出现了个Traceback: 被测试脚本: # splitter.py def split(line, types=None, delimiter=None) ...

  8. 三言两语聊Python模块–单元测试模块unittest

    实际上unittest模块才是真正意义上的用于测试的模块,功能强大的单元测试模块. 继续使用前面的例子: # splitter.py def split(line, types=None, delim ...

  9. unittest测试驱动之HTMLTestRunner.py

    对于自动化来说,测试报告是必须的,在敏捷化的团队中,团队中的成员需要自动化这边提供自动化的测试报告,来判断系统的整体质量以及下一步的测试策略.单元测试库生成测试输出到控制台的窗口上,但是这样的结果看起 ...

随机推荐

  1. Python *Mix_w

    Python的历史起源: 1989年圣诞节期间,由吉多.范罗苏姆创始. Python的优点"优美""明确""简单" python是一门解释型 ...

  2. 绑定的jndi获得connection时,出的错,java.io.NotSerializableException

    求助:java.io.NotSerializableException 最近系统频繁出现Lookup error: java.io.WriteAbortedException: Writing abo ...

  3. vuex-getter

    store 的计算属性. getter 的返回值会根据它的依赖被缓存起来,且只有当它的依赖值发生了改变才会被重新计算 const store = new Vuex.Store({ state: { t ...

  4. 【深入理解Java集合框架】红黑树讲解(上)

    来源:史上最清晰的红黑树讲解(上) - CarpenterLee 作者:CarpenterLee(转载已获得作者许可,如需转载请与原作者联系) 文中所有图片点击之后均可查看大图! 史上最清晰的红黑树讲 ...

  5. eclipse工具类及插件(修改eclipse.ini文件及作者名字)

    https://jingyan.baidu.com/album/9158e0005633c0a254122807.html?picindex=1 (修改eclipse.ini文件及作者名字) http ...

  6. 下载EU台网(欧洲台网)的地震波数据

    retrievedata.py ### here first to check the existence of the focal mechanism event file in the NDK d ...

  7. keil的可烧写hex文件生成

    右键Target1 Options Target for ‘Target1’ ...->Output->Create Executable:->Create HEX File Bui ...

  8. usermod语法

    语法 usermod [-LU][-c <备注>][-d <登入目录>][-e <有效期限>][-f <缓冲天数>][-g <群组>][-G ...

  9. Windows10 VS2017 C++ Json解析(使用jsoncpp库)

    1.项目必须是win32 2.生成的lib_json.lib放到工程目录下 3.incldue的头文件放到工程目录,然后设置工程->属性->配置属性->vc++目录->包含目录 ...

  10. Locust 参数化

    概述: 和Loadrunner一样对于多用户并发时,重复登入或者数据的重复使用会造成脚本的失败,那么我们引入Loadrunner的参数化概念,对用户数据进行参数化来使脚本运行成功. 头绪:   use ...