UnitTest Framework - Ausnahmetest

Das Python-Testframework bietet die folgenden Assertionsmethoden, um zu überprüfen, ob Ausnahmen ausgelöst werden.

assertRaises (Ausnahme, aufrufbar, * args, ** kwds)

Testen Sie, ob eine Ausnahme (erstes Argument) ausgelöst wird, wenn eine Funktion mit Positions- oder Schlüsselwortargumenten aufgerufen wird. Der Test besteht, wenn die erwartete Ausnahme ausgelöst wird, ist ein Fehler, wenn eine andere Ausnahme ausgelöst wird, oder schlägt fehl, wenn keine Ausnahme ausgelöst wird. Um eine Gruppe von Ausnahmen abzufangen, kann ein Tupel mit den Ausnahmeklassen als Ausnahme übergeben werden.

Im folgenden Beispiel wird eine Testfunktion definiert, um zu überprüfen, ob ZeroDivisionError ausgelöst wird.

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()

Die Funktion testraise () verwendet die Funktion assertRaises (), um festzustellen, ob beim Aufrufen der Funktion div () eine Division durch Null erfolgt. Der obige Code löst eine Ausnahme aus. Ändert die Argumente in div () wie folgt:

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

Wenn ein Code mit diesen Änderungen ausgeführt wird, schlägt der Test fehl, da ZeroDivisionError nicht auftritt.

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 (Ausnahme, regulärer Ausdruck, aufrufbar, * args, ** kwds)

Testet , ob Regexp mit der Zeichenfolgendarstellung der ausgelösten Ausnahme übereinstimmt . regexp kann ein Objekt mit regulären Ausdrücken oder eine Zeichenfolge sein, die einen regulären Ausdruck enthält, der für die Verwendung durch re.search () geeignet ist.

Das folgende Beispiel zeigt, wie assertRaisesRegexp () verwendet wird -

import unittest
import re

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

Hier schlägt der TestraseRegex () -Test nicht als erstes Argument fehl. "Punkt" befindet sich in der zweiten Argumentzeichenfolge.

================================================================
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
----------------------------------------------------------------------

Die Änderung ist jedoch wie unten gezeigt -

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

Die TypeError-Ausnahme wird ausgelöst. Daher wird das folgende Ergebnis angezeigt:

================================================================
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"
----------------------------------------------------------------------