unittest斷言的使用

斷言使用

  • 我們可以直接在測試用例里面添加unittest框架自帶的斷言(也就相當于判斷),斷言方法提供了測試結果是True還是False,所有的斷言方法都有一個msg參數(shù),如果指定msg參數(shù)的值,則將該信息作為失敗的錯誤信息返回;

    創(chuàng)新互聯(lián)公司堅持“要么做到,要么別承諾”的工作理念,服務領域包括:網(wǎng)站設計、成都網(wǎng)站設計、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣等服務,滿足客戶于互聯(lián)網(wǎng)時代的和碩網(wǎng)站設計、移動媒體設計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡建設合作伙伴!

  • 如果斷言失敗則拋出一個AssertionError,并標識該測試為失敗狀態(tài);如果成功,則標識該測試為成功狀態(tài);如果異常,則當做錯誤來處理;

先來看一個實例,在一個測試類MyTestCase中添加多個測試方法和斷言


from unittest import TestCase, main, skip
class MyTestCase(TestCase):
    def setUp(self):
        print('setUp')
    def tearDown(self):
        print('tearDown')
    def test_print1(self):
        print('第一個測試用例')
        # unittest框架自帶的斷言,如果不相等,直接拋出異常,相等什么都不做
        self.assertEqual(200, 200, '測試失敗')
    def test_print2(self):
        print('第二個測試用例')
    def test_print3(self):
        print('第三個測試用例')
if __name__ == '__main__':
    main()
========輸出========:
setUp
第一個測試用例
tearDown
setUp
第二個測試用例
tearDown
setUp
第三個測試用例
tearDown

這里有三個測試用例,每個測試用例開始之前都先執(zhí)行了setUp方法,每個測試用例之后都執(zhí)行了tearDown方法。如果我們想要忽略某個測試用例不執(zhí)行,要怎么做?比如忽略第三個測試用例,只需要在第三個測試用例之前加上skip裝飾器:


@skip('do not need test_print3')
    def test_print3(self):
        print('第三個測試用例')

skip裝飾器

  • 我們可以使用unitest.skip裝飾器跳過不需要的測試用例, @unittest .skip(reason) 表示無條件跳過測試用例,reason是用來說明原因的;

  • @unittest .skipIf(conditition,reason) :condititon為true時跳過測試用例;

  • @unittest .skipunless(condition,reason) :condition為False時跳過測試用例;

之前我們學習了setup方法和setUpClass方法,會在每個測試用例的前后都執(zhí)行一遍,那如果我們只想要在所有測試用例的前后執(zhí)行一遍,也就是在整個類中只執(zhí)行一遍要怎么辦呢,我們可以使用setUpClass方法和tearDownClass方法:


from unittest import TestCase, main, skip
class MyTestCase(TestCase):
    @classmethod
    def setUpClass(cls):
        print('setUpClass')
    @classmethod
    def tearDownClass(cls):
        print('tearDownClass')
    def test_print1(self):
        print('第一個測試用例')
        # unittest框架自帶的斷言,如果不相等,直接拋出異常,相等什么都不做
        self.assertEqual(200, 200, '測試失敗')
    def test_print2(self):
        print('第二個測試用例')
    @skip('do not need test_print3')
    def test_print3(self):
        print('第三個測試用例')
if __name__ == '__main__':
    main()
==========輸出===========
setUpClass
第一個測試用例
第二個測試用例
tearDownClass

setUpClass和tearDownClass的使用

  • setup方法和teardown方法在每次執(zhí)行一個測試用例時都會重新執(zhí)行一遍,所以要想在整個類中只執(zhí)行一遍可以用setUpClass和tearDownClass方法;

  • setUpClass :需要添加 @classmethod 裝飾器,在一個類中只會在所有測試用例運行前調用一次;

  • tearDownClass :需要添加 @classmethod 裝飾器,在所有測試用例運行后調用一次;

引入測試用例集,將測試用例與測試集合分開

  • 首先可以先在一個文件中寫好測試用例模塊,然后在另一個文件中導入這個模塊,再使用 unittest.TestSuite類 創(chuàng)建測試套件,然后使用這個類的addTest() 方法將需要被測試的測試用例添加到測試套件中,最后使用 unittest.TextTestRunner類 中的run()方法來運行suite所組裝的測試用例;
  • 測試用例模塊

from unittest import TestCase
from unittest import skip
from unittest import main as main_method
class MyTestCase(TestCase):
    @classmethod
    def setUpClass(cls):
        print('setUpClass')
    @classmethod
    def tearDownClass(cls):
        print('tearDownClass')
    def test_print1(self):
        print('第一個測試用例')
        self.assertEqual(200, 200, '測試失敗')
    def test_print2(self):
        print('第一個測試用例')
    @skip('do not need test_print3')
    def test_print3(self):
        print('第一個測試用例')
if __name__ == '__main__':
    main_method()

  • 測試集模塊

from test1 import MyTestCase
from unittest import TestSuite, TextTestRunner
suite = TestSuite()
# 在測試用例集中添加測試用例, 只添加兩個測試的方法
suite.addTest(MyTestCase('test_print1'))
suite.addTest(MyTestCase('test_print3'))
if __name__ == '__main__':
    # 創(chuàng)建測試runner,執(zhí)行測試用例集
    runner = TextTestRunner()
    runner.run(suite)
=========輸出=============
setUpClass
第一個測試用例
tearDownClass

我們運行這段代碼,只有第一個測試用例輸出,因為我們只將第一個和第三個測試用例加入到測試集中,所有第二個測試用例不會執(zhí)行,而我們在第三個測試用例前面機上了skip裝飾器會跳過此測試用例,所有第三個也不會執(zhí)行啦。

將待測試函數(shù)、測試用例、測試用例集分開

  • 將待測試函數(shù)、測試用例、測試用例集分別放在不同的文件中,先在測試用例中導入待測試函數(shù),然后使用斷言判斷函數(shù)是否正確,接著在測試用例集中創(chuàng)健測試套件,且將測試用例加入套件里面,最后運行;
  • 測試函數(shù)

def add(x, y):
    return x + y
def sub(x, y):
    return x - y

  • 測試用例

from unittest import TestCase
from unittest import skip
from unittest import main as main_method
from add_sub import add, sub
class MyTestCase(TestCase):
    @classmethod
    def setUpClass(cls):
        print('setUpClass')
    @classmethod
    def tearDownClass(cls):
        print('tearDownClass')
    def test_print1(self):
        ret = 1 + 2
        result = add(1, 2)
        self.assertEqual(result, ret, 'test_print1測試失敗')
    def test_print2(self):
        print('第二個測試用例')
    @skip('do not need test_print3')
    def test_print3(self):
        print('第三個測試用例')
if __name__ == '__main__':
    main_method()

  • 測試用例集

from test import MyTestCase
from unittest import TestSuite, TextTestRunner
suite = TestSuite()
# 在測試用例集中添加測試用例
suite.addTest(MyTestCase('test_print1'))
suite.addTest(MyTestCase('test_print2'))
suite.addTest(MyTestCase('test_print3'))
if __name__ == '__main__':
    # 創(chuàng)建測試runner,執(zhí)行測試用例集
    runner = TextTestRunner()
    runner.run(suite)
========輸出=========
setUpClass
第一個測試用例
第二個測試用例
tearDownClass

參考: https://www.9xkd.com/user/plan-view.html?id=4822012440

分享題目:unittest斷言的使用
文章分享:http://bm7419.com/article30/pcgoso.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站營銷、全網(wǎng)營銷推廣、品牌網(wǎng)站制作網(wǎng)頁設計公司、品牌網(wǎng)站設計域名注冊

廣告

聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站網(wǎng)頁設計