Python單元測試unittest的具體使用示例
Python中有一個自帶的單元測試框架是unittest模塊,用它來做單元測試,它里面封裝好了一些校驗返回的結(jié)果方法和一些用例執(zhí)行前的初始化操作。
unittest是python的標準測試庫,相比于其他測試框架是python目前使用最廣的測試框架。
unittest有四個比較重要的概念是test fixture, test case, test suite, test runner, 。
在說unittest之前,先說幾個概念:
TestCase 也就是測試用例
TestSuite 多個測試用例集合在一起,就是TestSuite
TestLoader是用來加載TestCase到TestSuite中的
TestRunner是來執(zhí)行測試用例的,測試的結(jié)果會保存到TestResult實例中,包括運行了多少測試用例,成功了多少,失敗了多少等信息
通過dir(unittest),我們可以看到unittest全部的屬性和方法,他們的關(guān)系如下圖所示。
unittest主要類關(guān)系
正常調(diào)用unittest的流程是,TestLoader 自動將測試用例TestCase中加載到TestSuite里,TextTestRunner調(diào)用TestSuite的run方法,順序執(zhí)行里面的TestCase中以test開頭的方法,并得到測試結(jié)果TestResult。在執(zhí)行TestCase過程中,先進行SetUp()環(huán)境準備,執(zhí)行測試代碼,最后tearDown()進行測試的還原。
其中TestLoader在加載過程中,進行添加的TestCase是沒有順序的。一個TestCase里如果存在多個驗證方法的話,會按照方法中test后方首字母的ascii碼從小到大排序后執(zhí)行。
可以通過手動調(diào)用TestSuite的addTest、addTests方法來動態(tài)添加TestCase,這樣既可以確定添加用例的執(zhí)行順序,也可避免TestCase中的驗證方法一定要用test開頭。
下面寫一個簡單的單元測試用例
import unittest class MyTest(unittest.TestCase): # 繼承unittest.TestCase def tearDown(self): # 每個測試用例執(zhí)行之后做操作 print('111') def setUp(self): # 每個測試用例執(zhí)行之前做操作 print('22222') @classmethod def tearDownClass(self): # 必須使用 @ classmethod裝飾器, 所有test運行完后運行一次 print('4444444') @classmethod def setUpClass(self): # 必須使用@classmethod 裝飾器,所有test運行前運行一次 print('33333') def test_a_run(self): self.assertEqual(1, 1) # 測試用例 def test_b_run(self): self.assertEqual(2, 2) # 測試用例 if __name__ == '__main__': unittest.main()#運行所有的測試用例
下面是一些常用的斷言,也就是校驗結(jié)果
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
那如何生成一個測試報告呢,需要加入另外一個模塊了,HTMLTestRunner,這個模塊需要自己安裝,使用執(zhí)行測試用例就會生成一個html的測試報告,里面會有每個測試用例的執(zhí)行結(jié)果,代碼如下:
import HTMLTestRunner import unittest class MyTest(unittest.TestCase):#繼承unittest.TestCase def tearDown(self): #每個測試用例執(zhí)行之后做操作 print('111') def setUp(self): #每個測試用例執(zhí)行之前做操作 print(22222) def test_run(self): # self.assertEqual(1,1) self.assertIs(1,1) #測試用例 def test_run2(self): # self.assertEqual(1,1) self.assertIs(1,1) #測試用例 def test_run3(self): # self.assertEqual(1,1) self.assertIs(1,1) #測試用例 def test_run1(self): # self.assertEqual(1,1) self.assertIs(1,1) #測試用例 if __name__ == '__main__': test_suite = unittest.TestSuite()#創(chuàng)建一個測試集合 test_suite.addTest(MyTest('test_run1'))#測試套件中添加測試用例 #test_suite.addTest(unittest.makeSuite(MyTest))#使用makeSuite方法添加所有的測試方法 fp = open('res.html','wb')#打開一個保存結(jié)果的html文件 runner = HTMLTestRunner.HTMLTestRunner(stream=fp,title='api測試報告',description='測試情況') #生成執(zhí)行用例的對象 runner.run(test_suite) #執(zhí)行測試套件
如果我們有很多個模塊,每個模塊下面都寫了很多python文件,每個python文件里面都有測試用例,那怎么把這個目錄下的用例都執(zhí)行了呢,就要先找到這個目錄下的所有python文件,然后找到里面的測試用例,逐個執(zhí)行,代碼如下:
import unittest,HTMLTestRunner suite = unittest.TestSuite()#創(chuàng)建測試套件 all_cases = unittest.defaultTestLoader.discover('.','test_*.py') #找到某個目錄下所有的以test開頭的Python文件里面的測試用例 for case in all_cases: suite.addTests(case)#把所有的測試用例添加進來 fp = open('res.html','wb') runner = HTMLTestRunner.HTMLTestRunner(stream=fp,title='all_tests',description='所有測試情況') runner.run(suite) #運行測試
我們在后續(xù)進行持續(xù)集成的時候,要讓代碼自動運行,就會用到Jenkins了,但是上面產(chǎn)生的測試報告都是html格式的,Jenkins不認識,就在Jenkins里面顯示不出來。那咱們就要產(chǎn)生一些Jenkins認識的測試報告,Jenkins認識xml格式的報告,那咱們就產(chǎn)生xml格式的唄,就需要用一個新的模塊,xmlrunner,安裝直接 pip install xmlrunner即可,代碼如下:
import unittest import xmlrunner #導(dǎo)入這個模塊 class My(unittest.TestCase): def test1(self,a,b,c): self.assertEqual(a+b,c) if __name__=='__main__': test_suite = unittest.TestSuite() test_suite.addTest(unittest.makeSuite(My)) runner = xmlrunner.XMLTestRunner(output='report')#指定報告放的目錄 runner.run(test_suite)
然后咱們運行,可以看到在report目錄下已經(jīng)產(chǎn)生了xml格式的報告了,而且還自動把日期加上了
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
python?pygame英雄循環(huán)飛行及作業(yè)示例
這篇文章主要為大家介紹了python?pygame英雄循環(huán)飛行及作業(yè)實現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-08-08Python根據(jù)詞頻信息(xlsx、csv文件)繪制詞云圖全過程(wordcloud)
這篇文章主要給大家介紹了關(guān)于Python根據(jù)詞頻信息(xlsx、csv文件)繪制詞云圖的相關(guān)資料,wordcloud是基于Python開發(fā)的詞云生成庫,功能強大使用簡單,文中通過代碼介紹的非常詳細,需要的朋友可以參考下2024-06-06解決pyCharm中 module 調(diào)用失敗的問題
今天小編就為大家分享一篇解決pyCharm中 module 調(diào)用失敗的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-02-02