国产精品嫩草99av在线_一区在线视频观看_欧美高清一区_欧美 日韩 国产 一区_99精品欧美一区二区三区_久久大香伊蕉在人线观看热2_一色屋精品视频在线观看网站_在线亚洲国产精品网站_亚洲区一区二区三区_你懂的视频一区二区

當前位置:首頁 > 科技  > 軟件

不拼花哨,只拼實用:Unittest指南,干貨為王!

來源: 責編: 時間:2023-09-18 21:40:46 390觀看
導讀Python為開發者提供了內置的單元測試框架 unittest,它是一種強大的工具,能夠有效地編寫和執行單元測試。unittest 提供了完整的測試結構,支持自動化測試的執行,能夠對測試用例進行組織,并且提供了豐富的斷言方法。最終,unit

Python為開發者提供了內置的單元測試框架 unittest,它是一種強大的工具,能夠有效地編寫和執行單元測試。unittest 提供了完整的測試結構,支持自動化測試的執行,能夠對測試用例進行組織,并且提供了豐富的斷言方法。最終,unittest 會生成詳細的測試報告,這個框架非常簡單且易于使用。fuG28資訊網——每日最新資訊28at.com

fuG28資訊網——每日最新資訊28at.com

unittest的工作流程

  • 編寫繼承自 unittest.TestCase 的測試用例類,其中每個測試函數都是一個獨立的測試用例。
  • 使用 TestLoader 加載測試用例,并將它們組織成 TestSuite 對象。
  • 使用 TestRunner 運行 TestSuite 中的測試用例,并輸出測試結果。

fuG28資訊網——每日最新資訊28at.com

使用unittest初級指南

  • 導入 unittest 模塊以及被測試的文件或類。
  • 創建一個測試類,并繼承 unittest.TestCase,所有自定義的單元測試類都要繼承它,作為基類。
  • 重寫 setUp 和 tearDown 方法,用于初始化和清理測試環境(如果有必要)。
  • 定義測試函數,函數名以 test_ 開頭,這樣才能被識別并執行。
  • 在測試函數中使用斷言來判斷測試結果是否符合預期。
  • 調用 unittest.main() 方法運行測試用例,按照函數名的排序執行測試。

以下是一個簡單的例子:fuG28資訊網——每日最新資訊28at.com

import unittestdef login(username, password):    if username == 'kira' and password == '123':        res = {"code": 200, "msg": "登錄成功"}        return res    return {"code": 400, "msg": "登錄失敗"}class TestLogin(unittest.TestCase):    def test_login_success(self):        """測試登錄成功"""        test_data = {"username": "kira", "password": "test"}        expect_data = {"code": 200, "msg": "登錄成功"}        res = login(**test_data)        self.assertEqual(res, expect_data)    def test_login_error_with_error_password(self):        """賬號正確,密碼錯誤,登錄失敗"""        test_data = {"username": "kira", "password": "12345"}        expect_data = {"code": 400, "msg": "登錄失敗"}        res = login(**test_data)        self.assertEqual(res, expect_data)    # 更多測試函數類似...if __name__ == '__main__':    unittest.main()

以上是一個簡單的測試用例,包含了兩個測試函數。運行腳本將輸出測試結果。fuG28資訊網——每日最新資訊28at.com

unittest核心概念

測試腳手架

測試腳手架 是測試用例的前置條件和后置條件,確保測試環境的初始化和清理,從而保證測試的準確性和可靠性。fuG28資訊網——每日最新資訊28at.com

import unittestclass MyTestCase(unittest.TestCase):    @classmethod    def setUpClass(cls):        # 類級別的前置條件設置,整個類運行最先只執行一次        print("setUpClass")    @classmethod    def tearDownClass(cls):        # 類級別的后置條件清理,整個類運行最后結束執行一次        print("tearDownClass")    def setUp(self):        # 測試方法級別的前置條件設置,所有測試方法運行前都執行一次        print("setUp")    def tearDown(self):        # 測試方法級別的后置條件清理,所有測試方法運行結束都執行一次        print("tearDown")    def test_example(self):        # 測試用例        print("test_example")if __name__ == "__main__":    unittest.main()
  • setUp():每個測試方法運行前執行,用于測試前置的初始化工作。
  • tearDown():每個測試方法結束后執行,用于測試后的清理工作。
  • setUpClass():所有的測試方法運行前執行,用于單元測試類運行前的準備工作。使用 @classmethod 裝飾器裝飾,整個測試類運行過程中只會執行一次。
  • tearDownClass():所有的測試方法結束后執行,用于單元測試類運行后的清理工作。使用 @classmethod 裝飾器裝飾,整個測試類運行過程中只會執行一次。

測試用例

測試用例 是最小的測試單元,用于檢測特定的輸入集合的特定的返回值。unittest 提供了 TestCase 基類,所有的測試類都需要繼承該基類,而在該類下的函數如果以 test_ 開頭,則被標識為測試函數:fuG28資訊網——每日最新資訊28at.com

class MyTestCase(unittest.TestCase):    def test_addition(self):        result = 2 + 3        self.assertEqual(result, 5)  # 使用斷言方法驗證結果是否相等    def test_subtraction(self):        result = 5 - 3        self.assertTrue(result == 2)  # 使用斷言方法驗證結果是否為True    # 更多測試用例函數...

斷言方法

以下是常用的斷言方法:fuG28資訊網——每日最新資訊28at.com

  • assertEqual(a, b, msg=None):驗證 a 等于 b。
  • assertNotEqual(a, b):驗證 a 不等于 b。
  • assertTrue(x):驗證 x 是否為 True。
  • assertFalse(x):驗證 x 是否為 False。
  • assertIs(a, b):驗證 a 是否是 b。
  • assertIsNot(a, b):驗證 a 是否不是 b。
  • assertIsNone(x):驗證 x 是否為 None。
  • assertIsNotNone(x):驗證 x 是否不為 None。
  • assertIn(a, b):驗證 a 是否在 b 中。
  • assertNotIn(a, b):驗證 a 是否不在 b 中。
  • assertIsInstance(a, b):驗證 a 是否是 b 類型的實例。
  • assertNotIsInstance(a, b):驗證 a 是否不是 b 類型的實例。

可以使用這些方法進行斷言,也可以直接使用原生的assert來斷言,如果斷言失敗,測試用例會被定義為執行失敗。fuG28資訊網——每日最新資訊28at.com

忽略特定測試方法

unittest 提供了一些方法來跳過特定的測試用例:fuG28資訊網——每日最新資訊28at.com

  • @unittest.skip(reason):強制跳過,reason 是跳過的原因。
  • @unittest.skipIf(condition, reason):當 condition 為 True 時跳過。
  • @unittest.skipUnless(condition, reason):當 condition 為 False 時跳過。
  • @unittest.expectedFailure:如果測試失敗,這個測試用例不會計入失敗的統計。

使用實例方法:self.skipTest() 使用和上述類似。fuG28資訊網——每日最新資訊28at.com

import sysimport unittestclass Test1(unittest.TestCase):    @unittest.expectedFailure  # 即使失敗也會被計為成功的用例    def test_1(self):        assert 1 + 1 == 3    @unittest.skip('無條件跳過')  # 不管什么情況都會進行跳過    def test_2(self):        print("2+2...", 4)    @unittest.skipIf(sys.platform == "win32", "跳過")  # 如果系統平臺為 Windows 則跳過    def test_3(self):        print("3+3...", 6)    @unittest.skipUnless(sys.platform == "win32", "跳過")  # 除非系統平臺為 Windows,否則跳過    def test_4(self):        print("4+4...", 8)    def test_5(self):        self.skipTest("跳過")        print("5+5...", 10)if __name__ == "__main__":    unittest.main(verbosity=2)

測試套件

測試套件用于收集和組織多個測試用例,便于集中執行。fuG28資訊網——每日最新資訊28at.com

  • 通過 unittest.main() 方法直接加載單元測試的測試模塊,這是一種簡單的加載方式。所有測試用例的執行順序按照方法名的字符串表示的 ASCII 碼升序排序,通過命名時使用 test_01_xxx 來指定執行順序。
  • 將所有的單元測試用例 TestCase 加載到測試套件 Test Suite 集合中,然后一次性加載所有測試對象。

通過 TestSuite 對象收集

此方式適用于需要自定義組合特定測試用例的情況。fuG28資訊網——每日最新資訊28at.com

import unittestclass MyTestCase(unittest.TestCase):    def test_addition(self):        result = 2 + 3        self.assertEqual(result, 5)def suite():    suite = unittest.TestSuite()    suite.addTest(MyTestCase('test_addition'))    return suiteif __name__ == '__main__':    runner = unittest.TextTestRunner()    runner.run(suite())

通過 TestLoader 對象收集

TestLoader 是 unittest 框架提供的加載測試用例的類。fuG28資訊網——每日最新資訊28at.com

import unittestif __name__ == '__main__':    loader = unittest.defaultTestLoader        # 自動加載當前模塊中所有以 'test_' 開頭的測試用例函數    suite = loader.loadTestsFromModule(__name__)    runner = unittest.TextTestRunner()    runner.run(suite)
import unittestclass MyTestCase(unittest.TestCase):    def test_addition(self):        result = 2 + 3        self.assertEqual(result, 5)if __name__ == '__main__':    loader = unittest.defaultTestLoader        # 自動加載 MyTestCase 類中的所有測試用例    suite = loader.loadTestsFromTestCase(MyTestCase)    runner = unittest.TextTestRunner()    runner.run(suite)
import unittestif __name__ == '__main__':    loader = unittest.defaultTestLoader        # 自動加載指定名稱的測試用例    suite = loader.loadTestsFromName('module.MyTestCase.test_addition')    runner = unittest.TextTestRunner()    runner.run(suite)
import unittestif __name__ == '__main__':    loader = unittest.defaultTestLoader        # 自動發現并加載指定目錄中的測試用例模塊    suite = loader.discover(start_dir='test_directory', pattern='test_*.py', top_level_dir=None)    runner = unittest.TextTestRunner()    runner.run(suite)

測試運行器

測試運行器是用于執行和輸出測試結果的組件。常用的運行器有:fuG28資訊網——每日最新資訊28at.com

  • unittest.TextTestRunner:這是 unittest 框架中默認的測試運行器,會在命令行輸出測試結果。通過調用 run() 方法運行測試套件,并將測試結果打印到控制臺。
import unittestif __name__ == '__main__':    loader = unittest.defaultTestLoader    suite = loader.discover(start_dir='tests', pattern='test_*.py')        runner = unittest.TextTestRunner()    result = runner.run(suite)
  • HTMLTestRunner:這是一個第三方庫,能夠生成漂亮的 HTML 測試報告,需要進行安裝。你可以通過搜索獲取相關文件進行安裝。
import unittestfrom HTMLTestRunner import HTMLTestRunnerif __name__ == '__main__':    loader = unittest.defaultTestLoader    suite = loader.discover(start_dir='tests', pattern='test_*.py')        with open('test_report.html', 'wb') as report_file:        runner = HTMLTestRunner(stream=report_file, title='Test Report', description='Test Results')        result = runner.run(suite)
  • XMLTestRunner:這是另一個第三方庫,用于生成 XML 格式的測試報告。
import unittestfrom xmlrunner import XMLTestRunnerif __name__ == '__main__':    loader = unittest.defaultTestLoader    suite = loader.discover(start_dir='tests', pattern='test_*.py')        with open('test_report.xml', 'wb') as report_file:        runner = XMLTestRunner(output=report_file)        result = runner.run(suite)

你也可以自定義測試運行器。繼承 unittest.TestRunner 類并實現 run() 方法,以創建自己的測試運行器。fuG28資訊網——每日最新資訊28at.com

import unittestclass MyTestRunner(unittest.TextTestRunner):    def run(self, test):        print("Running tests with MyTestRunner")        result = super().run(test)        return resultif __name__ == '__main__':    loader = unittest.defaultTestLoader    suite = loader.discover(start_dir='tests', pattern='test_*.py')        runner = MyTestRunner()    result = runner.run(suite)

通常使用 HTMLTestRunner 即可滿足需求,它非常易用。fuG28資訊網——每日最新資訊28at.com

實戰一個測試案例

假設有一個測試函數 login:fuG28資訊網——每日最新資訊28at.com

# login.pydef login(username, password):    """模擬登錄校驗"""    if username == 'kira' and password == '123456':        return {"code": 0, "msg": "登錄成功"}    else:        return {"code": 1, "msg": "賬號或密碼不正確"}

設計用例

根據函數的參數和邏輯,設計如下用例:fuG28資訊網——每日最新資訊28at.com

fuG28資訊網——每日最新資訊28at.com

編寫測試用例并運行

import unittestfrom login import loginclass TestLogin(unittest.TestCase):    def test_login_correct(self):        """測試賬號密碼正確"""        test_data = {"username": "kira", "password": "123456"}        expect_data = {"code": 0, "msg": "登錄成功"}        res = login(**test_data)        self.assertEqual(res, expect_data)    def test_login_wrong_password(self):        """測試賬號正確密碼不正確"""        test_data = {"username": "kira", "password": "123"}        expect_data = {"code": 1, "msg": "賬號或密碼不正確"}        res = login(**test_data)        self.assertEqual(res, expect_data)    def test_login_wrong_username(self):        """測試賬號錯誤密碼正確"""        test_data = {"username": "kir", "password": "123456"}        expect_data = {"code": 1, "msg": "賬號或密碼不正確"}        res = login(**test_data)        self.assertEqual(res, expect_data)if __name__ == '__main__':    unittest.main()

這是一個簡單的測試用例,包含了三個測試函數。運行測試用例后,會輸出測試結果,看完是否覺得unittest非常簡單易用。ner.run(suite)fuG28資訊網——每日最新資訊28at.com

本文鏈接:http://m.rrqrq.com/showinfo-26-10432-0.html不拼花哨,只拼實用:Unittest指南,干貨為王!

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: 基于范圍的 for 循環:現代 C++ 循環控制的新思維

下一篇: 2023年需求最大的八種編程語言

標簽:
  • 熱門焦點
Top 国产精品嫩草99av在线_一区在线视频观看_欧美高清一区_欧美 日韩 国产 一区_99精品欧美一区二区三区_久久大香伊蕉在人线观看热2_一色屋精品视频在线观看网站_在线亚洲国产精品网站_亚洲区一区二区三区_你懂的视频一区二区
欧美精品三级日韩久久| 成人av在线网站| 国产精品magnet| 欧美日韩国产一级二级| 亚洲免费色视频| 91啪九色porn原创视频在线观看| 国产欧美一区二区三区另类精品| 亚洲精品在线电影| 亚洲高清网站| 日韩三级高清在线| 精品精品国产高清一毛片一天堂| 午夜不卡在线视频| 亚洲高清资源| 国产午夜精品一区二区三区嫩草 | 7777精品伊人久久久大香线蕉的 | 91精品国产综合久久久蜜臀粉嫩| 伊人色综合久久天天人手人婷| 亚洲欧美日韩国产综合精品二区| 精品日韩av一区二区| 日产国产欧美视频一区精品| 亚洲国产高清视频| 欧美妇女性影城| 亚洲h精品动漫在线观看| 国语自产精品视频在线看抢先版结局 | 欧美影院午夜播放| 亚洲国产成人porn| 99一区二区| 中文字幕在线观看不卡| 青青草国产精品亚洲专区无| 久久成人资源| 欧美国产禁国产网站cc| 久久99国产精品久久| 久久综合导航| 日韩影院精彩在线| 午夜在线a亚洲v天堂网2018| 亚洲一区二区三区不卡国产欧美| 精品999网站| 日韩毛片在线免费观看| 欧美少妇一区| 国产精品乱人伦中文| 欧美日韩三区四区| 久久久久久亚洲综合影院红桃| 成人黄色大片在线观看| 欧美成人精品福利| 国产在线视频一区二区| 欧美激情中文字幕| 国模大尺度一区二区三区| 最新日韩av在线| 在线观看一区欧美| 国产麻豆精品在线| 欧美一级专区免费大片| 欧美激情视频一区二区三区在线播放 | 国产欧美精品在线观看| 一二三区精品| 激情文学综合网| 久久女同精品一区二区| 亚洲精品1区| 老司机免费视频一区二区| 日韩欧美不卡在线观看视频| 国产精品v日韩精品v欧美精品网站| 一区二区三区精品在线观看| 欧美日韩一区不卡| 欧美日韩国产三区| 亚洲超碰精品一区二区| 日本一道高清亚洲日美韩| 在线精品视频免费观看| 91一区在线观看| 亚洲中国最大av网站| 欧美三级韩国三级日本一级| 91美女在线视频| 日韩中文字幕区一区有砖一区| 日韩欧美一二区| 亚洲每日在线| 国产91丝袜在线观看| 亚洲欧美国产毛片在线| 911精品产国品一二三产区| 精品不卡一区二区三区| 国产在线精品一区二区不卡了 | 在线播放/欧美激情| 亚洲精品视频一区二区三区| 国产资源在线一区| 综合久久国产九一剧情麻豆| 欧美精品v日韩精品v韩国精品v| 欧美日韩18| 国产一区二区毛片| 亚洲精品伦理在线| 精品粉嫩超白一线天av| 久久久久久网| 亚洲特色特黄| 国产69精品一区二区亚洲孕妇 | 亚洲色欲色欲www| 日韩欧美精品在线| 91久久精品国产91性色tv| 国产主播一区| 东方欧美亚洲色图在线| 爽爽淫人综合网网站| 国产精品情趣视频| 欧美一区二区精品| 久久国产精品久久精品国产 | 国产乱码精品一区二区三| 一区二区三区在线观看视频| 精品电影一区二区| 欧美日韩综合不卡| 久久精品91| 99一区二区| 国内精品久久国产| av动漫一区二区| 国产另类ts人妖一区二区| 午夜欧美2019年伦理| 中文字幕一区二区三区精华液 | 久久99精品网久久| 亚洲大尺度视频在线观看| 中文字幕一区二区三区蜜月| 26uuu另类欧美亚洲曰本| 欧美精品粉嫩高潮一区二区| 裸体一区二区| 国产视频一区三区| 亚洲黄色免费| 欧美日韩免费精品| 99久久精品免费精品国产| 国产成人日日夜夜| 国产精品一二二区| 久久精品二区亚洲w码| 午夜影院久久久| 亚洲国产精选| 欧美.www| 欧美一区二区在线| 91在线视频免费观看| 国产成人亚洲综合色影视| 97精品国产露脸对白| 91精品国产综合久久蜜臀| 成人app网站| 国产欧美日韩另类视频免费观看 | 久久久久一区二区| 麻豆91精品| 午夜在线精品偷拍| 中文精品视频| 国产人成精品一区二区三| 亚洲裸体视频| 国产日韩欧美三区| 亚洲一卡久久| 色丁香久综合在线久综合在线观看 | 日产欧产美韩系列久久99| 天天综合色天天| 日日夜夜精品视频免费| 久久丁香综合五月国产三级网站 | 1000精品久久久久久久久| 亚洲色图制服诱惑| 亚洲国产综合色| 日本欧美一区二区三区| 九一九一国产精品| 国产精品自拍av| zzijzzij亚洲日本少妇熟睡| 欧美日韩综合网| 9色国产精品| 久久精品国产99精品国产亚洲性色| 久久一区亚洲| 欧美乱妇20p| 久久网这里都是精品| 国产精品久久久久一区二区三区| 一区二区成人在线观看| 日韩不卡一二三区| 国产乱子伦视频一区二区三区 | 在线综合视频| 欧美日韩亚洲丝袜制服| 欧美va亚洲va香蕉在线| 国产免费观看久久| 亚洲一区二区三区免费视频| 久久精品国产精品亚洲红杏| 国产成人精品网址| 含羞草久久爱69一区| 老牛国产精品一区的观看方式| 88在线观看91蜜桃国自产| 国产欧美一区二区精品忘忧草| 亚洲美腿欧美偷拍| 精品一区二区综合| 色综合中文综合网| 男女性色大片免费观看一区二区| 国产成人一区在线| 伊人精品成人久久综合软件| 在线视频一区二区三区| 日韩精品中文字幕在线一区| 国产精品国产馆在线真实露脸| 视频一区视频二区中文| www.色综合.com| 国产偷久久久精品专区| 欧美一二三在线| 亚洲另类春色国产| 国产成人三级在线观看| 亚洲九九精品| 91精品国产综合久久香蕉的特点| 国产精品久久久久久久蜜臀| 蜜臀av性久久久久蜜臀aⅴ流畅| 成人一区在线观看| 亚洲女优在线| 久久综合999| 日韩精品欧美精品| 欧美一区影院| 亚洲情趣在线观看| 狠狠色伊人亚洲综合成人|