UnitTest Framework - İstisnalar Testi

Python test çerçevesi, istisnaların ortaya çıkıp çıkmadığını kontrol etmek için aşağıdaki onaylama yöntemlerini sağlar.

assertRaises (istisna, çağrılabilir, * değiştirgeler, ** kwds)

Herhangi bir konumsal veya anahtar sözcük bağımsız değişkeniyle bir işlev çağrıldığında bir istisnanın (ilk bağımsız değişken) ortaya çıktığını test edin. Beklenen istisna ortaya çıkarsa test başarılı olur, başka bir istisna ortaya çıkarsa bir hatadır veya hiçbir istisna ortaya çıkmazsa başarısız olur. Bir istisna grubunu yakalamak için, istisna sınıflarını içeren bir demet istisna olarak aktarılabilir.

Aşağıdaki örnekte, ZeroDivisionError'ın yükseltilip yükseltilmediğini kontrol etmek için bir test işlevi tanımlanmıştır.

import unittest

def div(a,b):
   return a/b
class raiseTest(unittest.TestCase):
   def testraise(self):
      self.assertRaises(ZeroDivisionError, div, 1,0)

if __name__ == '__main__':
   unittest.main()

Testraise () işlevi, div () işlevi çağrıldığında sıfıra bölmenin gerçekleşip gerçekleşmediğini görmek için assertRaises () işlevini kullanır. Yukarıdaki kod bir istisna oluşturacaktır. Ancak argümanları div () işlevine aşağıdaki gibi değiştirir -

self.assertRaises(ZeroDivisionError, div, 1,1)

Bu değişikliklerle bir kod çalıştırıldığında, ZeroDivisionError oluşmadığından test başarısız olur.

F
================================================================
FAIL: testraise (__main__.raiseTest)
----------------------------------------------------------------------
Traceback (most recent call last):
   File "raisetest.py", line 7, in testraise
      self.assertRaises(ZeroDivisionError, div, 1,1)
AssertionError: ZeroDivisionError not raised

----------------------------------------------------------------------
Ran 1 test in 0.000s

FAILED (failures = 1)

assertRaisesRegexp (istisna, regexp, çağrılabilir, * args, ** kwds)

Düzenli ifadenin , ortaya çıkarılan istisnanın dize gösterimi ile eşleştiğini test eder. regexp, normal bir ifade nesnesi veya re.search () tarafından kullanılmaya uygun bir normal ifade içeren bir dize olabilir.

Aşağıdaki örnek, assertRaisesRegexp () öğesinin nasıl kullanıldığını gösterir -

import unittest
import re

class raiseTest(unittest.TestCase):
   def testraiseRegex(self):
      self.assertRaisesRegexp(TypeError, "invalid", reg,"Point","TutorialsPoint")
      
if __name__ == '__main__':
   unittest.main()

Burada testraseRegex () testi ilk argüman olarak başarısız olmaz. İkinci argüman dizesinde "Nokta" bulunur.

================================================================
FAIL: testraiseRegex (__main__.raiseTest)
----------------------------------------------------------------------
Traceback (most recent call last):
   File "C:/Python27/raiseTest.py", line 11, in testraiseRegex
      self.assertRaisesRegexp(TypeError, "invalid", reg,"Point","TutorialsPoint")
AssertionError: TypeError not raised
----------------------------------------------------------------------

Ancak, değişiklik aşağıda gösterildiği gibidir -

self.assertRaisesRegexp(TypeError, "invalid", reg,123,"TutorialsPoint")

TypeError istisnası atılacak. Bu nedenle, aşağıdaki sonuç görüntülenecektir -

================================================================
FAIL: testraiseRegex (__main__.raiseTest)
----------------------------------------------------------------------
Traceback (most recent call last):
   File "raisetest.py", line 11, in testraiseRegex
      self.assertRaisesRegexp(TypeError, "invalid", reg,123,"TutorialsPoint")
AssertionError: "invalid" does not match 
   "first argument must be string or compiled pattern"
----------------------------------------------------------------------