日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

全面介紹python中很常用的單元測試框架unitest

瀏覽:126日期:2022-07-02 11:40:08
1、unitest主要功能模塊介紹

unitest主要包含TestCase、TestSuite、TestLoader、TextTestRunner、TextTestResult這幾個功能模塊。

TestCase:一個TestCase實例就是一個測試用例,一個測試用例就是一個完整的測試流程,包括測試前環境的搭建,測試代碼的執行,以及測試后環境的還原或者銷毀。元測試的本質也就在這里,一個測試用例是一個完整的測試單元,可以對某一具體問題進行檢查驗證。 TestSuite:多個測試用例集合在一起就是TestSuite,TestSuite也可以嵌套TestSuite。 TestLoader:TestLoader的作用是將Testcase加載到TestSuite中。 TextTestRunner:TextTestRunner是用來執行測試用例的,其中的run(test)會執行TestSuite/TestCase中的run(result)方法。 TextTestResult:TextTestResult用來保存測試結果,其中包括運行了多少測試用例,成功了多少,失敗了多少等信息。

整個流程為:寫好TestCase,然后由TestLoader加載TestCase到TestSuite,然后由TextTestRunner來運行TestSuite,運行的結果保存在TextTestResult中。

2、實例介紹

首先準備幾個待測的方法,寫在test_func.py中。

def add(a, b): return a + bdef multi(a, b): return a * bdef lower_str(string): return string.lower()def square(x): return x ** 2

準備好幾個待測的方法之后,為這些方法寫一個測試用例,寫入our_testcase.py中。

import unittestfrom test_func import *class TestFunc(unittest.TestCase): '''Test test_func.py''' def test_add(self): '''Test func add''' self.assertEqual(3, add(1, 2)) self.assertNotEqual(3, add(1, 3)) def test_multi(self): '''Test func multi''' self.assertEqual(6, multi(2, 3)) self.assertNotEqual(8, multi(3, 3)) def test_lower_str(self): '''Test func lower_str''' self.assertEqual('abc', lower_str('ABC')) self.assertNotEqual('Dce', lower_str('DCE')) def test_square(self): '''Test func square''' self.assertEqual(17, square(4)) # 這里故意設計一個會出錯的用例,測試4的平方等于17,實際上并不等于。 self.assertNotEqual(35, square(6))if __name__ == ’__main__’: unittest.main()

這里寫好之后,進入命令行終端,執行python our_testcase.py,執行結果如下。

...F======================================================================FAIL: test_square (__main__.TestFunc)Test func square----------------------------------------------------------------------Traceback (most recent call last): File 'our_testcase.py', line 27, in test_square self.assertEqual(17, square(4))AssertionError: 17 != 16----------------------------------------------------------------------Ran 4 tests in 0.000sFAILED (failures=1)

這里分析一下這個執行結果。首先能夠看到一共運行了4個測試用例,失敗了1個,并且給出了失敗原因,AssertionError: 17 != 16,這是我們故意留下的錯誤漏洞,被測試用例測試出來了。

第一行...F中,一個點.代表測試成功,F代表失敗,我們的測試結果中,前三個成功了,第四個失敗了,總共是四個測試,其余的符號中E代表出錯,S代表跳過。

特別說明的一點是,測試的執行順序跟方法的順序沒有關系,四個測試是隨機先后執行的。

每個測試方法編寫的時候,都要以test開頭,比如test_square,否則是不被unitest識別的。

在unitest.main()中加上verbosity參數可以控制輸出的錯誤報告的詳細程序,默認是1,如果設為0,則不輸出每一用例的執行結果,即上面的第一行的執行結果內容。如果設為2,則輸出詳細的執行結果。

修改our_testcase.py中主函數。

if __name__ == ’__main__’: unittest.main(verbosity=2)

執行結果如下。

test_add (__main__.TestFunc)Test func add ... oktest_lower_str (__main__.TestFunc)Test func lower_str ... oktest_multi (__main__.TestFunc)Test func multi ... oktest_square (__main__.TestFunc)Test func square ... FAIL======================================================================FAIL: test_square (__main__.TestFunc)Test func square----------------------------------------------------------------------Traceback (most recent call last): File 'our_testcase.py', line 27, in test_square self.assertEqual(17, square(4))AssertionError: 17 != 16----------------------------------------------------------------------Ran 4 tests in 0.000sFAILED (failures=1)

可以看到,每一個用例的詳細執行情況以及用例名,用例描述均被輸出了出來,在測試方法下加代碼示例中的'''Doc String''',在用例執行時,會將該字符串作為此用例的描述,加合適的注釋能夠使輸出的測試報告更加便于閱讀。

3、組織TestSuite

按照上面的測試方法,我們無法控制用例執行的順序,這樣顯然是不合理的,因為在一些測試過程中,我們肯定需要控制先測試某些用例,再測試某些用例,這些用例有先后的因果關系。在這里,我們就需要用到TestSuite。我們添加到TestSuite中的case是會按照添加的順序執行的。

還有一個問題是,我們現在只有一個測試文件,我們直接執行該文件即可,但如果有多個測試文件,怎么進行組織,總不能一個個文件執行吧,答案也在TestSuite中。

新建一個文件,test_suite.py。

import unittestfrom our_testcase import TestFuncif __name__ == ’__main__’: suite = unittest.TestSuite() tests = [TestFunc('test_square'), TestFunc('test_lower_str'), TestFunc('test_multi')] suite.addTests(tests) runner = unittest.TextTestRunner(verbosity=2) runner.run(suite)

執行結果如下。

test_square (our_testcase.TestFunc)Test func square ... FAILtest_lower_str (our_testcase.TestFunc)Test func lower_str ... oktest_multi (our_testcase.TestFunc)Test func multi ... ok======================================================================FAIL: test_square (our_testcase.TestFunc)Test func square----------------------------------------------------------------------Traceback (most recent call last): File '/Users/luyuze/projects/test/our_testcase.py', line 27, in test_square self.assertEqual(17, square(4))AssertionError: 17 != 16----------------------------------------------------------------------Ran 3 tests in 0.000sFAILED (failures=1)

這樣,用例執行的順序就是按照我們添加進去的順序來執行的了。

上面使用的是TestSuite的addTests()方法,并直接傳入TestCase列表,也有一些其他的方法可以向TestSuite中添加用例。

# 直接用addTest方法添加單個TestCasesuite.addTest(TestMathFunc('test_multi'))# 使用loadTestFromName,傳入模塊名.TestCase名,下面倆方法效果相同suite.addTests(unittest.TestLoader().loadTestsFromName(’our_testcase.TestFunc’))suite.addTests(unittest.TestLoader().loadTestsFromNames([’our_testcase.TestFunc’]))# loadTestsFromTestCase(),傳入TestCasesuite.addTests(unittest.TestLoader().loadTestsFromTestCase(TestFunc))

用TestLoader的方法是無法對case進行排序的,同時,suite中也可以套suite。

4、輸出文件

用例組織好了,但是結果只能輸出到控制臺,這樣沒辦法查看之前的執行記錄,我們想將結果輸出到文件。

修改test_suite.py。

import unittestfrom our_testcase import TestFuncif __name__ == ’__main__’: suite = unittest.TestSuite() tests = [TestFunc('test_square'), TestFunc('test_lower_str'), TestFunc('test_multi')] suite.addTests(tests) with open(’UnitestTextReport.txt’, ’a’) as f: runner = unittest.TextTestRunner(stream=f, verbosity=2) runner.run(suite)5、測試前后的處理

在之前的測試中,可能會存在這樣的問題:如果要在測試之前準備環境,測試完成之后做一些清理怎么辦?這里需要用到的是setUp()和tearDown()。

修改our_testcase.py。

import unittestfrom test_func import *class TestFunc(unittest.TestCase): '''Test test_func.py''' def setUp(self): print('do something before testcase') def test_add(self): '''Test func add''' self.assertEqual(3, add(1, 2)) self.assertNotEqual(3, add(1, 3)) def test_multi(self): '''Test func multi''' self.assertEqual(6, multi(2, 3)) self.assertNotEqual(8, multi(3, 3)) def test_lower_str(self): '''Test func lower_str''' self.assertEqual('abc', lower_str('ABC')) self.assertNotEqual('Dce', lower_str('DCE')) def test_square(self): '''Test func square''' self.assertEqual(17, square(4)) self.assertNotEqual(35, square(6)) def tearDownClass(self): print('do something after testcase')if __name__ == ’__main__’: unittest.main(verbosity=2)

執行結果:

test_add (__main__.TestFunc)Test func add ... do something before testcasedo something after testcaseoktest_lower_str (__main__.TestFunc)Test func lower_str ... do something before testcasedo something after testcaseoktest_multi (__main__.TestFunc)Test func multi ... do something before testcasedo something after testcaseoktest_square (__main__.TestFunc)Test func square ... do something before testcasedo something after testcaseFAIL======================================================================FAIL: test_square (__main__.TestFunc)Test func square----------------------------------------------------------------------Traceback (most recent call last): File 'our_testcase.py', line 30, in test_square self.assertEqual(17, square(4))AssertionError: 17 != 16----------------------------------------------------------------------Ran 4 tests in 0.001sFAILED (failures=1)

可以發現setUp()和tearDown()在每個case前后都執行了一次。如果要在所有case執行之前和所有case執行之后準備和清理環境,我們可以使用setUpClass() 與 tearDownClass()。

class TestFunc(unittest.TestCase): '''Test test_func.py''' @classmethod def setUpClass(cls): print 'This setUpClass() method only called once.' @classmethod def tearDownClass(cls): print 'This tearDownClass() method only called once too.'6、跳過case

如果我們臨時想要跳過某個case不執行,unitest也有相應的方法。

1、skip裝飾器

# -*- coding: utf-8 -*-import unittestfrom test_func import *class TestFunc(unittest.TestCase): '''Test test_func.py''' @unittest.skip(’do not run this case’) def test_add(self): '''Test func add''' self.assertEqual(3, add(1, 2)) self.assertNotEqual(3, add(1, 3)) def test_multi(self): '''Test func multi''' self.assertEqual(6, multi(2, 3)) self.assertNotEqual(8, multi(3, 3)) def test_lower_str(self): '''Test func lower_str''' self.assertEqual('abc', lower_str('ABC')) self.assertNotEqual('Dce', lower_str('DCE')) def test_square(self): '''Test func square''' self.assertEqual(17, square(4)) self.assertNotEqual(35, square(6))if __name__ == ’__main__’: unittest.main(verbosity=2)

執行結果:

test_add (__main__.TestFunc)Test func add ... skipped ’do not run this case’test_lower_str (__main__.TestFunc)Test func lower_str ... oktest_multi (__main__.TestFunc)Test func multi ... oktest_square (__main__.TestFunc)Test func square ... FAIL======================================================================FAIL: test_square (__main__.TestFunc)Test func square----------------------------------------------------------------------Traceback (most recent call last): File 'our_testcase.py', line 28, in test_square self.assertEqual(17, square(4))AssertionError: 17 != 16----------------------------------------------------------------------Ran 4 tests in 0.000sFAILED (failures=1, skipped=1)

結果顯示為,總共執行4個測試,1個失敗,1個被跳過。

skip裝飾器一共有三個 unittest.skip(reason)、unittest.skipIf(condition, reason)、unittest.skipUnless(condition, reason),skip無條件跳過,skipIf當condition為True時跳過,skipUnless當condition為False時跳過。

2、TestCase.skipTest()方法

class TestFunc(unittest.TestCase): '''Test test_func.py''' def test_add(self): '''Test func add''' self.skipTest('do not run this case') self.assertEqual(3, add(1, 2)) self.assertNotEqual(3, add(1, 3))

效果與第一種是一樣的。

以上就是全面介紹python中很常用的單元測試框架unitest的詳細內容,更多關于python 單元測試框架unitest的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲在线国产日韩欧美| 香蕉国产精品| 亚洲aa在线| 亚洲日本久久| 国产亚洲一区二区三区不卡| 欧美一级久久| 日韩国产在线观看一区| 日韩在线精品| 动漫av一区| 岛国av在线网站| 极品av在线| 黑丝美女一区二区| 亚洲一区区二区| 天堂久久av| 国产一区调教| 国产精品三上| 欧美一级网站| 国产精品久久久久久久久妇女| 狂野欧美性猛交xxxx| 最新中文字幕在线播放| 日韩午夜黄色| 亚洲精品麻豆| 久久精品福利| 免费观看不卡av| 亚洲五月综合| 精品午夜久久| av亚洲免费| 国产视频一区二| 久久九九电影| 国产日产精品_国产精品毛片 | 日本大胆欧美人术艺术动态| 欧美日韩视频免费看| 五月激情久久| 青青国产91久久久久久| 亚洲精品在线观看91| 久久av中文| 亚洲综合色婷婷在线观看| 免费成人在线观看| 日韩欧美在线中字| 日本三级亚洲精品| 色爱av综合网| 热久久国产精品| 久久精品资源| 国产真实久久| 国产欧美日韩一区二区三区在线| 欧美日韩调教| 久久亚洲影院| 国内精品福利| 亚洲精品大全| 合欧美一区二区三区| 成人午夜毛片| 国产精品视频一区视频二区| 99xxxx成人网| 久久精品一区二区三区中文字幕| 亚洲毛片在线| 亚洲福利精品| 亚洲人成亚洲精品| 国产精品成人a在线观看| 亚洲影视一区二区三区| 久久久久九九精品影院| 亚洲人成亚洲精品| 成人羞羞在线观看网站| 国产66精品| 精品国产乱码久久久| 国产精品伦一区二区| 日韩二区三区在线观看| 久久久久亚洲| 久久精品国产999大香线蕉| 国产日韩一区二区三区在线播放| 亚洲欧洲专区| 激情欧美国产欧美| 性欧美69xoxoxoxo| 伊人网在线播放| 秋霞影院一区二区三区| 国产成人精品999在线观看| 欧美精品导航| 91麻豆国产自产在线观看亚洲| 久久精品一区二区不卡| 日本中文字幕一区二区视频| 日韩精品视频一区二区三区| 男女激情视频一区| 午夜性色一区二区三区免费视频| 亚洲aa在线| 久久亚洲人体| 日韩在线不卡| 亚洲一区二区三区高清不卡| 日韩在线观看中文字幕| 国产福利片在线观看| 久久av一区二区三区| 伊人www22综合色| 国产精品亲子伦av一区二区三区| 精品三级av在线导航| 91精品啪在线观看国产18 | 麻豆91精品| 亚洲在线一区| 亚洲精品99| 美女精品在线观看| 欧美一区成人| 色爱综合av| 7777精品| 午夜av成人| 日韩精品免费视频人成 | 国产精品流白浆在线观看| 老牛影视精品| 亚洲我射av| 日韩88av| 一区二区三区四区在线观看国产日韩| 久草精品视频| 一本色道久久精品| 国产videos久久| 亚洲综合精品| 麻豆视频一区| 国内精品福利| av亚洲免费| 国产精品欧美三级在线观看| 美女精品在线观看| 国产精品午夜一区二区三区| 先锋影音久久久| 免费在线欧美黄色| 免费人成精品欧美精品| 99热精品久久| 国产66精品| 国产精品免费精品自在线观看| 免费日韩av| 在线国产一区| 欧美一区三区| 国产伊人精品| 午夜精品网站| 黄色亚洲精品| 黄色国产精品| 在线视频精品| 亚洲深夜视频| 日韩免费在线| 日韩精品网站| 午夜精品久久久久久久久久蜜桃| 激情久久99| 香蕉视频亚洲一级| 亚洲高清二区| 国产亚洲综合精品| 午夜亚洲福利在线老司机| 欧美不卡视频| 中文一区一区三区免费在线观 | 亚洲电影在线| 欧美va亚洲va日韩∨a综合色| 91精品婷婷色在线观看| 午夜国产精品视频| 亚洲ww精品| 国产日韩欧美在线播放不卡| 国产精品视频3p| 精品一区二区三区的国产在线观看| 国产精品99久久免费| 高清一区二区三区av| 福利一区二区三区视频在线观看| 国产欧洲在线| 亚洲少妇在线| 国产精品18| 国产精品视频一区二区三区综合| 亚洲bt欧美bt精品777| 亚洲色图综合| 国产精品白丝av嫩草影院| 蜜桃精品视频| 亚洲性视频h| 免费不卡在线视频| 久久成人高清| 日韩一区欧美二区| 国产精品久久久久av蜜臀| 久久久精品日韩| 美女少妇全过程你懂的久久| 国产精品www.| 国产亚洲精品v| 成人午夜亚洲| 日韩精品国产欧美| 91精品亚洲| 精品国产午夜| 日韩动漫一区| 亚洲免费婷婷| 激情偷拍久久| av资源亚洲| 欧美日韩视频免费观看| 亚洲精品中文字幕乱码| 91欧美日韩| 麻豆一区二区99久久久久| 国产精品婷婷| 欧美亚洲国产一区| av资源中文在线| 国产精品久久久网站| 婷婷五月色综合香五月| 在线亚洲国产精品网站| 今天的高清视频免费播放成人| 精品一区二区三区中文字幕| 亚洲精品乱码| 亚洲欧美日本国产专区一区| 日韩精品欧美激情一区二区| 97精品国产| 高清在线一区| av高清一区| 在线日韩电影| 日韩大片在线| 日韩三区在线| 色婷婷久久久|